Merge "Add functional test for notifier backend"
This commit is contained in:
commit
9ddcab56a3
@ -1,4 +1,4 @@
|
||||
[DEFAULT]
|
||||
test_command=OS_STDOUT_CAPTURE=1 OS_STDERR_CAPTURE=1 ${PYTHON:-python} -m subunit.run discover -t ./ ./osprofiler/tests/unit $LISTOPT $IDOPTION
|
||||
test_command=OS_STDOUT_CAPTURE=1 OS_STDERR_CAPTURE=1 ${PYTHON:-python} -m subunit.run discover -t ./ ${OS_TEST_PATH:-./osprofiler/tests/unit} $LISTOPT $IDOPTION
|
||||
test_id_option=--load-list $IDFILE
|
||||
test_list_option=--list
|
||||
|
0
osprofiler/tests/functional/__init__.py
Normal file
0
osprofiler/tests/functional/__init__.py
Normal file
3
osprofiler/tests/functional/config.cfg
Normal file
3
osprofiler/tests/functional/config.cfg
Normal file
@ -0,0 +1,3 @@
|
||||
|
||||
[profiler]
|
||||
connection_string="messaging://"
|
110
osprofiler/tests/functional/test_driver.py
Normal file
110
osprofiler/tests/functional/test_driver.py
Normal file
@ -0,0 +1,110 @@
|
||||
# Copyright (c) 2016 VMware, Inc.
|
||||
# All Rights Reserved.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||
# not use this file except in compliance with the License. You may obtain
|
||||
# a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
import os
|
||||
|
||||
from oslo_config import cfg
|
||||
|
||||
from osprofiler.drivers import base
|
||||
from osprofiler import initializer
|
||||
from osprofiler import opts
|
||||
from osprofiler import profiler
|
||||
from osprofiler.tests import test
|
||||
|
||||
|
||||
CONF = cfg.CONF
|
||||
|
||||
|
||||
class DriverTestCase(test.TestCase):
|
||||
|
||||
SERVICE = "service"
|
||||
PROJECT = "project"
|
||||
|
||||
def setUp(self):
|
||||
super(DriverTestCase, self).setUp()
|
||||
CONF(["--config-file", os.path.dirname(__file__) + "/config.cfg"])
|
||||
opts.set_defaults(CONF,
|
||||
enabled=True,
|
||||
trace_sqlalchemy=False,
|
||||
hmac_keys="SECRET_KEY")
|
||||
|
||||
@profiler.trace_cls("rpc", hide_args=True)
|
||||
class Foo(object):
|
||||
|
||||
def bar(self, x):
|
||||
return self.baz(x, x)
|
||||
|
||||
def baz(self, x, y):
|
||||
return x * y
|
||||
|
||||
def _assert_dict(self, info, **kwargs):
|
||||
for key in kwargs:
|
||||
self.assertEqual(kwargs[key], info[key])
|
||||
|
||||
def _assert_child_dict(self, child, base_id, parent_id, name, fn_name):
|
||||
self.assertEqual(parent_id, child["parent_id"])
|
||||
|
||||
exp_info = {"name": "rpc",
|
||||
"service": self.SERVICE,
|
||||
"project": self.PROJECT}
|
||||
self._assert_dict(child["info"], **exp_info)
|
||||
|
||||
exp_raw_info = {"project": self.PROJECT,
|
||||
"service": self.SERVICE}
|
||||
raw_start = child["info"]["meta.raw_payload.%s-start" % name]
|
||||
self._assert_dict(raw_start["info"], **exp_raw_info)
|
||||
self.assertEqual(fn_name, raw_start["info"]["function"]["name"])
|
||||
exp_raw = {"name": "%s-start" % name,
|
||||
"service": self.SERVICE,
|
||||
"trace_id": child["trace_id"],
|
||||
"project": self.PROJECT,
|
||||
"base_id": base_id}
|
||||
self._assert_dict(raw_start, **exp_raw)
|
||||
|
||||
raw_stop = child["info"]["meta.raw_payload.%s-stop" % name]
|
||||
self._assert_dict(raw_stop["info"], **exp_raw_info)
|
||||
exp_raw["name"] = "%s-stop" % name
|
||||
self._assert_dict(raw_stop, **exp_raw)
|
||||
|
||||
def test_get_report(self):
|
||||
initializer.init_from_conf(
|
||||
CONF, None, self.PROJECT, self.SERVICE, "host")
|
||||
profiler.init("SECRET_KEY", project=self.PROJECT, service=self.SERVICE)
|
||||
|
||||
foo = DriverTestCase.Foo()
|
||||
foo.bar(1)
|
||||
|
||||
engine = base.get_driver(CONF.profiler.connection_string,
|
||||
project=self.PROJECT,
|
||||
service=self.SERVICE,
|
||||
host="host",
|
||||
conf=CONF)
|
||||
base_id = profiler.get().get_base_id()
|
||||
res = engine.get_report(base_id)
|
||||
|
||||
self.assertEqual("total", res["info"]["name"])
|
||||
self.assertEqual(2, res["stats"]["rpc"]["count"])
|
||||
self.assertEqual(1, len(res["children"]))
|
||||
|
||||
cbar = res["children"][0]
|
||||
self._assert_child_dict(
|
||||
cbar, base_id, base_id, "rpc",
|
||||
"osprofiler.tests.functional.test_driver.Foo.bar")
|
||||
|
||||
self.assertEqual(1, len(cbar["children"]))
|
||||
cbaz = cbar["children"][0]
|
||||
self._assert_child_dict(
|
||||
cbaz, base_id, cbar["trace_id"], "rpc",
|
||||
"osprofiler.tests.functional.test_driver.Foo.baz")
|
11
tox.ini
11
tox.ini
@ -16,6 +16,17 @@ usedevelop = True
|
||||
commands = python setup.py testr --slowest --testr-args='{posargs}'
|
||||
distribute = false
|
||||
|
||||
[testenv:functional]
|
||||
basepython = python2.7
|
||||
setenv = {[testenv]setenv}
|
||||
OS_TEST_PATH=./osprofiler/tests/functional
|
||||
deps = {[testenv]deps}
|
||||
|
||||
[testenv:functional-py35]
|
||||
basepython = python3.5
|
||||
setenv = {[testenv:functional]setenv}
|
||||
deps = {[testenv:functional]deps}
|
||||
|
||||
[testenv:pep8]
|
||||
commands =
|
||||
flake8
|
||||
|
Loading…
Reference in New Issue
Block a user