Verify CIDR overlaps among networks' subnets.
Make sure CIDR for subnets in a given network do not overlap each other. Fixes bug 1021106 Change-Id: I212a734ad59bbba86876d372a2f559f21ac60835
This commit is contained in:
parent
80a44c82d0
commit
a3c7f7c901
@ -482,6 +482,24 @@ class QuantumDbPluginV2(quantum_plugin_base_v2.QuantumPluginBaseV2):
|
|||||||
'subnet_id': result['subnet_id']})
|
'subnet_id': result['subnet_id']})
|
||||||
return ips
|
return ips
|
||||||
|
|
||||||
|
def _validate_subnet_cidr(self, network, new_subnet_cidr):
|
||||||
|
"""Validate the CIDR for a subnet.
|
||||||
|
|
||||||
|
Verifies the specified CIDR does not overlap with the ones defined
|
||||||
|
for the other subnets specified for this network.
|
||||||
|
|
||||||
|
"""
|
||||||
|
for subnet in network.subnets:
|
||||||
|
if (netaddr.IPSet([subnet.cidr]) &
|
||||||
|
netaddr.IPSet([new_subnet_cidr])):
|
||||||
|
err_msg = ("Requested subnet with cidr: %s "
|
||||||
|
"for network: %s "
|
||||||
|
"overlaps with subnet: %s)" % (new_subnet_cidr,
|
||||||
|
network.id,
|
||||||
|
subnet.cidr))
|
||||||
|
LOG.error(err_msg)
|
||||||
|
raise q_exc.InvalidInput(error_message=err_msg)
|
||||||
|
|
||||||
def _validate_allocation_pools(self, ip_pools, gateway_ip, subnet_cidr):
|
def _validate_allocation_pools(self, ip_pools, gateway_ip, subnet_cidr):
|
||||||
"""Validate IP allocation pools.
|
"""Validate IP allocation pools.
|
||||||
|
|
||||||
@ -671,6 +689,7 @@ class QuantumDbPluginV2(quantum_plugin_base_v2.QuantumPluginBaseV2):
|
|||||||
|
|
||||||
with context.session.begin():
|
with context.session.begin():
|
||||||
network = self._get_network(context, s["network_id"])
|
network = self._get_network(context, s["network_id"])
|
||||||
|
self._validate_subnet_cidr(network, s['cidr'])
|
||||||
subnet = models_v2.Subnet(network_id=s['network_id'],
|
subnet = models_v2.Subnet(network_id=s['network_id'],
|
||||||
ip_version=s['ip_version'],
|
ip_version=s['ip_version'],
|
||||||
cidr=s['cidr'],
|
cidr=s['cidr'],
|
||||||
|
@ -701,11 +701,11 @@ class TestNetworksV2(QuantumDbPluginV2TestCase):
|
|||||||
|
|
||||||
class TestSubnetsV2(QuantumDbPluginV2TestCase):
|
class TestSubnetsV2(QuantumDbPluginV2TestCase):
|
||||||
|
|
||||||
def _test_create_subnet(self, **kwargs):
|
def _test_create_subnet(self, network=None, **kwargs):
|
||||||
keys = kwargs.copy()
|
keys = kwargs.copy()
|
||||||
keys.setdefault('cidr', '10.0.0.0/24')
|
keys.setdefault('cidr', '10.0.0.0/24')
|
||||||
keys.setdefault('ip_version', 4)
|
keys.setdefault('ip_version', 4)
|
||||||
with self.subnet(**keys) as subnet:
|
with self.subnet(network=network, **keys) as subnet:
|
||||||
# verify the response has each key with the correct value
|
# verify the response has each key with the correct value
|
||||||
for k in keys:
|
for k in keys:
|
||||||
self.assertIn(k, subnet['subnet'])
|
self.assertIn(k, subnet['subnet'])
|
||||||
@ -718,6 +718,45 @@ class TestSubnetsV2(QuantumDbPluginV2TestCase):
|
|||||||
self._test_create_subnet(gateway_ip=gateway_ip,
|
self._test_create_subnet(gateway_ip=gateway_ip,
|
||||||
cidr=cidr)
|
cidr=cidr)
|
||||||
|
|
||||||
|
def test_create_two_subnets(self):
|
||||||
|
gateway_ips = ['10.0.0.1', '10.0.1.1']
|
||||||
|
cidrs = ['10.0.0.0/24', '10.0.1.0/24']
|
||||||
|
with self.network() as network:
|
||||||
|
with self.subnet(network=network,
|
||||||
|
gateway_ip=gateway_ips[0],
|
||||||
|
cidr=cidrs[0]):
|
||||||
|
with self.subnet(network=network,
|
||||||
|
gateway_ip=gateway_ips[1],
|
||||||
|
cidr=cidrs[1]):
|
||||||
|
net_req = self.new_show_request('networks',
|
||||||
|
network['network']['id'])
|
||||||
|
raw_res = net_req.get_response(self.api)
|
||||||
|
net_res = self.deserialize('json', raw_res)
|
||||||
|
for subnet_id in net_res['network']['subnets']:
|
||||||
|
sub_req = self.new_show_request('subnets', subnet_id)
|
||||||
|
raw_res = sub_req.get_response(self.api)
|
||||||
|
sub_res = self.deserialize('json', raw_res)
|
||||||
|
self.assertIn(sub_res['subnet']['cidr'], cidrs)
|
||||||
|
self.assertIn(sub_res['subnet']['gateway_ip'],
|
||||||
|
gateway_ips)
|
||||||
|
|
||||||
|
def test_create_two_subnets_same_cidr_returns_400(self):
|
||||||
|
gateway_ip_1 = '10.0.0.1'
|
||||||
|
cidr_1 = '10.0.0.0/24'
|
||||||
|
gateway_ip_2 = '10.0.0.10'
|
||||||
|
cidr_2 = '10.0.0.0/24'
|
||||||
|
with self.network() as network:
|
||||||
|
with self.subnet(network=network,
|
||||||
|
gateway_ip=gateway_ip_1,
|
||||||
|
cidr=cidr_1):
|
||||||
|
with self.assertRaises(
|
||||||
|
webob.exc.HTTPClientError) as ctx_manager:
|
||||||
|
with self.subnet(network=network,
|
||||||
|
gateway_ip=gateway_ip_2,
|
||||||
|
cidr=cidr_2):
|
||||||
|
pass
|
||||||
|
self.assertEquals(ctx_manager.exception.code, 400)
|
||||||
|
|
||||||
def test_delete_subnet(self):
|
def test_delete_subnet(self):
|
||||||
gateway_ip = '10.0.0.1'
|
gateway_ip = '10.0.0.1'
|
||||||
cidr = '10.0.0.0/24'
|
cidr = '10.0.0.0/24'
|
||||||
@ -869,7 +908,7 @@ class TestSubnetsV2(QuantumDbPluginV2TestCase):
|
|||||||
# or just drop 2.6 support ;)
|
# or just drop 2.6 support ;)
|
||||||
with self.network() as network:
|
with self.network() as network:
|
||||||
with self.subnet(network=network, gateway_ip='10.0.0.1',
|
with self.subnet(network=network, gateway_ip='10.0.0.1',
|
||||||
cidr='10.0.1.0/24') as subnet:
|
cidr='10.0.0.0/24') as subnet:
|
||||||
with self.subnet(network=network, gateway_ip='10.0.1.1',
|
with self.subnet(network=network, gateway_ip='10.0.1.1',
|
||||||
cidr='10.0.1.0/24') as subnet2:
|
cidr='10.0.1.0/24') as subnet2:
|
||||||
req = self.new_list_request('subnets')
|
req = self.new_list_request('subnets')
|
||||||
|
Loading…
x
Reference in New Issue
Block a user