From f7ccaac6f09cf890d51f8974ecf6714afea8c41b Mon Sep 17 00:00:00 2001 From: root Date: Mon, 18 Jun 2012 06:09:00 -0400 Subject: [PATCH] Unit test and Readme changes related to cisco plugin. Change-Id: Ica6db500a2ec8a895cb90756ca9ff304faa16519 Unit test and Readme changes related to cisco plugin. Remove additional space in the Readme file Remove file inadverntently checked in Bug #1015410 Change-Id: I273255ff475b1ca6e80409fbf7f8c8571b3c456c --- etc/quantum/plugins/cisco/cisco_plugins.ini | 4 +- quantum/plugins/cisco/README | 32 ++-- .../cisco/tests/unit/test_l2networkApi.py | 139 ++++++++++-------- .../cisco/tests/unit/test_ucs_inventory.py | 2 - .../cisco/tests/unit/test_ucs_plugin.py | 4 +- 5 files changed, 105 insertions(+), 76 deletions(-) diff --git a/etc/quantum/plugins/cisco/cisco_plugins.ini b/etc/quantum/plugins/cisco/cisco_plugins.ini index de98ccb18e2..2e6308766a1 100644 --- a/etc/quantum/plugins/cisco/cisco_plugins.ini +++ b/etc/quantum/plugins/cisco/cisco_plugins.ini @@ -1,7 +1,7 @@ [PLUGINS] -ucs_plugin=quantum.plugins.cisco.ucs.cisco_ucs_plugin.UCSVICPlugin +#ucs_plugin=quantum.plugins.cisco.ucs.cisco_ucs_plugin.UCSVICPlugin #nexus_plugin=quantum.plugins.cisco.nexus.cisco_nexus_plugin.NexusPlugin [INVENTORY] -ucs_plugin=quantum.plugins.cisco.ucs.cisco_ucs_inventory.UCSInventory +#ucs_plugin=quantum.plugins.cisco.ucs.cisco_ucs_inventory.UCSInventory #nexus_plugin=quantum.plugins.cisco.nexus.cisco_nexus_inventory.NexusInventory diff --git a/quantum/plugins/cisco/README b/quantum/plugins/cisco/README index d817643631f..bccbcb55548 100755 --- a/quantum/plugins/cisco/README +++ b/quantum/plugins/cisco/README @@ -46,6 +46,7 @@ If you plan to just leverage the plugin framework, you do not need these.) ** Ubuntu 11.10 or above ** Package: python-configobj-4.6.0-3.el6.noarch (or newer) ** Package: python-routes-1.12.3-2.el6.noarch (or newer) + ** Package: pip install mysql-python If you are using a Nexus switch in your topology, you'll need the following NX-OS version and packages to enable Nexus support: @@ -364,29 +365,33 @@ result the run_tests.py script. 1. All unit tests (needs environment setup as indicated in the pre-requisites): - ./run_tests.sh -N quantum.plugins.cisco.tests.unit - - or by modifying the environment variable to point to the plugin directory + Modify the environment variable to point to the plugin directory In bash : export PLUGIN_DIR=quantum/plugins/cisco tcsh/csh : setenv PLUGIN_DIR quantum/plugins/cisco - ./run_tests.sh -N + When no sub-plugins are configured(ucs or nexus plugins), execute only the l2networkApi unit tests. + Device-specific sub-plugins can be disabled by commenting out all the entries in: + etc/quantum/plugins/cisco/cisco_plugins.ini - Another option is to execute the python script run_tests.py + Execute the l2networkApi tests only using: + ./run_tests.sh quantum.plugins.cisco.tests.unit.test_l2networkApi - python run_tests.py quantum.plugins.cisco.tests.unit + If just the ucs or both ucs and the nexus plugins are configured then all the tests could be executed by + ./run_tests.sh + + All the test execution steps listed below is for when the sub-plugins are configured. 2. Testing the core API (without UCS/Nexus/RHEL hardware, and can be run on Ubuntu): - Device-specific plugins can be disabled by commenting out the entries in: - etc/quantum/plugins/cisco/cisco_plugins.ini The Core API can be tested by initially disabling all device plugins, then enabling just the UCS plugins, and finally enabling both the UCS and the Nexus plugins. + Device-specific plugins can be disabled by commenting out the entries in: + etc/quantum/plugins/cisco/cisco_plugins.ini Execute the test script as follows: - ./run_tests.sh -N quantum.plugins.cisco.tests.unit.test_l2networkApi + ./run_tests.sh quantum.plugins.cisco.tests.unit.test_l2networkApi or @@ -395,7 +400,7 @@ result the run_tests.py script. 3. Specific Plugin unit test (needs environment setup as indicated in the pre-requisites): - ./run_tests.sh -N quantum.plugins.cisco.tests.unit. + ./run_tests.sh quantum.plugins.cisco.tests.unit. or @@ -405,6 +410,11 @@ result the run_tests.py script. python run_tests.py quantum.plugins.cisco.tests.unit.test_ucs_plugin To run specific tests, use the following: + + ./run_tests.sh quantum.plugins.cisco.tests.unit.:. + + or + python run_tests.py quantum.plugins.cisco.tests.unit.:. @@ -418,7 +428,7 @@ result the run_tests.py script. Location quantum/plugins/cisco/tests/unit/test_cisco_extension.py The script can be executed by : - ./run_tests.sh -N quantum.plugins.cisco.tests.unit.test_cisco_extension + ./run_tests.sh quantum.plugins.cisco.tests.unit.test_cisco_extension or diff --git a/quantum/plugins/cisco/tests/unit/test_l2networkApi.py b/quantum/plugins/cisco/tests/unit/test_l2networkApi.py index fa3824ff0c8..d335fbd2299 100644 --- a/quantum/plugins/cisco/tests/unit/test_l2networkApi.py +++ b/quantum/plugins/cisco/tests/unit/test_l2networkApi.py @@ -113,10 +113,13 @@ class CoreAPITestFunc(unittest.TestCase): instance_vif_desc = {'project_id': tenant_id, 'user_id': nova_user_id, 'vif_id': vif_id} - vif_description = self._l2network_plugin.associate_port( - instance_tenant_id, instance_id, - instance_vif_desc) - + if conf.PLUGINS[const.PLUGINS].keys(): + vif_description = self._l2network_plugin.associate_port( + instance_tenant_id, instance_id, instance_vif_desc) + else: + db.port_set_attachment_by_id(port_dict[const.PORT_ID], + instance_vif_desc['vif_id'] + + const.UNPLUGGED) self.assertRaises(exc.NetworkInUse, self._l2network_plugin.delete_network, tenant_id, new_net_dict[const.NET_ID]) @@ -359,7 +362,6 @@ class CoreAPITestFunc(unittest.TestCase): """ Tests deletion of Ports when port is in Use. """ - LOG.debug("test_delete_portInUse - START") new_net_dict = self._l2network_plugin.create_network( tenant_id, self.network_name) @@ -374,12 +376,17 @@ class CoreAPITestFunc(unittest.TestCase): instance_vif_desc = {'project_id': tenant_id, 'user_id': nova_user_id, 'vif_id': vif_id} - vif_description = self._l2network_plugin.associate_port( - instance_tenant_id, instance_id, - instance_vif_desc) - self.assertRaises(exc.PortInUse, - self._l2network_plugin.delete_port, tenant_id, - new_net_dict[const.NET_ID], port_dict[const.PORT_ID]) + if conf.PLUGINS[const.PLUGINS].keys(): + vif_description = self._l2network_plugin.associate_port( + instance_tenant_id, instance_id, instance_vif_desc) + else: + db.port_set_attachment_by_id(port_dict[const.PORT_ID], + instance_vif_desc['vif_id'] + + const.UNPLUGGED) + + self.assertRaises(exc.PortInUse, self._l2network_plugin.delete_port, + tenant_id, new_net_dict[const.NET_ID], + port_dict[const.PORT_ID]) self.tearDownNetworkPortInterface( tenant_id, instance_tenant_id, instance_id, instance_vif_desc, new_net_dict[const.NET_ID], port_dict[const.PORT_ID]) @@ -506,13 +513,19 @@ class CoreAPITestFunc(unittest.TestCase): instance_vif_desc = {'project_id': tenant_id, 'user_id': nova_user_id, 'vif_id': vif_id} - vif_description = self._l2network_plugin.associate_port( - instance_tenant_id, instance_id, - instance_vif_desc) - self._l2network_plugin.plug_interface( - tenant_id, new_net_dict[const.NET_ID], - port_dict[const.PORT_ID], vif_id) + if conf.PLUGINS[const.PLUGINS].keys(): + vif_description = self._l2network_plugin.associate_port( + instance_tenant_id, instance_id, + instance_vif_desc) + else: + db.port_set_attachment_by_id(port_dict[const.PORT_ID], + instance_vif_desc['vif_id'] + + const.UNPLUGGED) + + self._l2network_plugin.plug_interface(tenant_id, + new_net_dict[const.NET_ID], + port_dict[const.PORT_ID], vif_id) port = db.port_get(new_net_dict[const.NET_ID], port_dict[const.PORT_ID]) self.assertEqual(port[const.INTERFACEID], vif_id) @@ -543,13 +556,13 @@ class CoreAPITestFunc(unittest.TestCase): """ Tests attachment of interface port does not exist """ - LOG.debug("test_plug_interface_portDNE - START") new_net_dict = self._l2network_plugin.create_network(tenant_id, self.network_name) - self.assertRaises( - exc.PortNotFound, self._l2network_plugin.plug_interface, tenant_id, - new_net_dict[const.NET_ID], port_id, remote_interface) + self.assertRaises(exc.PortNotFound, + self._l2network_plugin.plug_interface, + tenant_id, new_net_dict[const.NET_ID], port_id, + remote_interface) self.tearDownNetwork(tenant_id, new_net_dict[const.NET_ID]) LOG.debug("test_plug_interface_portDNE - END") @@ -564,31 +577,33 @@ class CoreAPITestFunc(unittest.TestCase): Tests attachment of new interface to the port when there is an existing attachment """ - LOG.debug("test_plug_interface_portInUse - START") - new_net_dict = self._l2network_plugin.create_network( - tenant_id, self.network_name) + new_net_dict = self._l2network_plugin.create_network(tenant_id, + self.network_name) port_dict = self._l2network_plugin.create_port( tenant_id, new_net_dict[const.NET_ID], self.state) - instance_desc = {'project_id': tenant_id, - 'user_id': nova_user_id} + instance_desc = {'project_id': tenant_id, 'user_id': nova_user_id} host_list = self._l2network_plugin.schedule_host(instance_tenant_id, instance_id, instance_desc) - instance_vif_desc = {'project_id': tenant_id, - 'user_id': nova_user_id, + instance_vif_desc = {'project_id': tenant_id, 'user_id': nova_user_id, 'vif_id': vif_id} - vif_description = self._l2network_plugin.associate_port( - instance_tenant_id, instance_id, - instance_vif_desc) - self.assertRaises(exc.PortInUse, - self._l2network_plugin.plug_interface, tenant_id, - new_net_dict[const.NET_ID], + if conf.PLUGINS[const.PLUGINS].keys(): + vif_description = self._l2network_plugin.associate_port( + instance_tenant_id, instance_id, instance_vif_desc) + else: + db.port_set_attachment_by_id(port_dict[const.PORT_ID], + instance_vif_desc['vif_id'] + + const.UNPLUGGED) + + self.assertRaises(exc.PortInUse, self._l2network_plugin.plug_interface, + tenant_id, new_net_dict[const.NET_ID], port_dict[const.PORT_ID], remote_interface) - self.tearDownNetworkPortInterface( - tenant_id, instance_tenant_id, instance_id, instance_vif_desc, - new_net_dict[const.NET_ID], port_dict[const.PORT_ID]) + self.tearDownNetworkPortInterface(tenant_id, instance_tenant_id, + instance_id, instance_vif_desc, + new_net_dict[const.NET_ID], + port_dict[const.PORT_ID]) LOG.debug("test_plug_interface_portInUse - END") @@ -599,38 +614,43 @@ class CoreAPITestFunc(unittest.TestCase): """ Tests detaachment of an interface to a port """ - LOG.debug("test_unplug_interface - START") - new_net_dict = self._l2network_plugin.create_network( - tenant_id, self.network_name) + new_net_dict = self._l2network_plugin.create_network(tenant_id, + self.network_name) port_dict = self._l2network_plugin.create_port( - tenant_id, new_net_dict[const.NET_ID], - self.state) + tenant_id, new_net_dict[const.NET_ID], self.state) instance_desc = {'project_id': tenant_id, 'user_id': nova_user_id} host_list = self._l2network_plugin.schedule_host(instance_tenant_id, instance_id, instance_desc) - instance_vif_desc = {'project_id': tenant_id, - 'user_id': nova_user_id, + instance_vif_desc = {'project_id': tenant_id, 'user_id': nova_user_id, 'vif_id': vif_id} - vif_description = self._l2network_plugin.associate_port( - instance_tenant_id, instance_id, - instance_vif_desc) - self._l2network_plugin.plug_interface( - tenant_id, new_net_dict[const.NET_ID], - port_dict[const.PORT_ID], vif_id) - self._l2network_plugin.unplug_interface( - tenant_id, new_net_dict[const.NET_ID], - port_dict[const.PORT_ID]) + if conf.PLUGINS[const.PLUGINS].keys(): + vif_description = self._l2network_plugin. associate_port( + instance_tenant_id, + instance_id, + instance_vif_desc) + else: + db.port_set_attachment_by_id(port_dict[const.PORT_ID], + instance_vif_desc['vif_id'] + + const.UNPLUGGED) + + self._l2network_plugin.plug_interface(tenant_id, + new_net_dict[const.NET_ID], + port_dict[const.PORT_ID], vif_id) + self._l2network_plugin.unplug_interface(tenant_id, + new_net_dict[const.NET_ID], + port_dict[const.PORT_ID]) port = db.port_get(new_net_dict[const.NET_ID], port_dict[const.PORT_ID]) vif_id_unplugged = vif_id + '(detached)' self.assertEqual(port[const.INTERFACEID], vif_id_unplugged) - self.tearDownNetworkPortInterface( - tenant_id, instance_tenant_id, instance_id, instance_vif_desc, - new_net_dict[const.NET_ID], port_dict[const.PORT_ID]) + self.tearDownNetworkPortInterface(tenant_id, instance_tenant_id, + instance_id, instance_vif_desc, + new_net_dict[const.NET_ID], + port_dict[const.PORT_ID]) LOG.debug("test_unplug_interface - END") @@ -1020,8 +1040,11 @@ class CoreAPITestFunc(unittest.TestCase): """ Tear down Network Port Interface """ - self._l2network_plugin.detach_port(instance_tenant_id, instance_id, - instance_desc) + if not conf.PLUGINS[const.PLUGINS].keys(): + db.port_unset_attachment_by_id(port_id) + else: + self._l2network_plugin.detach_port(instance_tenant_id, instance_id, + instance_desc) self.tearDownNetworkPort(tenant_id, network_dict_id, port_id) def tearDownPortProfile(self, tenant_id, port_profile_id): diff --git a/quantum/plugins/cisco/tests/unit/test_ucs_inventory.py b/quantum/plugins/cisco/tests/unit/test_ucs_inventory.py index 1183aa85ae1..537bc2e5195 100644 --- a/quantum/plugins/cisco/tests/unit/test_ucs_inventory.py +++ b/quantum/plugins/cisco/tests/unit/test_ucs_inventory.py @@ -29,10 +29,8 @@ from quantum.plugins.cisco.l2network_plugin import L2Network from quantum.plugins.cisco.ucs.cisco_ucs_inventory import UCSInventory -logging.basicConfig(level=LOG.WARN) LOG = logging.getLogger(__name__) - # Set some data to use in tests tenant = 'shubh' net_name = 'TestNetwork1' diff --git a/quantum/plugins/cisco/tests/unit/test_ucs_plugin.py b/quantum/plugins/cisco/tests/unit/test_ucs_plugin.py index 5bcd74be8f4..887359b8913 100644 --- a/quantum/plugins/cisco/tests/unit/test_ucs_plugin.py +++ b/quantum/plugins/cisco/tests/unit/test_ucs_plugin.py @@ -29,9 +29,7 @@ from quantum.plugins.cisco.ucs import cisco_ucs_configuration as conf from quantum.plugins.cisco.ucs import cisco_ucs_inventory as ucsinv from quantum.plugins.cisco.ucs import cisco_ucs_plugin - -logging.basicConfig(level=LOG.WARN) -LOG = logging.getLogger("cisco_ucs_plugin") +LOG = logging.getLogger(__name__) class UCSVICTestPlugin(unittest.TestCase):