Merge "Do not add DHCP info to subnet if DHCP is disabled"

This commit is contained in:
Jenkins 2013-11-28 20:01:14 +00:00 committed by Gerrit Code Review
commit 87d1c346c4
2 changed files with 20 additions and 10 deletions

View File

@ -251,6 +251,9 @@ class MidonetPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
if subnet["ip_version"] == 6: if subnet["ip_version"] == 6:
# TODO(ryu) handle IPv6 # TODO(ryu) handle IPv6
continue continue
if not subnet["enable_dhcp"]:
# Skip if DHCP is disabled
continue
yield subnet['cidr'], fixed_ip["ip_address"], mac yield subnet['cidr'], fixed_ip["ip_address"], mac
def _metadata_subnets(self, context, fixed_ips): def _metadata_subnets(self, context, fixed_ips):
@ -406,6 +409,7 @@ class MidonetPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
gateway_ip = s['gateway_ip'] gateway_ip = s['gateway_ip']
cidr = s['cidr'] cidr = s['cidr']
if s['enable_dhcp']:
dns_nameservers = None dns_nameservers = None
host_routes = None host_routes = None
if s['dns_nameservers'] is not attributes.ATTR_NOT_SPECIFIED: if s['dns_nameservers'] is not attributes.ATTR_NOT_SPECIFIED:
@ -443,6 +447,7 @@ class MidonetPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
super(MidonetPluginV2, self).delete_subnet(context, id) super(MidonetPluginV2, self).delete_subnet(context, id)
bridge = self.client.get_bridge(subnet['network_id']) bridge = self.client.get_bridge(subnet['network_id'])
if subnet['enable_dhcp']:
self.client.delete_dhcp(bridge, subnet['cidr']) self.client.delete_dhcp(bridge, subnet['cidr'])
# If the network is external, clean up routes, links, ports # If the network is external, clean up routes, links, ports

View File

@ -131,6 +131,11 @@ class TestMidonetSubnetsV2(test_plugin.TestSubnetsV2,
def test_create_subnet_inconsistent_ipv6_gatewayv4(self): def test_create_subnet_inconsistent_ipv6_gatewayv4(self):
pass pass
def test_create_subnet_dhcp_disabled(self):
super(TestMidonetSubnetsV2, self)._test_create_subnet(
enable_dhcp=False)
self.assertFalse(self.instance.return_value.create_dhcp.called)
class TestMidonetPortsV2(test_plugin.TestPortsV2, class TestMidonetPortsV2(test_plugin.TestPortsV2,
MidonetPluginV2TestCase): MidonetPluginV2TestCase):