From 200f9d53be496dcb331d24f721cb63f66f653bbd Mon Sep 17 00:00:00 2001 From: Gary Kotton Date: Wed, 23 Jan 2013 07:39:18 +0000 Subject: [PATCH] LinuxBridge: set port status as 'DOWN' on creation When a port is created the initial status will be 'DOWN'. The agent in turn will update the plugin of the actual port status. Change-Id: I66b51501304f7cb3f0157a4adaec4b82c62b30a3 --- quantum/db/db_base_plugin_v2.py | 7 ++++++- quantum/plugins/linuxbridge/lb_quantum_plugin.py | 3 +++ .../tests/unit/linuxbridge/test_linuxbridge_plugin.py | 6 ++++++ quantum/tests/unit/test_db_plugin.py | 9 ++++++--- 4 files changed, 21 insertions(+), 4 deletions(-) diff --git a/quantum/db/db_base_plugin_v2.py b/quantum/db/db_base_plugin_v2.py index ad0ddae900..16cee3cd49 100644 --- a/quantum/db/db_base_plugin_v2.py +++ b/quantum/db/db_base_plugin_v2.py @@ -1213,13 +1213,18 @@ class QuantumDbPluginV2(quantum_plugin_base_v2.QuantumPluginBaseV2): # Returns the IP's for the port ips = self._allocate_ips_for_port(context, network, port) + if 'status' not in p: + status = constants.PORT_STATUS_ACTIVE + else: + status = p['status'] + port = models_v2.Port(tenant_id=tenant_id, name=p['name'], id=port_id, network_id=network_id, mac_address=mac_address, admin_state_up=p['admin_state_up'], - status=constants.PORT_STATUS_ACTIVE, + status=status, device_id=p['device_id'], device_owner=p['device_owner']) context.session.add(port) diff --git a/quantum/plugins/linuxbridge/lb_quantum_plugin.py b/quantum/plugins/linuxbridge/lb_quantum_plugin.py index 976178d0dc..89b3d7a015 100644 --- a/quantum/plugins/linuxbridge/lb_quantum_plugin.py +++ b/quantum/plugins/linuxbridge/lb_quantum_plugin.py @@ -481,6 +481,9 @@ class LinuxBridgePluginV2(db_base_plugin_v2.QuantumDbPluginV2, with session.begin(subtransactions=True): self._ensure_default_security_group_on_port(context, port) sgids = self._get_security_groups_on_port(context, port) + # Set port status as 'DOWN'. This will be updated by agent + port['port']['status'] = q_const.PORT_STATUS_DOWN + port = super(LinuxBridgePluginV2, self).create_port(context, port) self._process_port_create_security_group( diff --git a/quantum/tests/unit/linuxbridge/test_linuxbridge_plugin.py b/quantum/tests/unit/linuxbridge/test_linuxbridge_plugin.py index 1112a0c91b..bd41d4f0ae 100644 --- a/quantum/tests/unit/linuxbridge/test_linuxbridge_plugin.py +++ b/quantum/tests/unit/linuxbridge/test_linuxbridge_plugin.py @@ -26,6 +26,7 @@ class LinuxBridgePluginV2TestCase(test_plugin.QuantumDbPluginV2TestCase): def setUp(self): super(LinuxBridgePluginV2TestCase, self).setUp(PLUGIN_NAME) + self.port_create_status = 'DOWN' class TestLinuxBridgeBasicGet(test_plugin.TestBasicGet, @@ -45,6 +46,11 @@ class TestLinuxBridgePortsV2(test_plugin.TestPortsV2, VIF_TYPE = portbindings.VIF_TYPE_BRIDGE HAS_PORT_FILTER = True + def test_update_port_status_build(self): + with self.port() as port: + self.assertEqual(port['port']['status'], 'DOWN') + self.assertEqual(self.port_create_status, 'DOWN') + class TestLinuxBridgeNetworksV2(test_plugin.TestNetworksV2, LinuxBridgePluginV2TestCase): diff --git a/quantum/tests/unit/test_db_plugin.py b/quantum/tests/unit/test_db_plugin.py index 5f78c802c2..fbbf77ca03 100644 --- a/quantum/tests/unit/test_db_plugin.py +++ b/quantum/tests/unit/test_db_plugin.py @@ -103,6 +103,8 @@ class QuantumDbPluginV2TestCase(unittest2.TestCase): cfg.CONF.set_override('max_dns_nameservers', 2) cfg.CONF.set_override('max_subnet_host_routes', 2) self.api = APIRouter() + # Set the defualt port status + self.port_create_status = 'ACTIVE' def _is_native_bulk_supported(): plugin_obj = QuantumManager.get_plugin() @@ -616,7 +618,7 @@ class TestV2HTTPResponse(QuantumDbPluginV2TestCase): class TestPortsV2(QuantumDbPluginV2TestCase): def test_create_port_json(self): - keys = [('admin_state_up', True), ('status', 'ACTIVE')] + keys = [('admin_state_up', True), ('status', self.port_create_status)] with self.port(name='myname') as port: for k, v in keys: self.assertEqual(port['port'][k], v) @@ -640,7 +642,7 @@ class TestPortsV2(QuantumDbPluginV2TestCase): self.assertEqual(res.status_int, 403) def test_create_port_public_network(self): - keys = [('admin_state_up', True), ('status', 'ACTIVE')] + keys = [('admin_state_up', True), ('status', self.port_create_status)] with self.network(shared=True) as network: port_res = self._create_port('json', network['network']['id'], @@ -656,7 +658,8 @@ class TestPortsV2(QuantumDbPluginV2TestCase): def test_create_port_public_network_with_ip(self): with self.network(shared=True) as network: with self.subnet(network=network, cidr='10.0.0.0/24') as subnet: - keys = [('admin_state_up', True), ('status', 'ACTIVE'), + keys = [('admin_state_up', True), + ('status', self.port_create_status), ('fixed_ips', [{'subnet_id': subnet['subnet']['id'], 'ip_address': '10.0.0.2'}])] port_res = self._create_port('json',