summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMorgan Richomme <morgan.richomme@orange.com>2017-05-17 10:29:20 +0200
committerspisarski <s.pisarski@cablelabs.com>2017-05-17 09:51:05 -0600
commit956acc7da293b931c3e21e64fa0a9011f995c11c (patch)
treefdc3690743dfebb92f185a5481531f8fe2399858
parent10c665d7c831cf198ac9e675654693860e602bf9 (diff)
bugfix: get_security_group_by_id always return first element
add check on id before return value fixed kwarg into the neutron.list_security_groups to the correct one 'id' added unit test to ensure this function always works as designed JIRA: SNAPS-82 Change-Id: I965e1dd54fd1efa8c2d7f6efb87c78ab24cca0e5 Signed-off-by: Morgan Richomme <morgan.richomme@orange.com>
-rw-r--r--snaps/openstack/utils/neutron_utils.py5
-rw-r--r--snaps/openstack/utils/tests/neutron_utils_tests.py63
2 files changed, 46 insertions, 22 deletions
diff --git a/snaps/openstack/utils/neutron_utils.py b/snaps/openstack/utils/neutron_utils.py
index a65a42f..3063176 100644
--- a/snaps/openstack/utils/neutron_utils.py
+++ b/snaps/openstack/utils/neutron_utils.py
@@ -336,9 +336,10 @@ def get_security_group_by_id(neutron, sec_grp_id):
"""
logger.info('Retrieving security group with ID - ' + sec_grp_id)
- groups = neutron.list_security_groups(**{'sec_grp_id': sec_grp_id})
+ groups = neutron.list_security_groups(**{'id': sec_grp_id})
for group in groups['security_groups']:
- return {'security_group': group}
+ if group['id'] == sec_grp_id:
+ return {'security_group': group}
return None
diff --git a/snaps/openstack/utils/tests/neutron_utils_tests.py b/snaps/openstack/utils/tests/neutron_utils_tests.py
index 9a043e3..e90b94c 100644
--- a/snaps/openstack/utils/tests/neutron_utils_tests.py
+++ b/snaps/openstack/utils/tests/neutron_utils_tests.py
@@ -476,7 +476,7 @@ class NeutronUtilsSecurityGroupTests(OSComponentTestCase):
guid = self.__class__.__name__ + '-' + str(uuid.uuid4())
self.sec_grp_name = guid + 'name'
- self.security_group = None
+ self.security_groups = list()
self.security_group_rules = list()
self.neutron = neutron_utils.neutron_client(self.os_creds)
self.keystone = keystone_utils.keystone_client(self.os_creds)
@@ -488,27 +488,29 @@ class NeutronUtilsSecurityGroupTests(OSComponentTestCase):
for rule in self.security_group_rules:
neutron_utils.delete_security_group_rule(self.neutron, rule)
- if self.security_group:
- neutron_utils.delete_security_group(self.neutron, self.security_group)
+ for security_group in self.security_groups:
+ try:
+ neutron_utils.delete_security_group(self.neutron, security_group)
+ except:
+ pass
def test_create_delete_simple_sec_grp(self):
"""
Tests the neutron_utils.create_security_group() function
"""
sec_grp_settings = SecurityGroupSettings(name=self.sec_grp_name)
- self.security_group = neutron_utils.create_security_group(self.neutron, self.keystone, sec_grp_settings)
+ security_group = neutron_utils.create_security_group(self.neutron, self.keystone, sec_grp_settings)
- self.assertTrue(sec_grp_settings.name, self.security_group['security_group']['name'])
+ self.assertTrue(sec_grp_settings.name, security_group['security_group']['name'])
sec_grp_get = neutron_utils.get_security_group(self.neutron, sec_grp_settings.name)
self.assertIsNotNone(sec_grp_get)
self.assertTrue(validation_utils.objects_equivalent(
- self.security_group['security_group'], sec_grp_get['security_group']))
+ security_group['security_group'], sec_grp_get['security_group']))
- neutron_utils.delete_security_group(self.neutron, self.security_group)
+ neutron_utils.delete_security_group(self.neutron, security_group)
sec_grp_get = neutron_utils.get_security_group(self.neutron, sec_grp_settings.name)
self.assertIsNone(sec_grp_get)
- self.security_group = None
def test_create_sec_grp_no_name(self):
"""
@@ -517,22 +519,23 @@ class NeutronUtilsSecurityGroupTests(OSComponentTestCase):
"""
with self.assertRaises(Exception):
sec_grp_settings = SecurityGroupSettings()
- self.security_group = neutron_utils.create_security_group(self.neutron, self.keystone, sec_grp_settings)
+ self.security_groups.append(
+ neutron_utils.create_security_group(self.neutron, self.keystone, sec_grp_settings))
def test_create_sec_grp_no_rules(self):
"""
Tests the neutron_utils.create_security_group() function
"""
sec_grp_settings = SecurityGroupSettings(name=self.sec_grp_name, description='hello group')
- self.security_group = neutron_utils.create_security_group(self.neutron, self.keystone, sec_grp_settings)
+ self.security_groups.append(neutron_utils.create_security_group(self.neutron, self.keystone, sec_grp_settings))
- self.assertTrue(sec_grp_settings.name, self.security_group['security_group']['name'])
- self.assertTrue(sec_grp_settings.description, self.security_group['security_group']['description'])
+ self.assertTrue(sec_grp_settings.name, self.security_groups[0]['security_group']['name'])
+ self.assertTrue(sec_grp_settings.description, self.security_groups[0]['security_group']['description'])
sec_grp_get = neutron_utils.get_security_group(self.neutron, sec_grp_settings.name)
self.assertIsNotNone(sec_grp_get)
self.assertTrue(validation_utils.objects_equivalent(
- self.security_group['security_group'], sec_grp_get['security_group']))
+ self.security_groups[0]['security_group'], sec_grp_get['security_group']))
def test_create_sec_grp_one_rule(self):
"""
@@ -543,8 +546,8 @@ class NeutronUtilsSecurityGroupTests(OSComponentTestCase):
sec_grp_settings = SecurityGroupSettings(name=self.sec_grp_name, description='hello group',
rule_settings=[sec_grp_rule_settings])
- self.security_group = neutron_utils.create_security_group(self.neutron, self.keystone, sec_grp_settings)
- free_rules = neutron_utils.get_rules_by_security_group(self.neutron, self.security_group)
+ self.security_groups.append(neutron_utils.create_security_group(self.neutron, self.keystone, sec_grp_settings))
+ free_rules = neutron_utils.get_rules_by_security_group(self.neutron, self.security_groups[0])
for free_rule in free_rules:
self.security_group_rules.append(free_rule)
@@ -552,19 +555,39 @@ class NeutronUtilsSecurityGroupTests(OSComponentTestCase):
neutron_utils.create_security_group_rule(self.neutron, sec_grp_settings.rule_settings[0]))
# Refresh object so it is populated with the newly added rule
- self.security_group = neutron_utils.get_security_group(self.neutron, sec_grp_settings.name)
+ security_group = neutron_utils.get_security_group(self.neutron, sec_grp_settings.name)
- rules = neutron_utils.get_rules_by_security_group(self.neutron, self.security_group)
+ rules = neutron_utils.get_rules_by_security_group(self.neutron, security_group)
self.assertTrue(validation_utils.objects_equivalent(self.security_group_rules, rules))
- self.assertTrue(sec_grp_settings.name, self.security_group['security_group']['name'])
- self.assertTrue(sec_grp_settings.description, self.security_group['security_group']['description'])
+ self.assertTrue(sec_grp_settings.name, security_group['security_group']['name'])
+ self.assertTrue(sec_grp_settings.description, security_group['security_group']['description'])
sec_grp_get = neutron_utils.get_security_group(self.neutron, sec_grp_settings.name)
self.assertIsNotNone(sec_grp_get)
self.assertTrue(validation_utils.objects_equivalent(
- self.security_group['security_group'], sec_grp_get['security_group']))
+ security_group['security_group'], sec_grp_get['security_group']))
+
+ def test_get_sec_grp_by_id(self):
+ """
+ Tests the neutron_utils.create_security_group() function
+ """
+
+ self.security_groups.append(neutron_utils.create_security_group(
+ self.neutron, self.keystone,
+ SecurityGroupSettings(name=self.sec_grp_name + '-1', description='hello group')))
+ self.security_groups.append(neutron_utils.create_security_group(
+ self.neutron, self.keystone,
+ SecurityGroupSettings(name=self.sec_grp_name + '-2', description='hello group')))
+
+ sec_grp_1b = neutron_utils.get_security_group_by_id(
+ self.neutron, self.security_groups[0]['security_group']['id'])
+ sec_grp_2b = neutron_utils.get_security_group_by_id(
+ self.neutron, self.security_groups[1]['security_group']['id'])
+
+ self.assertEqual(self.security_groups[0]['security_group']['id'], sec_grp_1b['security_group']['id'])
+ self.assertEqual(self.security_groups[1]['security_group']['id'], sec_grp_2b['security_group']['id'])
"""