Merge "fix check_ports_exist_on_l3agent in no subnet case"
This commit is contained in:
commit
f4e08b1381
@ -385,6 +385,8 @@ class L3AgentSchedulerDbMixin(l3agentscheduler.L3AgentSchedulerPluginBase,
|
|||||||
ports on the host, running the input l3agent.
|
ports on the host, running the input l3agent.
|
||||||
"""
|
"""
|
||||||
subnet_ids = self.get_subnet_ids_on_router(context, router_id)
|
subnet_ids = self.get_subnet_ids_on_router(context, router_id)
|
||||||
|
if not subnet_ids:
|
||||||
|
return False
|
||||||
|
|
||||||
core_plugin = manager.NeutronManager.get_plugin()
|
core_plugin = manager.NeutronManager.get_plugin()
|
||||||
filter = {'fixed_ips': {'subnet_id': subnet_ids}}
|
filter = {'fixed_ips': {'subnet_id': subnet_ids}}
|
||||||
|
@ -667,32 +667,44 @@ class L3SchedulerTestBaseMixin(object):
|
|||||||
|
|
||||||
def test_check_ports_exist_on_l3agent_no_subnets(self):
|
def test_check_ports_exist_on_l3agent_no_subnets(self):
|
||||||
l3_agent, router = self._prepare_check_ports_exist_tests()
|
l3_agent, router = self._prepare_check_ports_exist_tests()
|
||||||
|
with mock.patch.object(manager.NeutronManager,
|
||||||
|
'get_plugin') as getp:
|
||||||
|
getp.return_value = self.plugin
|
||||||
# no subnets
|
# no subnets
|
||||||
|
self.get_subnet_ids_on_router.return_value = set()
|
||||||
val = self.check_ports_exist_on_l3agent(self.adminContext,
|
val = self.check_ports_exist_on_l3agent(self.adminContext,
|
||||||
l3_agent, router['id'])
|
l3_agent, router['id'])
|
||||||
|
self.assertFalse(self.plugin.get_ports.called)
|
||||||
self.assertFalse(val)
|
self.assertFalse(val)
|
||||||
|
|
||||||
def test_check_ports_exist_on_l3agent_no_subnet_match(self):
|
def test_check_ports_exist_on_l3agent_no_subnet_match(self):
|
||||||
l3_agent, router = self._prepare_check_ports_exist_tests()
|
l3_agent, router = self._prepare_check_ports_exist_tests()
|
||||||
|
with mock.patch.object(manager.NeutronManager,
|
||||||
|
'get_plugin') as getp:
|
||||||
|
getp.return_value = self.plugin
|
||||||
# no matching subnet
|
# no matching subnet
|
||||||
self.plugin.get_subnet_ids_on_router = mock.Mock(
|
self.get_subnet_ids_on_router.return_value = [str(uuid.uuid4())]
|
||||||
return_value=[str(uuid.uuid4())])
|
|
||||||
val = self.check_ports_exist_on_l3agent(self.adminContext,
|
val = self.check_ports_exist_on_l3agent(self.adminContext,
|
||||||
l3_agent, router['id'])
|
l3_agent, router['id'])
|
||||||
|
self.assertTrue(self.plugin.get_ports.called)
|
||||||
self.assertFalse(val)
|
self.assertFalse(val)
|
||||||
|
|
||||||
def test_check_ports_exist_on_l3agent_subnet_match(self):
|
def test_check_ports_exist_on_l3agent_subnet_match(self):
|
||||||
l3_agent, router = self._prepare_check_ports_exist_tests()
|
l3_agent, router = self._prepare_check_ports_exist_tests()
|
||||||
|
with mock.patch.object(manager.NeutronManager,
|
||||||
|
'get_plugin') as getp:
|
||||||
|
getp.return_value = self.plugin
|
||||||
# matching subnet
|
# matching subnet
|
||||||
port = {'subnet_id': str(uuid.uuid4()),
|
port = {'subnet_id': str(uuid.uuid4()),
|
||||||
'binding:host_id': 'host_1',
|
'binding:host_id': 'host_1',
|
||||||
'device_owner': 'compute:',
|
'device_owner': 'compute:',
|
||||||
'id': 1234}
|
'id': 1234}
|
||||||
self.plugin.get_ports.return_value = [port]
|
self.plugin.get_ports.return_value = [port]
|
||||||
self.plugin.get_subnet_ids_on_router = mock.Mock(
|
self.get_subnet_ids_on_router = mock.Mock(
|
||||||
return_value=[port['subnet_id']])
|
return_value=[port['subnet_id']])
|
||||||
val = self.check_ports_exist_on_l3agent(self.adminContext,
|
val = self.check_ports_exist_on_l3agent(self.adminContext,
|
||||||
l3_agent, router['id'])
|
l3_agent, router['id'])
|
||||||
|
self.assertTrue(self.plugin.get_ports.called)
|
||||||
self.assertTrue(val)
|
self.assertTrue(val)
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user