52
52
self.keystone = None
55
class TestKwapiPollster(base.TestCase):
58
def fake_kwapi_iter_probes(self, ksclient):
59
probes = PROBE_DICT['probes']
60
for key, value in probes.iteritems():
62
probe_dict['id'] = key
66
def fake_kwapi_get_kwapi_client(self, ksclient):
55
class TestKwapi(base.TestCase):
57
@mock.patch('ceilometer.pipeline.setup_pipeline', mock.MagicMock())
59
super(TestKwapi, self).setUp()
60
self.context = context.get_admin_context()
61
self.manager = TestManager()
64
def fake_get_kwapi_client(self, ksclient):
67
65
raise exceptions.EndpointNotFound("fake keystone exception")
69
@mock.patch('ceilometer.pipeline.setup_pipeline', mock.MagicMock())
71
super(TestKwapiPollster, self).setUp()
72
self.context = context.get_admin_context()
73
self.manager = TestManager()
75
def test_kwapi_endpoint_not_exist(self):
67
def test_endpoint_not_exist(self):
76
68
self.stubs.Set(kwapi._Base, 'get_kwapi_client',
77
self.fake_kwapi_get_kwapi_client)
69
self.fake_get_kwapi_client)
79
counters = list(kwapi.KwapiPollster().get_counters(self.manager))
71
counters = list(kwapi.EnergyPollster().get_counters(self.manager, {}))
80
72
self.assertEqual(len(counters), 0)
82
def test_kwapi_counter(self):
83
self.stubs.Set(kwapi._Base, 'iter_probes', self.fake_kwapi_iter_probes)
85
counters = list(kwapi.KwapiPollster().get_counters(self.manager))
86
self.assertEqual(len(counters), 6)
87
energy_counters = [counter for counter in counters
88
if counter.name == "energy"]
89
power_counters = [counter for counter in counters
90
if counter.name == "power"]
91
for probe in PROBE_DICT['probes'].values():
93
any(map(lambda counter: counter.timestamp ==
94
datetime.datetime.fromtimestamp(
95
probe['timestamp']).isoformat(),
98
any(map(lambda counter: counter.volume == probe['kwh'],
101
any(map(lambda counter: counter.volume == probe['w'],
104
def test_kwapi_counter_list(self):
105
self.stubs.Set(kwapi._Base, 'iter_probes', self.fake_kwapi_iter_probes)
107
counters = list(kwapi.KwapiPollster().get_counters(self.manager))
108
self.assertEqual(set([c.name for c in counters]),
109
set(kwapi.KwapiPollster().get_counter_names()))
75
class TestEnergyPollster(base.TestCase):
77
@mock.patch('ceilometer.pipeline.setup_pipeline', mock.MagicMock())
79
super(TestEnergyPollster, self).setUp()
80
self.context = context.get_admin_context()
81
self.manager = TestManager()
82
self.stubs.Set(kwapi._Base, '_iter_probes',
83
self.fake_iter_probes)
86
def fake_iter_probes(self, ksclient, cache):
87
probes = PROBE_DICT['probes']
88
for key, value in probes.iteritems():
90
probe_dict['id'] = key
93
def test_counter(self):
95
counters = list(kwapi.EnergyPollster().get_counters(
99
self.assertEqual(len(counters), 3)
100
counters_by_name = dict((c.resource_id, c) for c in counters)
101
for name, probe in PROBE_DICT['probes'].items():
102
counter = counters_by_name[name]
103
expected = datetime.datetime.fromtimestamp(
106
self.assertEqual(counter.timestamp, expected)
107
self.assertEqual(counter.volume, probe['kwh'])
109
# any(map(lambda counter: counter.volume == probe['w'],
113
class TestEnergyPollsterCache(base.TestCase):
115
@mock.patch('ceilometer.pipeline.setup_pipeline', mock.MagicMock())
117
super(TestEnergyPollsterCache, self).setUp()
118
self.context = context.get_admin_context()
119
self.manager = TestManager()
121
def test_get_counters_cached(self):
123
probe.update(PROBE_DICT['probes']['A'])
125
kwapi.EnergyPollster.CACHE_KEY_PROBE: [probe],
127
self.manager.keystone = mock.Mock()
128
pollster = kwapi.EnergyPollster()
129
with mock.patch.object(pollster, '_get_probes') as do_not_call:
130
do_not_call.side_effect = AssertionError('should not be called')
131
counters = list(pollster.get_counters(self.manager, cache))
132
self.assertEqual(len(counters), 1)
135
class TestPowerPollster(base.TestCase):
137
@mock.patch('ceilometer.pipeline.setup_pipeline', mock.MagicMock())
139
super(TestPowerPollster, self).setUp()
140
self.context = context.get_admin_context()
141
self.manager = TestManager()
142
self.stubs.Set(kwapi._Base, '_iter_probes',
143
self.fake_iter_probes)
146
def fake_iter_probes(self, ksclient, cache):
147
probes = PROBE_DICT['probes']
148
for key, value in probes.iteritems():
150
probe_dict['id'] = key
153
def test_counter(self):
155
counters = list(kwapi.PowerPollster().get_counters(
159
self.assertEqual(len(counters), 3)
160
counters_by_name = dict((c.resource_id, c) for c in counters)
161
for name, probe in PROBE_DICT['probes'].items():
162
counter = counters_by_name[name]
163
expected = datetime.datetime.fromtimestamp(
166
self.assertEqual(counter.timestamp, expected)
167
self.assertEqual(counter.volume, probe['w'])
170
class TestPowerPollsterCache(base.TestCase):
172
@mock.patch('ceilometer.pipeline.setup_pipeline', mock.MagicMock())
174
super(TestPowerPollsterCache, self).setUp()
175
self.context = context.get_admin_context()
176
self.manager = TestManager()
178
def test_get_counters_cached(self):
180
probe.update(PROBE_DICT['probes']['A'])
182
kwapi.PowerPollster.CACHE_KEY_PROBE: [probe],
184
self.manager.keystone = mock.Mock()
185
pollster = kwapi.PowerPollster()
186
with mock.patch.object(pollster, '_get_probes') as do_not_call:
187
do_not_call.side_effect = AssertionError('should not be called')
188
counters = list(pollster.get_counters(self.manager, cache))
189
self.assertEqual(len(counters), 1)