Merge "Fix handling of CIDR in allowed address pairs" into stable/juno

This commit is contained in:
Jenkins 2014-11-28 22:21:58 +00:00 committed by Gerrit Code Review
commit 181310428c
2 changed files with 67 additions and 35 deletions

View File

@ -214,7 +214,7 @@ class SecurityGroupServerRpcMixin(sg_db.SecurityGroupDbMixin):
context, sg_info['sg_member_ips'].keys()) context, sg_info['sg_member_ips'].keys())
for sg_id, member_ips in ips.items(): for sg_id, member_ips in ips.items():
for ip in member_ips: for ip in member_ips:
ethertype = 'IPv%d' % netaddr.IPAddress(ip).version ethertype = 'IPv%d' % netaddr.IPNetwork(ip).version
if (ethertype in sg_info['sg_member_ips'][sg_id] if (ethertype in sg_info['sg_member_ips'][sg_id]
and ip not in sg_info['sg_member_ips'][sg_id][ethertype]): and ip not in sg_info['sg_member_ips'][sg_id][ethertype]):
sg_info['sg_member_ips'][sg_id][ethertype].append(ip) sg_info['sg_member_ips'][sg_id][ethertype].append(ip)

View File

@ -222,21 +222,23 @@ class SGServerRpcCallBackTestCase(test_sg.SecurityGroupDBTestCase):
expected) expected)
self._delete('ports', port_id1) self._delete('ports', port_id1)
def test_security_group_rules_for_devices_ipv4_ingress_addr_pair(self): @contextlib.contextmanager
def _port_with_addr_pairs_and_security_group(self):
plugin_obj = manager.NeutronManager.get_plugin() plugin_obj = manager.NeutronManager.get_plugin()
if ('allowed-address-pairs' if ('allowed-address-pairs'
not in plugin_obj.supported_extension_aliases): not in plugin_obj.supported_extension_aliases):
self.skipTest("Test depeneds on allowed-address-pairs extension") self.skipTest("Test depeneds on allowed-address-pairs extension")
fake_prefix = FAKE_PREFIX['IPv4'] fake_prefix = FAKE_PREFIX['IPv4']
with self.network() as n: with self.network() as n:
with contextlib.nested(self.subnet(n), with contextlib.nested(
self.security_group()) as (subnet_v4, self.subnet(n),
sg1): self.security_group()
) as (subnet_v4, sg1):
sg1_id = sg1['security_group']['id'] sg1_id = sg1['security_group']['id']
rule1 = self._build_security_group_rule( rule1 = self._build_security_group_rule(
sg1_id, sg1_id,
'ingress', 'tcp', '22', 'ingress', 'tcp', '22',
'22') '22', remote_group_id=sg1_id)
rule2 = self._build_security_group_rule( rule2 = self._build_security_group_rule(
sg1_id, sg1_id,
'ingress', 'tcp', '23', 'ingress', 'tcp', '23',
@ -248,7 +250,7 @@ class SGServerRpcCallBackTestCase(test_sg.SecurityGroupDBTestCase):
self.deserialize(self.fmt, res) self.deserialize(self.fmt, res)
self.assertEqual(res.status_int, 201) self.assertEqual(res.status_int, 201)
address_pairs = [{'mac_address': '00:00:00:00:00:01', address_pairs = [{'mac_address': '00:00:00:00:00:01',
'ip_address': '10.0.0.0/24'}, 'ip_address': '10.0.1.0/24'},
{'mac_address': '00:00:00:00:00:01', {'mac_address': '00:00:00:00:00:01',
'ip_address': '11.0.0.1'}] 'ip_address': '11.0.0.1'}]
res1 = self._create_port( res1 = self._create_port(
@ -256,34 +258,64 @@ class SGServerRpcCallBackTestCase(test_sg.SecurityGroupDBTestCase):
security_groups=[sg1_id], security_groups=[sg1_id],
arg_list=(addr_pair.ADDRESS_PAIRS,), arg_list=(addr_pair.ADDRESS_PAIRS,),
allowed_address_pairs=address_pairs) allowed_address_pairs=address_pairs)
ports_rest1 = self.deserialize(self.fmt, res1) yield self.deserialize(self.fmt, res1)
port_id1 = ports_rest1['port']['id']
self.rpc.devices = {port_id1: ports_rest1['port']} def test_security_group_info_for_devices_ipv4_addr_pair(self):
devices = [port_id1, 'no_exist_device'] with self._port_with_addr_pairs_and_security_group() as port:
ctx = context.get_admin_context() port_id = port['port']['id']
ports_rpc = self.rpc.security_group_rules_for_devices( sg_id = port['port']['security_groups'][0]
ctx, devices=devices) devices = [port_id, 'no_exist_device']
port_rpc = ports_rpc[port_id1] ctx = context.get_admin_context()
expected = [{'direction': 'egress', 'ethertype': 'IPv4', # verify that address pairs are included in remote SG IPs
'security_group_id': sg1_id}, sg_member_ips = self.rpc.security_group_info_for_devices(
{'direction': 'egress', 'ethertype': 'IPv6', ctx, devices=devices)['sg_member_ips']
'security_group_id': sg1_id}, expected_member_ips = [
{'direction': 'ingress', '10.0.1.0/24', '11.0.0.1',
'protocol': 'tcp', 'ethertype': 'IPv4', port['port']['fixed_ips'][0]['ip_address']]
'port_range_max': 22, self.assertEqual(sorted(expected_member_ips),
'security_group_id': sg1_id, sorted(sg_member_ips[sg_id]['IPv4']))
'port_range_min': 22}, self._delete('ports', port_id)
{'direction': 'ingress', 'protocol': 'tcp',
'ethertype': 'IPv4', def test_security_group_rules_for_devices_ipv4_ingress_addr_pair(self):
'port_range_max': 23, 'security_group_id': sg1_id, fake_prefix = FAKE_PREFIX[const.IPv4]
'port_range_min': 23, with self._port_with_addr_pairs_and_security_group() as port:
'source_ip_prefix': fake_prefix}, port_id = port['port']['id']
] sg_id = port['port']['security_groups'][0]
self.assertEqual(port_rpc['security_group_rules'], devices = [port_id, 'no_exist_device']
expected) ctx = context.get_admin_context()
self.assertEqual(port_rpc['allowed_address_pairs'], ports_rpc = self.rpc.security_group_rules_for_devices(
address_pairs) ctx, devices=devices)
self._delete('ports', port_id1)
port_rpc = ports_rpc[port_id]
expected = [{'direction': 'egress', 'ethertype': 'IPv4',
'security_group_id': sg_id},
{'direction': 'egress', 'ethertype': 'IPv6',
'security_group_id': sg_id},
{'direction': 'ingress',
'protocol': 'tcp', 'ethertype': 'IPv4',
'port_range_max': 22,
'remote_group_id': sg_id,
'security_group_id': sg_id,
'source_ip_prefix': '11.0.0.1/32',
'port_range_min': 22},
{'direction': 'ingress',
'protocol': 'tcp', 'ethertype': 'IPv4',
'port_range_max': 22,
'remote_group_id': sg_id,
'security_group_id': sg_id,
'source_ip_prefix': '10.0.1.0/24',
'port_range_min': 22},
{'direction': 'ingress', 'protocol': 'tcp',
'ethertype': 'IPv4',
'port_range_max': 23, 'security_group_id': sg_id,
'port_range_min': 23,
'source_ip_prefix': fake_prefix},
]
self.assertEqual(expected,
port_rpc['security_group_rules'])
self.assertEqual(port['port']['allowed_address_pairs'],
port_rpc['allowed_address_pairs'])
self._delete('ports', port_id)
def test_security_group_rules_for_devices_ipv4_egress(self): def test_security_group_rules_for_devices_ipv4_egress(self):
fake_prefix = FAKE_PREFIX[const.IPv4] fake_prefix = FAKE_PREFIX[const.IPv4]