summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2014-10-23 11:55:44 +0000
committerGerrit Code Review <review@openstack.org>2014-10-23 11:55:44 +0000
commit2eef0dc03d4fd6d7363cdb8fc02c4d5d188c1a88 (patch)
tree6f22ce0d83bd240f50ed3df1fff285d70460c5d3
parentdfe800bbd5b8cfe13b6c3b662995064ffed055a6 (diff)
parentd712663b99520e6d26269b0ca193527603178742 (diff)
downloadneutron-2eef0dc03d4fd6d7363cdb8fc02c4d5d188c1a88.tar.gz
Merge "Move disabling of metadata and ipv6_ra to _destroy_router_namespace"
-rw-r--r--neutron/agent/l3_agent.py9
-rw-r--r--neutron/tests/unit/services/vpn/test_vpn_agent.py5
-rw-r--r--neutron/tests/unit/test_l3_agent.py5
3 files changed, 7 insertions, 12 deletions
diff --git a/neutron/agent/l3_agent.py b/neutron/agent/l3_agent.py
index 2bb784277f..03f21d2bb7 100644
--- a/neutron/agent/l3_agent.py
+++ b/neutron/agent/l3_agent.py
@@ -644,7 +644,6 @@ class L3NATAgent(firewall_l3_agent.FWaaSL3AgentRpcCallback,
one attempt will be made to delete them.
"""
for ns in router_namespaces:
- ra.disable_ipv6_ra(ns[len(NS_PREFIX):], ns, self.root_helper)
try:
self._destroy_namespace(ns)
except RuntimeError:
@@ -654,8 +653,6 @@ class L3NATAgent(firewall_l3_agent.FWaaSL3AgentRpcCallback,
def _destroy_namespace(self, ns):
if ns.startswith(NS_PREFIX):
- if self.conf.enable_metadata_proxy:
- self._destroy_metadata_proxy(ns[len(NS_PREFIX):], ns)
self._destroy_router_namespace(ns)
elif ns.startswith(FIP_NS_PREFIX):
self._destroy_fip_namespace(ns)
@@ -704,6 +701,10 @@ class L3NATAgent(firewall_l3_agent.FWaaSL3AgentRpcCallback,
self.agent_gateway_port = None
def _destroy_router_namespace(self, ns):
+ router_id = ns[len(NS_PREFIX):]
+ ra.disable_ipv6_ra(router_id, ns, self.root_helper)
+ if self.conf.enable_metadata_proxy:
+ self._destroy_metadata_proxy(router_id, ns)
ns_ip = ip_lib.IPWrapper(self.root_helper, namespace=ns)
for d in ns_ip.get_devices(exclude_loopback=True):
if d.name.startswith(INTERNAL_DEV_PREFIX):
@@ -807,8 +808,6 @@ class L3NATAgent(firewall_l3_agent.FWaaSL3AgentRpcCallback,
for c, r in self.metadata_nat_rules():
ri.iptables_manager.ipv4['nat'].remove_rule(c, r)
ri.iptables_manager.apply()
- if self.conf.enable_metadata_proxy:
- self._destroy_metadata_proxy(ri.router_id, ri.ns_name)
del self.router_info[router_id]
self._destroy_router_namespace(ri.ns_name)
diff --git a/neutron/tests/unit/services/vpn/test_vpn_agent.py b/neutron/tests/unit/services/vpn/test_vpn_agent.py
index 987b26cd4d..d6ab140fc3 100644
--- a/neutron/tests/unit/services/vpn/test_vpn_agent.py
+++ b/neutron/tests/unit/services/vpn/test_vpn_agent.py
@@ -171,9 +171,10 @@ class TestVPNAgent(base.BaseTestCase):
'neutron.agent.linux.iptables_manager.IptablesManager').start()
router_id = _uuid()
ri = l3_agent.RouterInfo(router_id, self.conf.root_helper,
- self.conf.use_namespaces, {})
+ self.conf.use_namespaces, {},
+ ns_name="qrouter-%s" % router_id)
ri.router = {
- 'id': _uuid(),
+ 'id': router_id,
'admin_state_up': True,
'routes': [],
'external_gateway_info': {},
diff --git a/neutron/tests/unit/test_l3_agent.py b/neutron/tests/unit/test_l3_agent.py
index 38fd1e811a..df362342d7 100644
--- a/neutron/tests/unit/test_l3_agent.py
+++ b/neutron/tests/unit/test_l3_agent.py
@@ -2016,15 +2016,10 @@ vrrp_instance VR_1 {
ns_list = agent._list_namespaces()
agent._cleanup_namespaces(ns_list, [r['id'] for r in router_list])
- # Expect process manager to disable one radvd per stale namespace
- expected_pm_disables = len(stale_namespace_list)
-
# Expect process manager to disable metadata proxy per qrouter ns
qrouters = [n for n in stale_namespace_list
if n.startswith(l3_agent.NS_PREFIX)]
- expected_pm_disables += len(qrouters)
- self.assertEqual(expected_pm_disables, pm.disable.call_count)
self.assertEqual(agent._destroy_router_namespace.call_count,
len(qrouters))
self.assertEqual(agent._destroy_snat_namespace.call_count,