blob: 3d8b36082a3c299fca62e1d6370c345ac077bc06 [file] [log] [blame]
Andrea Frittoli (andreaf)23950142016-06-13 12:39:29 +01001# Copyright (c) 2016 Hewlett-Packard Enterprise Development Company, L.P.
2#
3# Licensed under the Apache License, Version 2.0 (the "License"); you may not
4# use this file except in compliance with the License. You may obtain a copy of
5# the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12# License for the specific language governing permissions and limitations under
13# the License.
14
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +010015import fixtures
Andrea Frittoli (andreaf)73dd51d2016-06-21 17:20:31 +010016import mock
Andrea Frittoli (andreaf)23950142016-06-13 12:39:29 +010017import testtools
Andrea Frittoli (andreaf)73dd51d2016-06-21 17:20:31 +010018import types
Andrea Frittoli (andreaf)23950142016-06-13 12:39:29 +010019
20from tempest.lib import auth
21from tempest.lib import exceptions
22from tempest import service_clients
23from tempest.tests import base
Andrea Frittoli (andreaf)73dd51d2016-06-21 17:20:31 +010024from tempest.tests.lib import fake_auth_provider
Andrea Frittoli (andreaf)23950142016-06-13 12:39:29 +010025from tempest.tests.lib import fake_credentials
26
27
Andrea Frittoli (andreaf)73dd51d2016-06-21 17:20:31 +010028has_attribute = testtools.matchers.MatchesPredicateWithParams(
29 lambda x, y: hasattr(x, y), '{0} does not have an attribute {1}')
30
31
32class TestClientsFactory(base.TestCase):
33
34 def setUp(self):
35 super(TestClientsFactory, self).setUp()
36 self.classes = []
37
38 def _setup_fake_module(self, class_names=None, extra_dict=None):
39 class_names = class_names or []
40 fake_module = types.ModuleType('fake_service_client')
41 _dict = {}
42 # Add fake classes to the fake module
43 for name in class_names:
44 _dict[name] = type(name, (object,), {})
45 # Store it for assertions
46 self.classes.append(_dict[name])
47 if extra_dict:
48 _dict[extra_dict] = extra_dict
49 fake_module.__dict__.update(_dict)
50 fixture_importlib = self.useFixture(fixtures.MockPatch(
51 'importlib.import_module', return_value=fake_module))
52 return fixture_importlib.mock
53
54 def test___init___one_class(self):
55 fake_partial = 'fake_partial'
56 partial_mock = self.useFixture(fixtures.MockPatch(
57 'tempest.service_clients.ClientsFactory._get_partial_class',
58 return_value=fake_partial)).mock
59 class_names = ['FakeServiceClient1']
60 mock_importlib = self._setup_fake_module(class_names=class_names)
61 auth_provider = fake_auth_provider.FakeAuthProvider()
62 params = {'k1': 'v1', 'k2': 'v2'}
63 factory = service_clients.ClientsFactory('fake_path', class_names,
64 auth_provider, **params)
65 # Assert module has been imported
66 mock_importlib.assert_called_once_with('fake_path')
67 # All attributes have been created
68 for client in class_names:
69 self.assertThat(factory, has_attribute(client))
70 # Partial have been invoked correctly
71 partial_mock.assert_called_once_with(
72 self.classes[0], auth_provider, params)
73 # Get the clients
74 for name in class_names:
75 self.assertEqual(fake_partial, getattr(factory, name))
76
77 def test___init___two_classes(self):
78 fake_partial = 'fake_partial'
79 partial_mock = self.useFixture(fixtures.MockPatch(
80 'tempest.service_clients.ClientsFactory._get_partial_class',
81 return_value=fake_partial)).mock
82 class_names = ['FakeServiceClient1', 'FakeServiceClient2']
83 mock_importlib = self._setup_fake_module(class_names=class_names)
84 auth_provider = fake_auth_provider.FakeAuthProvider()
85 params = {'k1': 'v1', 'k2': 'v2'}
86 factory = service_clients.ClientsFactory('fake_path', class_names,
87 auth_provider, **params)
88 # Assert module has been imported
89 mock_importlib.assert_called_once_with('fake_path')
90 # All attributes have been created
91 for client in class_names:
92 self.assertThat(factory, has_attribute(client))
93 # Partial have been invoked the right number of times
94 partial_mock.call_count = len(class_names)
95 # Get the clients
96 for name in class_names:
97 self.assertEqual(fake_partial, getattr(factory, name))
98
99 def test___init___no_module(self):
100 auth_provider = fake_auth_provider.FakeAuthProvider()
101 class_names = ['FakeServiceClient1', 'FakeServiceClient2']
102 with testtools.ExpectedException(ImportError, '.*fake_module.*'):
103 service_clients.ClientsFactory('fake_module', class_names,
104 auth_provider)
105
106 def test___init___not_a_class(self):
107 class_names = ['FakeServiceClient1', 'FakeServiceClient2']
108 extended_class_names = class_names + ['not_really_a_class']
109 self._setup_fake_module(
110 class_names=class_names, extra_dict='not_really_a_class')
111 auth_provider = fake_auth_provider.FakeAuthProvider()
112 expected_msg = '.*not_really_a_class.*str.*'
113 with testtools.ExpectedException(TypeError, expected_msg):
114 service_clients.ClientsFactory('fake_module', extended_class_names,
115 auth_provider)
116
117 def test___init___class_not_found(self):
118 class_names = ['FakeServiceClient1', 'FakeServiceClient2']
119 extended_class_names = class_names + ['not_really_a_class']
120 self._setup_fake_module(class_names=class_names)
121 auth_provider = fake_auth_provider.FakeAuthProvider()
122 expected_msg = '.*not_really_a_class.*fake_service_client.*'
123 with testtools.ExpectedException(AttributeError, expected_msg):
124 service_clients.ClientsFactory('fake_module', extended_class_names,
125 auth_provider)
126
127 def test__get_partial_class_no_later_kwargs(self):
128 expected_fake_client = 'not_really_a_client'
129 self._setup_fake_module(class_names=[])
130 auth_provider = fake_auth_provider.FakeAuthProvider()
131 params = {'k1': 'v1', 'k2': 'v2'}
132 factory = service_clients.ClientsFactory(
133 'fake_path', [], auth_provider, **params)
134 klass_mock = mock.Mock(return_value=expected_fake_client)
135 partial = factory._get_partial_class(klass_mock, auth_provider, params)
136 # Class has not be initialised yet
137 klass_mock.assert_not_called()
138 # Use partial and assert on parameters
139 client = partial()
140 self.assertEqual(expected_fake_client, client)
141 klass_mock.assert_called_once_with(auth_provider=auth_provider,
142 **params)
143
144 def test__get_partial_class_later_kwargs(self):
145 expected_fake_client = 'not_really_a_client'
146 self._setup_fake_module(class_names=[])
147 auth_provider = fake_auth_provider.FakeAuthProvider()
148 params = {'k1': 'v1', 'k2': 'v2'}
149 later_params = {'k2': 'v4', 'k3': 'v3'}
150 factory = service_clients.ClientsFactory(
151 'fake_path', [], auth_provider, **params)
152 klass_mock = mock.Mock(return_value=expected_fake_client)
153 partial = factory._get_partial_class(klass_mock, auth_provider, params)
154 # Class has not be initialised yet
155 klass_mock.assert_not_called()
156 # Use partial and assert on parameters
157 client = partial(**later_params)
158 params.update(later_params)
159 self.assertEqual(expected_fake_client, client)
160 klass_mock.assert_called_once_with(auth_provider=auth_provider,
161 **params)
162
163
Andrea Frittoli (andreaf)23950142016-06-13 12:39:29 +0100164class TestServiceClients(base.TestCase):
165
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +0100166 def setUp(self):
167 super(TestServiceClients, self).setUp()
168 self.useFixture(fixtures.MockPatch(
169 'tempest.service_clients.tempest_modules',
170 return_value=set(['fake_service1', 'fake_service2'])))
171
172 def test___init___creds_v2_uri(self):
Andrea Frittoli (andreaf)23950142016-06-13 12:39:29 +0100173 # Verify that no API request is made, since no mock
174 # is required to run the test successfully
175 creds = fake_credentials.FakeKeystoneV2Credentials()
176 uri = 'fake_uri'
177 _manager = service_clients.ServiceClients(creds, identity_uri=uri)
178 self.assertIsInstance(_manager.auth_provider,
179 auth.KeystoneV2AuthProvider)
180
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +0100181 def test___init___creds_v3_uri(self):
Andrea Frittoli (andreaf)23950142016-06-13 12:39:29 +0100182 # Verify that no API request is made, since no mock
183 # is required to run the test successfully
184 creds = fake_credentials.FakeKeystoneV3Credentials()
185 uri = 'fake_uri'
186 _manager = service_clients.ServiceClients(creds, identity_uri=uri)
187 self.assertIsInstance(_manager.auth_provider,
188 auth.KeystoneV3AuthProvider)
189
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +0100190 def test___init___base_creds_uri(self):
Andrea Frittoli (andreaf)23950142016-06-13 12:39:29 +0100191 creds = fake_credentials.FakeCredentials()
192 uri = 'fake_uri'
193 with testtools.ExpectedException(exceptions.InvalidCredentials):
194 service_clients.ServiceClients(creds, identity_uri=uri)
195
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +0100196 def test___init___invalid_creds_uri(self):
Andrea Frittoli (andreaf)23950142016-06-13 12:39:29 +0100197 creds = fake_credentials.FakeKeystoneV2Credentials()
198 delattr(creds, 'username')
199 uri = 'fake_uri'
200 with testtools.ExpectedException(exceptions.InvalidCredentials):
201 service_clients.ServiceClients(creds, identity_uri=uri)
202
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +0100203 def test___init___creds_uri_none(self):
Andrea Frittoli (andreaf)23950142016-06-13 12:39:29 +0100204 creds = fake_credentials.FakeKeystoneV2Credentials()
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +0100205 msg = ("Invalid Credentials\nDetails: ServiceClients requires a "
206 "non-empty")
Andrea Frittoli (andreaf)23950142016-06-13 12:39:29 +0100207 with testtools.ExpectedException(exceptions.InvalidCredentials,
208 value_re=msg):
209 service_clients.ServiceClients(creds, None)
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +0100210
211 def test___init___creds_uri_params(self):
212 creds = fake_credentials.FakeKeystoneV2Credentials()
213 expeted_params = {'fake_param1': 'fake_value1',
214 'fake_param2': 'fake_value2'}
215 params = {'fake_service1': expeted_params}
216 uri = 'fake_uri'
217 _manager = service_clients.ServiceClients(creds, identity_uri=uri,
218 client_parameters=params)
Joe H. Rahmea72f2c62016-07-11 16:28:19 +0200219 self.assertIn('fake_service1', _manager.parameters)
220 for _key in expeted_params:
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +0100221 self.assertIn(_key, _manager.parameters['fake_service1'].keys())
222 self.assertEqual(expeted_params[_key],
223 _manager.parameters['fake_service1'].get(_key))
224
225 def test___init___creds_uri_params_unknown_services(self):
226 creds = fake_credentials.FakeKeystoneV2Credentials()
227 fake_params = {'fake_param1': 'fake_value1'}
228 params = {'unknown_service1': fake_params,
229 'unknown_service2': fake_params}
230 uri = 'fake_uri'
231 msg = "(?=.*{0})(?=.*{1})".format(*list(params.keys()))
232 with testtools.ExpectedException(
233 exceptions.UnknownServiceClient, value_re=msg):
234 service_clients.ServiceClients(creds, identity_uri=uri,
235 client_parameters=params)
236
237 def _get_manager(self, init_region='fake_region'):
238 # Get a manager to invoke _setup_parameters on
239 creds = fake_credentials.FakeKeystoneV2Credentials()
240 return service_clients.ServiceClients(creds, identity_uri='fake_uri',
241 region=init_region)
242
243 def test__setup_parameters_none_no_region(self):
244 kwargs = {}
245 _manager = self._get_manager(init_region=None)
246 _params = _manager._setup_parameters(kwargs)
247 self.assertNotIn('region', _params)
248
249 def test__setup_parameters_none(self):
250 kwargs = {}
251 _manager = self._get_manager()
252 _params = _manager._setup_parameters(kwargs)
253 self.assertIn('region', _params)
254 self.assertEqual('fake_region', _params['region'])
255
256 def test__setup_parameters_all(self):
257 expected_params = {'region': 'fake_region1',
258 'catalog_type': 'fake_service2_mod',
259 'fake_param1': 'fake_value1',
260 'fake_param2': 'fake_value2'}
261 _manager = self._get_manager()
262 _params = _manager._setup_parameters(expected_params)
263 for _key in _params.keys():
264 self.assertEqual(expected_params[_key],
265 _params[_key])
Andrea Frittoli (andreaf)6d4d85a2016-06-21 17:20:31 +0100266
267 def test_register_service_client_module(self):
Andrea Frittoli (andreaf)6d4d85a2016-06-21 17:20:31 +0100268 expected_params = {'fake_param1': 'fake_value1',
269 'fake_param2': 'fake_value2'}
270 _manager = self._get_manager(init_region='fake_region_default')
Andrea Frittoli (andreaf)f2affcc2016-06-28 21:41:47 +0100271 # Mock after the _manager is setup to preserve the call count
272 factory_mock = self.useFixture(fixtures.MockPatch(
273 'tempest.service_clients.ClientsFactory')).mock
Andrea Frittoli (andreaf)6d4d85a2016-06-21 17:20:31 +0100274 _manager.register_service_client_module(
275 name='fake_module',
276 service_version='fake_service',
277 module_path='fake.path.to.module',
278 client_names=[],
279 **expected_params)
280 self.assertThat(_manager, has_attribute('fake_module'))
281 # Assert called once, without check for exact parameters
282 self.assertTrue(factory_mock.called)
283 self.assertEqual(1, factory_mock.call_count)
284 # Assert expected params are in with their values
285 actual_kwargs = factory_mock.call_args[1]
286 self.assertIn('region', actual_kwargs)
287 self.assertEqual('fake_region_default', actual_kwargs['region'])
288 for param in expected_params:
289 self.assertIn(param, actual_kwargs)
290 self.assertEqual(expected_params[param], actual_kwargs[param])
291 # Assert the new service is registered
292 self.assertIn('fake_service', _manager._registered_services)
293
294 def test_register_service_client_module_override_default(self):
Andrea Frittoli (andreaf)6d4d85a2016-06-21 17:20:31 +0100295 new_region = 'new_region'
296 expected_params = {'fake_param1': 'fake_value1',
297 'fake_param2': 'fake_value2',
298 'region': new_region}
299 _manager = self._get_manager(init_region='fake_region_default')
Andrea Frittoli (andreaf)f2affcc2016-06-28 21:41:47 +0100300 # Mock after the _manager is setup to preserve the call count
301 factory_mock = self.useFixture(fixtures.MockPatch(
302 'tempest.service_clients.ClientsFactory')).mock
Andrea Frittoli (andreaf)6d4d85a2016-06-21 17:20:31 +0100303 _manager.register_service_client_module(
304 name='fake_module',
305 service_version='fake_service',
306 module_path='fake.path.to.module',
307 client_names=[],
308 **expected_params)
309 self.assertThat(_manager, has_attribute('fake_module'))
310 # Assert called once, without check for exact parameters
311 self.assertTrue(factory_mock.called)
312 self.assertEqual(1, factory_mock.call_count)
313 # Assert expected params are in with their values
314 actual_kwargs = factory_mock.call_args[1]
315 self.assertIn('region', actual_kwargs)
316 self.assertEqual(new_region, actual_kwargs['region'])
317 for param in expected_params:
318 self.assertIn(param, actual_kwargs)
319 self.assertEqual(expected_params[param], actual_kwargs[param])
320 # Assert the new service is registered
321 self.assertIn('fake_service', _manager._registered_services)
322
323 def test_register_service_client_module_duplicate_name(self):
324 self.useFixture(fixtures.MockPatch(
325 'tempest.service_clients.ClientsFactory'))
326 _manager = self._get_manager()
327 name_owner = 'this_is_a_string'
328 setattr(_manager, 'fake_module', name_owner)
329 expected_error = '.*' + name_owner
330 with testtools.ExpectedException(
331 exceptions.ServiceClientRegistrationException, expected_error):
332 _manager.register_service_client_module(
333 name='fake_module', module_path='fake.path.to.module',
334 service_version='fake_service', client_names=[])
335
336 def test_register_service_client_module_duplicate_service(self):
337 self.useFixture(fixtures.MockPatch(
338 'tempest.service_clients.ClientsFactory'))
339 _manager = self._get_manager()
340 duplicate_service = 'fake_service1'
341 expected_error = '.*' + duplicate_service
342 with testtools.ExpectedException(
343 exceptions.ServiceClientRegistrationException, expected_error):
344 _manager.register_service_client_module(
345 name='fake_module', module_path='fake.path.to.module',
346 service_version=duplicate_service, client_names=[])