Merge "Refactor process test"

This commit is contained in:
Jenkins 2016-05-25 14:48:04 +00:00 committed by Gerrit Code Review
commit f5eee8fb16
2 changed files with 75 additions and 29 deletions

View File

@ -2,13 +2,14 @@ import os
import sys
import inspect
import monasca_agent.collector.checks as checks
import monasca_agent.common.config as configuration
from monasca_agent.common.util import Paths
# Base config must be loaded before AgentCheck or it will try to load with no config file
base_config = configuration.Config(os.path.join(os.path.dirname(__file__), 'test-agent.yaml'))
from monasca_agent.collector.checks import AgentCheck
base_config = configuration.Config(os.path.join(os.path.dirname(__file__),
'test-agent.yaml'))
def load_check(name, config):
checksd_path = Paths().get_checksd_path()
@ -19,17 +20,18 @@ def load_check(name, config):
check_class = None
classes = inspect.getmembers(check_module, inspect.isclass)
for name, clsmember in classes:
if clsmember == AgentCheck:
if clsmember == checks.AgentCheck:
continue
if issubclass(clsmember, AgentCheck):
if issubclass(clsmember, checks.AgentCheck):
check_class = clsmember
if AgentCheck in clsmember.__bases__:
if checks.AgentCheck in clsmember.__bases__:
continue
else:
break
if check_class is None:
raise Exception(
"Unable to import check %s. Missing a class that inherits AgentCheck" % name)
"Unable to import check %s. Missing a class that inherits "
"AgentCheck" % name)
init_config = config.get('init_config', None)
instances = config.get('instances')
@ -38,11 +40,12 @@ def load_check(name, config):
# init the check class
try:
return check_class(
name, init_config=init_config, agent_config=agent_config, instances=instances)
except:
name, init_config=init_config, agent_config=agent_config,
instances=instances)
except Exception:
# Backwards compatitiblity for old checks that don't support the
# instances argument.
c = check_class(name, init_config=init_config, agent_config=agent_config)
c = check_class(name, init_config=init_config,
agent_config=agent_config)
c.instances = instances
return c

View File

@ -1,5 +1,4 @@
import os
import psutil
import mock
import unittest
from tests.common import load_check
@ -7,40 +6,84 @@ from tests.common import load_check
class TestSimpleProcess(unittest.TestCase):
def setUp(self):
p = psutil.Process(os.getpid())
config = {'init_config': {}, 'instances': [{'name': 'test',
'search_string': [p.name()],
'detailed': False}]}
self.psutil_process_iter_patcher = mock.patch('psutil.process_iter')
self.mock_process_iter = self.psutil_process_iter_patcher.start()
process_attrs = {
'name.return_value': 'process_name',
'pid': 1234,
'username.return_value': 'user',
'cmdline.return_value': '/usr/bin/process_name'
}
process = mock.Mock(**process_attrs)
self.mock_process_iter.return_value = [process]
config = {'init_config': {},
'instances': [{'name': 'test',
'search_string': ['process_name'],
'detailed': False}]}
self.check = load_check('process', config)
def tearDown(self):
self.psutil_process_iter_patcher.stop()
def testPidCount(self):
self.check.run()
metrics = self.check.get_metrics()
self.assertTrue(len(metrics) == 1, metrics)
self.assertTrue(metrics[0].name == 'process.pid_count')
self.assertEqual(1, len(metrics))
self.assertEqual('process.pid_count', metrics[0].name)
class TestDetailedProcess(unittest.TestCase):
def setUp(self):
p = psutil.Process(os.getpid())
config = {'init_config': {}, 'instances': [{'name': 'test',
'search_string': [p.name()],
'detailed': True}]}
self.psutil_process_patcher = mock.patch('psutil.Process')
self.psutil_process_iter_patcher = mock.patch('psutil.process_iter')
self.mock_process = self.psutil_process_patcher.start()
self.mock_process_iter = self.psutil_process_iter_patcher.start()
process_attrs = {
'name.return_value': 'process_name',
'pid': 1234,
'username.return_value': 'user',
'cmdline.return_value': '/usr/bin/process_name',
'memory_info_ex.return_value': mock.Mock(rss=1048576),
'num_threads.return_value': 1,
'num_fds.return_value': 1,
'cpu_percent.return_value': 1,
'io_counters.return_value': mock.Mock(**{'read_count': 1,
'write_count': 1,
'read_bytes': 1024,
'write_bytes': 1024})
}
process = mock.Mock(**process_attrs)
self.mock_process_iter.return_value = [process]
self.mock_process.return_value = process
config = {'init_config': {},
'instances': [{'name': 'test',
'search_string': ['process_name'],
'detailed': True}]}
self.check = load_check('process', config)
def tearDown(self):
self.psutil_process_patcher.stop()
self.psutil_process_iter_patcher.stop()
def testPidCount(self):
self.check.run()
metrics = self.check.get_metrics()
self.assertTrue(len(metrics) > 1, metrics)
self.assertGreater(len(metrics), 1)
def run_check(self):
self.check.prepare_run()
self.check.run()
metrics = self.check.get_metrics()
measurement_names = []
for metric in metrics:
measurement_names.append(metric.name)
measurement_names = [metric.name for metric in metrics]
measurement_names.sort()
return measurement_names
@ -58,9 +101,9 @@ class TestDetailedProcess(unittest.TestCase):
'process.pid_count',
'process.thread_count']
self.assertEquals(measurement_names, expected_names)
self.assertListEqual(measurement_names, expected_names)
# run again to get cpu_perc
expected_names.insert(0, 'process.cpu_perc')
measurement_names = self.run_check()
self.assertEquals(measurement_names, expected_names)
self.assertListEqual(measurement_names, expected_names)