Add a route to reach the MD server when a subnet is created

When the first subnet is created, the dhcp port is created and
midonet plugin correctly adds the static route to reach the MD
server in create_port. When a second or following subnets are
created, a new ip is added to the dhcp port. This patch takes
care of adding the static route to correcly reach the MD server
in update_port. This fixes the problem of VMs not being able to
reach the MD if assigned to the second subnet

Closes-bug: #1231914
Change-Id: Ifc95f901d4222b76a4254e21295829ac8d82493b
This commit is contained in:
Rossella Sblendido 2013-09-25 14:55:04 +00:00
parent 61dce1a606
commit cf7aca87e1
2 changed files with 39 additions and 10 deletions

View File

@ -625,20 +625,30 @@ class MidonetPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
old_port = self._get_port(context, id) old_port = self._get_port(context, id)
net_id = old_port["network_id"] net_id = old_port["network_id"]
mac = old_port["mac_address"] mac = old_port["mac_address"]
old_fixed_ips = old_port.get('fixed_ips') old_ips = old_port["fixed_ips"]
# update the port DB # update the port DB
p = super(MidonetPluginV2, self).update_port(context, id, port) p = super(MidonetPluginV2, self).update_port(context, id, port)
if "fixed_ips" in p: new_ips = p["fixed_ips"]
# IPs have changed. Re-map the DHCP entries if new_ips:
bridge = self.client.get_bridge(net_id) bridge = self.client.get_bridge(net_id)
for cidr, ip, mac in self._dhcp_mappings( # If it's a DHCP port, add a route to reach the MD server
context, old_fixed_ips, mac): if _is_dhcp_port(p):
self.client.remove_dhcp_host(bridge, cidr, ip, mac) for cidr, ip in self._metadata_subnets(
for cidr, ip, mac in self._dhcp_mappings(context, context, new_ips):
p["fixed_ips"], mac): self.client.add_dhcp_route_option(
self.client.add_dhcp_host(bridge, cidr, ip, mac) bridge, cidr, ip, METADATA_DEFAULT_IP)
else:
# IPs have changed. Re-map the DHCP entries
for cidr, ip, mac in self._dhcp_mappings(
context, old_ips, mac):
self.client.remove_dhcp_host(
bridge, cidr, ip, mac)
for cidr, ip, mac in self._dhcp_mappings(
context, new_ips, mac):
self.client.add_dhcp_host(
bridge, cidr, ip, mac)
if (self._check_update_deletes_security_groups(port) or if (self._check_update_deletes_security_groups(port) or
self._check_update_has_security_groups(port)): self._check_update_has_security_groups(port)):

View File

@ -108,6 +108,25 @@ class MidoClientTestCase(testtools.TestCase):
"2A:DB:6B:8C:19:99") "2A:DB:6B:8C:19:99")
bridge.assert_has_calls(calls, any_order=True) bridge.assert_has_calls(calls, any_order=True)
def test_add_dhcp_route_option(self):
bridge = mock.Mock()
subnet = bridge.get_dhcp_subnet.return_value
subnet.get_opt121_routes.return_value = None
dhcp_subnet_call = mock.call.get_dhcp_subnet("10.0.0.0_24")
dst_ip = "10.0.0.3/24"
gw_ip = "10.0.0.1"
prefix, length = dst_ip.split("/")
routes = [{'destinationPrefix': prefix, 'destinationLength': length,
'gatewayAddr': gw_ip}]
opt121_routes_call = dhcp_subnet_call.opt121_routes(routes)
calls = [dhcp_subnet_call, opt121_routes_call,
opt121_routes_call.update()]
self.client.add_dhcp_route_option(bridge, "10.0.0.0/24",
gw_ip, dst_ip)
bridge.assert_has_calls(calls, any_order=True)
def test_get_router_error(self): def test_get_router_error(self):
self.mock_api.get_router.side_effect = w_exc.HTTPInternalServerError() self.mock_api.get_router.side_effect = w_exc.HTTPInternalServerError()
self.assertRaises(midonet_lib.MidonetApiException, self.assertRaises(midonet_lib.MidonetApiException,