Merge "Fix string formatting issues"

This commit is contained in:
Jenkins 2015-09-28 16:15:24 +00:00 committed by Gerrit Code Review
commit efb8b2abb6
3 changed files with 37 additions and 2 deletions

View File

@ -320,7 +320,7 @@ class NeutronDHCPApi(base.BaseDHCP):
if not port.get('port') or not port['port'].get('id'): if not port.get('port') or not port['port'].get('id'):
self._rollback_cleaning_ports(task) self._rollback_cleaning_ports(task)
msg = (_('Failed to create cleaning ports for node ' msg = (_('Failed to create cleaning ports for node '
'%(node)s') % task.node.uuid) '%(node)s') % {'node': task.node.uuid})
LOG.error(msg) LOG.error(msg)
raise exception.NodeCleaningFailure(msg) raise exception.NodeCleaningFailure(msg)
# Match return value of get_node_vif_ids() # Match return value of get_node_vif_ids()

View File

@ -510,7 +510,7 @@ class BaseAgentVendor(base.VendorInterface):
ports = self._find_ports_by_macs(context, mac_addresses) ports = self._find_ports_by_macs(context, mac_addresses)
if not ports: if not ports:
raise exception.NodeNotFound(_( raise exception.NodeNotFound(_(
'No ports matching the given MAC addresses %sexist in the ' 'No ports matching the given MAC addresses %s exist in the '
'database.') % mac_addresses) 'database.') % mac_addresses)
node_id = self._get_node_id(ports) node_id = self._get_node_id(ports)
try: try:

View File

@ -393,6 +393,41 @@ class TestNeutron(db_base.DbTestCase):
'admin_state_up': True, 'mac_address': self.ports[0].address}}) 'admin_state_up': True, 'mac_address': self.ports[0].address}})
rollback_mock.assert_called_once_with(task) rollback_mock.assert_called_once_with(task)
@mock.patch.object(neutron.NeutronDHCPApi, '_rollback_cleaning_ports')
@mock.patch.object(client.Client, 'create_port')
def test_create_cleaning_ports_fail_delayed(self, create_mock,
rollback_mock):
"""Check ports are cleaned up on failure to create them
This test checks that the port clean-up occurs
when the port create call was successful,
but the port in fact was not created.
"""
# NOTE(pas-ha) this is trying to emulate the complex port object
# with both methods and dictionary access with methods on elements
mockport = mock.MagicMock()
create_mock.return_value = mockport
# fail only on second 'or' branch to fool lazy eval
# and actually execute both expressions to assert on both mocks
mockport.get.return_value = True
mockitem = mock.Mock()
mockport.__getitem__.return_value = mockitem
mockitem.get.return_value = None
api = dhcp_factory.DHCPFactory().provider
with task_manager.acquire(self.context, self.node.uuid) as task:
self.assertRaises(exception.NodeCleaningFailure,
api.create_cleaning_ports,
task)
create_mock.assert_called_once_with({'port': {
'network_id': '00000000-0000-0000-0000-000000000000',
'admin_state_up': True, 'mac_address': self.ports[0].address}})
rollback_mock.assert_called_once_with(task)
mockport.get.assert_called_once_with('port')
mockitem.get.assert_called_once_with('id')
mockport.__getitem__.assert_called_once_with('port')
@mock.patch.object(client.Client, 'create_port') @mock.patch.object(client.Client, 'create_port')
def test_create_cleaning_ports_bad_config(self, create_mock): def test_create_cleaning_ports_bad_config(self, create_mock):
# Check an error is raised if the cleaning network is not set # Check an error is raised if the cleaning network is not set