From a049b476eccaa9c9be2ce18c868e77c8b06a3dc7 Mon Sep 17 00:00:00 2001 From: Rich Curran Date: Thu, 10 Apr 2014 17:11:32 -0400 Subject: [PATCH] ML2 Cisco Nexus MD: Remove unnecessary Cisco nexus DB The nexus switch information is retrieved from a dictionary created at initialization. The ML2 cisco credentials database in not needed. Change-Id: I723293de9f2b821a011db2ad9176a945fef72ee0 Closes-Bug: 1284676 --- .../4eca4a84f08a_remove_ml2_cisco_cred_db.py | 59 +++++++ .../alembic_migrations/versions/HEAD | 2 +- .../ml2/drivers/cisco/nexus/credentials_v2.py | 71 -------- .../drivers/cisco/nexus/mech_cisco_nexus.py | 5 - .../ml2/drivers/cisco/nexus/network_db_v2.py | 116 ------------ .../drivers/cisco/nexus/network_models_v2.py | 31 ---- .../cisco/nexus/nexus_network_driver.py | 21 +-- .../cisco/nexus/test_cisco_network_db.py | 167 ------------------ .../drivers/cisco/nexus/test_cisco_nexus.py | 18 +- 9 files changed, 66 insertions(+), 424 deletions(-) create mode 100644 neutron/db/migration/alembic_migrations/versions/4eca4a84f08a_remove_ml2_cisco_cred_db.py delete mode 100644 neutron/plugins/ml2/drivers/cisco/nexus/credentials_v2.py delete mode 100644 neutron/plugins/ml2/drivers/cisco/nexus/network_db_v2.py delete mode 100644 neutron/plugins/ml2/drivers/cisco/nexus/network_models_v2.py delete mode 100644 neutron/tests/unit/ml2/drivers/cisco/nexus/test_cisco_network_db.py diff --git a/neutron/db/migration/alembic_migrations/versions/4eca4a84f08a_remove_ml2_cisco_cred_db.py b/neutron/db/migration/alembic_migrations/versions/4eca4a84f08a_remove_ml2_cisco_cred_db.py new file mode 100644 index 0000000000..ed1e8316cf --- /dev/null +++ b/neutron/db/migration/alembic_migrations/versions/4eca4a84f08a_remove_ml2_cisco_cred_db.py @@ -0,0 +1,59 @@ +# Copyright 2014 OpenStack Foundation +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may +# not use this file except in compliance with the License. You may obtain +# a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. +# + +"""Remove ML2 Cisco Credentials DB + +Revision ID: 4eca4a84f08a +Revises: 33c3db036fe4 +Create Date: 2014-04-10 19:32:46.697189 + +""" + +# revision identifiers, used by Alembic. +revision = '4eca4a84f08a' +down_revision = '33c3db036fe4' + +# Change to ['*'] if this migration applies to all plugins + +migration_for_plugins = [ + 'neutron.plugins.ml2.plugin.Ml2Plugin' +] + +from alembic import op +import sqlalchemy as sa + +from neutron.db import migration + + +def upgrade(active_plugins=None, options=None): + if not migration.should_run(active_plugins, migration_for_plugins): + return + + op.drop_table('cisco_ml2_credentials') + + +def downgrade(active_plugins=None, options=None): + if not migration.should_run(active_plugins, migration_for_plugins): + return + + op.create_table( + 'cisco_ml2_credentials', + sa.Column('credential_id', sa.string(length=255), nullable=True), + sa.Column('tenant_id', sa.string(length=255), nullable=False), + sa.Column('credential_name', sa.string(length=255), nullable=False), + sa.Column('user_name', sa.string(length=255), nullable=True), + sa.Column('password', sa.string(length=255), nullable=True), + sa.PrimaryKeyConstraint('tenant_id', 'credential_name') + ) diff --git a/neutron/db/migration/alembic_migrations/versions/HEAD b/neutron/db/migration/alembic_migrations/versions/HEAD index cc5794e19a..a15d5c34c0 100644 --- a/neutron/db/migration/alembic_migrations/versions/HEAD +++ b/neutron/db/migration/alembic_migrations/versions/HEAD @@ -1 +1 @@ -33c3db036fe4 +4eca4a84f08a diff --git a/neutron/plugins/ml2/drivers/cisco/nexus/credentials_v2.py b/neutron/plugins/ml2/drivers/cisco/nexus/credentials_v2.py deleted file mode 100644 index 87d5ce59d0..0000000000 --- a/neutron/plugins/ml2/drivers/cisco/nexus/credentials_v2.py +++ /dev/null @@ -1,71 +0,0 @@ -# Copyright (c) 2013 OpenStack Foundation -# All Rights Reserved. -# -# Licensed under the Apache License, Version 2.0 (the "License"); you may -# not use this file except in compliance with the License. You may obtain -# a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT -# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the -# License for the specific language governing permissions and limitations -# under the License. -# - -from neutron.plugins.ml2.drivers.cisco.nexus import config -from neutron.plugins.ml2.drivers.cisco.nexus import constants as const -from neutron.plugins.ml2.drivers.cisco.nexus import exceptions as cexc -from neutron.plugins.ml2.drivers.cisco.nexus import network_db_v2 as cdb - - -TENANT = const.NETWORK_ADMIN - - -class Store(object): - """ML2 Cisco Mechanism Driver Credential Store.""" - - @staticmethod - def initialize(): - _nexus_dict = config.ML2MechCiscoConfig.nexus_dict - for ipaddr, keyword in _nexus_dict.keys(): - if keyword == const.USERNAME: - try: - cdb.add_credential(TENANT, ipaddr, - _nexus_dict[ipaddr, const.USERNAME], - _nexus_dict[ipaddr, const.PASSWORD]) - except cexc.CredentialAlreadyExists: - # We are quietly ignoring this, since it only happens - # if this class module is loaded more than once, in which - # case, the credentials are already populated - pass - - @staticmethod - def put_credential(cred_name, username, password): - """Set the username and password.""" - cdb.add_credential(TENANT, cred_name, username, password) - - @staticmethod - def get_username(cred_name): - """Get the username.""" - credential = cdb.get_credential_name(TENANT, cred_name) - return credential[const.CREDENTIAL_USERNAME] - - @staticmethod - def get_password(cred_name): - """Get the password.""" - credential = cdb.get_credential_name(TENANT, cred_name) - return credential[const.CREDENTIAL_PASSWORD] - - @staticmethod - def get_credential(cred_name): - """Get the username and password.""" - credential = cdb.get_credential_name(TENANT, cred_name) - return {const.USERNAME: credential[const.CREDENTIAL_USERNAME], - const.PASSWORD: credential[const.CREDENTIAL_PASSWORD]} - - @staticmethod - def delete_credential(cred_name): - """Delete a credential.""" - cdb.remove_credential(TENANT, cred_name) diff --git a/neutron/plugins/ml2/drivers/cisco/nexus/mech_cisco_nexus.py b/neutron/plugins/ml2/drivers/cisco/nexus/mech_cisco_nexus.py index 3514017cce..8db7528297 100644 --- a/neutron/plugins/ml2/drivers/cisco/nexus/mech_cisco_nexus.py +++ b/neutron/plugins/ml2/drivers/cisco/nexus/mech_cisco_nexus.py @@ -25,7 +25,6 @@ from neutron.openstack.common import log as logging from neutron.plugins.common import constants as p_const from neutron.plugins.ml2 import driver_api as api from neutron.plugins.ml2.drivers.cisco.nexus import config as conf -from neutron.plugins.ml2.drivers.cisco.nexus import credentials_v2 as cred from neutron.plugins.ml2.drivers.cisco.nexus import exceptions as excep from neutron.plugins.ml2.drivers.cisco.nexus import nexus_db_v2 as nxos_db from neutron.plugins.ml2.drivers.cisco.nexus import nexus_network_driver @@ -45,12 +44,8 @@ class CiscoNexusMechanismDriver(api.MechanismDriver): self._nexus_switches = conf.ML2MechCiscoConfig.nexus_dict LOG.debug(_("nexus_switches found = %s"), self._nexus_switches) - self.credentials = {} self.driver = nexus_network_driver.CiscoNexusDriver() - # Initialize credential store after database initialization. - cred.Store.initialize() - def _valid_network_segment(self, segment): return (cfg.CONF.ml2_cisco.managed_physical_network is None or cfg.CONF.ml2_cisco.managed_physical_network == diff --git a/neutron/plugins/ml2/drivers/cisco/nexus/network_db_v2.py b/neutron/plugins/ml2/drivers/cisco/nexus/network_db_v2.py deleted file mode 100644 index 0020ebd3e1..0000000000 --- a/neutron/plugins/ml2/drivers/cisco/nexus/network_db_v2.py +++ /dev/null @@ -1,116 +0,0 @@ -# Copyright (c) 2013 OpenStack Foundation -# All Rights Reserved. -# -# Licensed under the Apache License, Version 2.0 (the "License"); you may -# not use this file except in compliance with the License. You may obtain -# a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT -# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the -# License for the specific language governing permissions and limitations -# under the License. -# - -from sqlalchemy.orm import exc - -from neutron.db import api as db -from neutron.openstack.common import log as logging -from neutron.openstack.common import uuidutils -from neutron.plugins.ml2.drivers.cisco.nexus import constants as const -from neutron.plugins.ml2.drivers.cisco.nexus import exceptions as c_exc -from neutron.plugins.ml2.drivers.cisco.nexus import network_models_v2 -from neutron.plugins.ml2.drivers.cisco.nexus import nexus_models_v2 # noqa - - -LOG = logging.getLogger(__name__) - - -def get_all_credentials(tenant_id): - """Lists all the creds for a tenant.""" - session = db.get_session() - return (session.query(network_models_v2.Credential). - filter_by(tenant_id=tenant_id).all()) - - -def get_credential(tenant_id, credential_id): - """Lists the creds for given a cred_id and tenant_id.""" - session = db.get_session() - try: - cred = (session.query(network_models_v2.Credential). - filter_by(tenant_id=tenant_id). - filter_by(credential_id=credential_id).one()) - return cred - except exc.NoResultFound: - raise c_exc.CredentialNotFound(credential_id=credential_id, - tenant_id=tenant_id) - - -def get_credential_name(tenant_id, credential_name): - """Lists the creds for given a cred_name and tenant_id.""" - session = db.get_session() - try: - cred = (session.query(network_models_v2.Credential). - filter_by(tenant_id=tenant_id). - filter_by(credential_name=credential_name).one()) - return cred - except exc.NoResultFound: - raise c_exc.CredentialNameNotFound(credential_name=credential_name, - tenant_id=tenant_id) - - -def add_credential(tenant_id, credential_name, user_name, password): - """Adds a qos to tenant association.""" - session = db.get_session() - try: - cred = (session.query(network_models_v2.Credential). - filter_by(tenant_id=tenant_id). - filter_by(credential_name=credential_name).one()) - raise c_exc.CredentialAlreadyExists(credential_name=credential_name, - tenant_id=tenant_id) - except exc.NoResultFound: - cred = network_models_v2.Credential( - credential_id=uuidutils.generate_uuid(), - tenant_id=tenant_id, - credential_name=credential_name, - user_name=user_name, - password=password) - session.add(cred) - session.flush() - return cred - - -def remove_credential(tenant_id, credential_id): - """Removes a credential from a tenant.""" - session = db.get_session() - try: - cred = (session.query(network_models_v2.Credential). - filter_by(tenant_id=tenant_id). - filter_by(credential_id=credential_id).one()) - session.delete(cred) - session.flush() - return cred - except exc.NoResultFound: - pass - - -def update_credential(tenant_id, credential_id, - new_user_name=None, new_password=None): - """Updates a credential for a tenant.""" - session = db.get_session() - try: - cred = (session.query(network_models_v2.Credential). - filter_by(tenant_id=tenant_id). - filter_by(credential_id=credential_id).one()) - if new_user_name: - cred[const.CREDENTIAL_USERNAME] = new_user_name - if new_password: - cred[const.CREDENTIAL_PASSWORD] = new_password - session.merge(cred) - session.flush() - return cred - except exc.NoResultFound: - raise c_exc.CredentialNotFound(credential_id=credential_id, - tenant_id=tenant_id) diff --git a/neutron/plugins/ml2/drivers/cisco/nexus/network_models_v2.py b/neutron/plugins/ml2/drivers/cisco/nexus/network_models_v2.py deleted file mode 100644 index 8725edb7b4..0000000000 --- a/neutron/plugins/ml2/drivers/cisco/nexus/network_models_v2.py +++ /dev/null @@ -1,31 +0,0 @@ -# Copyright (c) 2013 OpenStack Foundation -# All Rights Reserved. -# -# Licensed under the Apache License, Version 2.0 (the "License"); you may -# not use this file except in compliance with the License. You may obtain -# a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT -# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the -# License for the specific language governing permissions and limitations -# under the License. -# - -import sqlalchemy as sa - -from neutron.db import model_base - - -class Credential(model_base.BASEV2): - """Represents credentials for a tenant to control Cisco switches.""" - - __tablename__ = 'cisco_ml2_credentials' - - credential_id = sa.Column(sa.String(255)) - tenant_id = sa.Column(sa.String(255), primary_key=True) - credential_name = sa.Column(sa.String(255), primary_key=True) - user_name = sa.Column(sa.String(255)) - password = sa.Column(sa.String(255)) diff --git a/neutron/plugins/ml2/drivers/cisco/nexus/nexus_network_driver.py b/neutron/plugins/ml2/drivers/cisco/nexus/nexus_network_driver.py index 8670c55348..d7921f4bd2 100644 --- a/neutron/plugins/ml2/drivers/cisco/nexus/nexus_network_driver.py +++ b/neutron/plugins/ml2/drivers/cisco/nexus/nexus_network_driver.py @@ -22,7 +22,6 @@ from neutron.openstack.common import importutils from neutron.openstack.common import log as logging from neutron.plugins.ml2.drivers.cisco.nexus import config as conf from neutron.plugins.ml2.drivers.cisco.nexus import constants as const -from neutron.plugins.ml2.drivers.cisco.nexus import credentials_v2 as cred from neutron.plugins.ml2.drivers.cisco.nexus import exceptions as cexc from neutron.plugins.ml2.drivers.cisco.nexus import nexus_db_v2 from neutron.plugins.ml2.drivers.cisco.nexus import nexus_snippets as snipp @@ -35,7 +34,6 @@ class CiscoNexusDriver(object): def __init__(self): self.ncclient = None self.nexus_switches = conf.ML2MechCiscoConfig.nexus_dict - self.credentials = {} self.connections = {} def _import_ncclient(self): @@ -77,20 +75,6 @@ class CiscoNexusDriver(object): # the original ncclient exception. raise cexc.NexusConfigFailed(config=config, exc=e) - def get_credential(self, nexus_ip): - """Return credential information for a given Nexus IP address. - - If credential doesn't exist then also add to local dictionary. - """ - if nexus_ip not in self.credentials: - nexus_username = cred.Store.get_username(nexus_ip) - nexus_password = cred.Store.get_password(nexus_ip) - self.credentials[nexus_ip] = { - const.USERNAME: nexus_username, - const.PASSWORD: nexus_password - } - return self.credentials[nexus_ip] - def nxos_connect(self, nexus_host): """Make SSH connection to the Nexus Switch.""" if getattr(self.connections.get(nexus_host), 'connected', None): @@ -99,9 +83,8 @@ class CiscoNexusDriver(object): if not self.ncclient: self.ncclient = self._import_ncclient() nexus_ssh_port = int(self.nexus_switches[nexus_host, 'ssh_port']) - nexus_creds = self.get_credential(nexus_host) - nexus_user = nexus_creds[const.USERNAME] - nexus_password = nexus_creds[const.PASSWORD] + nexus_user = self.nexus_switches[nexus_host, const.USERNAME] + nexus_password = self.nexus_switches[nexus_host, const.PASSWORD] try: man = self.ncclient.connect(host=nexus_host, port=nexus_ssh_port, diff --git a/neutron/tests/unit/ml2/drivers/cisco/nexus/test_cisco_network_db.py b/neutron/tests/unit/ml2/drivers/cisco/nexus/test_cisco_network_db.py deleted file mode 100644 index 9b52902b88..0000000000 --- a/neutron/tests/unit/ml2/drivers/cisco/nexus/test_cisco_network_db.py +++ /dev/null @@ -1,167 +0,0 @@ -# Copyright (c) 2013 OpenStack Foundation -# All Rights Reserved. -# -# Licensed under the Apache License, Version 2.0 (the "License"); you may -# not use this file except in compliance with the License. You may obtain -# a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT -# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the -# License for the specific language governing permissions and limitations -# under the License. - -import collections -import testtools - -from neutron.db import api as db -from neutron.plugins.ml2.drivers.cisco.nexus import exceptions -from neutron.plugins.ml2.drivers.cisco.nexus import network_db_v2 -from neutron.tests import base - - -class CiscoNetworkCredentialDbTest(base.BaseTestCase): - - """Unit tests for Cisco ML2 mechanism driver credentials database.""" - - CredObj = collections.namedtuple('CredObj', - 'tenant_id cred_name user_name pwd') - - def setUp(self): - super(CiscoNetworkCredentialDbTest, self).setUp() - db.configure_db() - self.addCleanup(db.clear_db) - - def _cred_test_obj(self, tenant_num, cred_num): - """Create a Credential test object from a pair of numbers.""" - tenant_id = 'tenant_%s' % tenant_num - cred_name = 'credential_%s_%s' % (tenant_num, cred_num) - user_name = 'user_%s_%s' % (tenant_num, cred_num) - pwd = 'password_%s_%s' % (tenant_num, cred_num) - return self.CredObj(tenant_id, cred_name, user_name, pwd) - - def _assert_cred_equal(self, db_cred, test_cred): - """Assert that a database credential matches a credential test obj.""" - self.assertEqual(db_cred.tenant_id, test_cred.tenant_id) - self.assertEqual(db_cred.credential_name, test_cred.cred_name) - self.assertEqual(db_cred.user_name, test_cred.user_name) - self.assertEqual(db_cred.password, test_cred.pwd) - - def _get_credential(self, db_cred): - """Lists credentials that match a credential's tenant and cred IDs.""" - return network_db_v2.get_credential(db_cred.tenant_id, - db_cred.credential_id) - - def _get_credential_name(self, db_cred): - """Lists credentials that match a cred's tenant ID and cred name.""" - return network_db_v2.get_credential_name(db_cred.tenant_id, - db_cred.credential_name) - - def _add_credential(self, test_cred): - """Adds a credential to the database.""" - return network_db_v2.add_credential(test_cred.tenant_id, - test_cred.cred_name, - test_cred.user_name, - test_cred.pwd) - - def _remove_credential(self, db_cred): - """Removes a credential from the database.""" - return network_db_v2.remove_credential(db_cred.tenant_id, - db_cred.credential_id) - - def _update_credential(self, db_cred, new_user_name=None, - new_password=None): - """Updates a credential with a new user name and password.""" - return network_db_v2.update_credential(db_cred.tenant_id, - db_cred.credential_id, - new_user_name, - new_password) - - def test_credential_add_remove(self): - """Tests add and removal of credential to/from the database.""" - cred11 = self._cred_test_obj(1, 1) - cred = self._add_credential(cred11) - self._assert_cred_equal(cred, cred11) - cred = self._remove_credential(cred) - self._assert_cred_equal(cred, cred11) - cred = self._remove_credential(cred) - self.assertIsNone(cred) - - def test_credential_add_dup(self): - """Tests addition of a duplicate credential to the database.""" - cred22 = self._cred_test_obj(2, 2) - cred = self._add_credential(cred22) - self._assert_cred_equal(cred, cred22) - with testtools.ExpectedException(exceptions.CredentialAlreadyExists): - self._add_credential(cred22) - cred = self._remove_credential(cred) - self._assert_cred_equal(cred, cred22) - cred = self._remove_credential(cred) - self.assertIsNone(cred) - - def test_credential_get(self): - """Tests get of credentials by tenant ID and credential ID.""" - cred11 = self._cred_test_obj(1, 1) - cred11_db = self._add_credential(cred11) - cred21 = self._cred_test_obj(2, 1) - cred21_db = self._add_credential(cred21) - cred22 = self._cred_test_obj(2, 2) - cred22_db = self._add_credential(cred22) - - cred = self._get_credential(cred11_db) - self._assert_cred_equal(cred, cred11) - cred = self._get_credential(cred21_db) - self._assert_cred_equal(cred, cred21) - cred = self._get_credential(cred22_db) - self._assert_cred_equal(cred, cred22) - - with testtools.ExpectedException(exceptions.CredentialNotFound): - network_db_v2.get_credential("dummyTenantId", "dummyCredentialId") - - cred_all_t1 = network_db_v2.get_all_credentials(cred11.tenant_id) - self.assertEqual(len(cred_all_t1), 1) - cred_all_t2 = network_db_v2.get_all_credentials(cred21.tenant_id) - self.assertEqual(len(cred_all_t2), 2) - - def test_credential_get_name(self): - """Tests get of credential by tenant ID and credential name.""" - cred11 = self._cred_test_obj(1, 1) - cred11_db = self._add_credential(cred11) - cred21 = self._cred_test_obj(2, 1) - cred21_db = self._add_credential(cred21) - cred22 = self._cred_test_obj(2, 2) - cred22_db = self._add_credential(cred22) - self.assertNotEqual(cred11_db.credential_id, cred21_db.credential_id) - self.assertNotEqual(cred11_db.credential_id, cred22_db.credential_id) - self.assertNotEqual(cred21_db.credential_id, cred22_db.credential_id) - - cred = self._get_credential_name(cred11_db) - self._assert_cred_equal(cred, cred11) - cred = self._get_credential_name(cred21_db) - self._assert_cred_equal(cred, cred21) - cred = self._get_credential_name(cred22_db) - self._assert_cred_equal(cred, cred22) - - with testtools.ExpectedException(exceptions.CredentialNameNotFound): - network_db_v2.get_credential_name("dummyTenantId", - "dummyCredentialName") - - def test_credential_update(self): - """Tests update of a credential with a new user name and password.""" - cred11 = self._cred_test_obj(1, 1) - cred11_db = self._add_credential(cred11) - self._update_credential(cred11_db) - new_user_name = "new user name" - new_pwd = "new password" - new_credential = self._update_credential( - cred11_db, new_user_name, new_pwd) - expected_cred = self.CredObj( - cred11.tenant_id, cred11.cred_name, new_user_name, new_pwd) - self._assert_cred_equal(new_credential, expected_cred) - new_credential = self._get_credential(cred11_db) - self._assert_cred_equal(new_credential, expected_cred) - with testtools.ExpectedException(exceptions.CredentialNotFound): - network_db_v2.update_credential( - "dummyTenantId", "dummyCredentialId", new_user_name, new_pwd) diff --git a/neutron/tests/unit/ml2/drivers/cisco/nexus/test_cisco_nexus.py b/neutron/tests/unit/ml2/drivers/cisco/nexus/test_cisco_nexus.py index 390477e1d3..31573b82b0 100644 --- a/neutron/tests/unit/ml2/drivers/cisco/nexus/test_cisco_nexus.py +++ b/neutron/tests/unit/ml2/drivers/cisco/nexus/test_cisco_nexus.py @@ -121,17 +121,6 @@ class TestCiscoNexusDevice(base.BaseTestCase): VLAN_ID_PC), } - test_credentials = { - NEXUS_IP_ADDRESS: { - constants.USERNAME: 'admin', - constants.PASSWORD: 'pass1234' - }, - NEXUS_IP_ADDRESS_PC: { - constants.USERNAME: 'admin', - constants.PASSWORD: 'password' - }, - } - def setUp(self): """Sets up mock ncclient, and switch and credentials dictionaries.""" super(TestCiscoNexusDevice, self).setUp() @@ -154,12 +143,13 @@ class TestCiscoNexusDevice(base.BaseTestCase): host_name)] = nexus_port mech_instance._nexus_switches[(ip_addr, 'ssh_port')] = NEXUS_SSH_PORT + mech_instance._nexus_switches[(ip_addr, + constants.USERNAME)] = 'admin' + mech_instance._nexus_switches[(ip_addr, + constants.PASSWORD)] = 'password' mech_instance.driver.nexus_switches = ( mech_instance._nexus_switches) - mech_instance.driver.credentials = ( - TestCiscoNexusDevice.test_credentials) - db.configure_db() mock.patch.object(mech_cisco_nexus.CiscoNexusMechanismDriver,