Source code for ironic.tests.unit.drivers.modules.network.test_common

#    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 mock
from oslo_config import cfg
from oslo_utils import uuidutils

from ironic.common import exception
from ironic.common import neutron as neutron_common
from ironic.common import utils as common_utils
from ironic.conductor import task_manager
from ironic.drivers.modules.network import common
from ironic.tests.unit.conductor import mgr_utils
from ironic.tests.unit.db import base as db_base
from ironic.tests.unit.objects import utils as obj_utils

CONF = cfg.CONF


[docs]class TestCommonFunctions(db_base.DbTestCase):
[docs] def setUp(self): super(TestCommonFunctions, self).setUp() self.config(enabled_drivers=['fake']) mgr_utils.mock_the_extension_manager() self.node = obj_utils.create_test_node(self.context, network_interface='neutron') self.port = obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:32') self.vif_id = "fake_vif_id"
def _objects_setup(self): pg1 = obj_utils.create_test_portgroup( self.context, node_id=self.node.id) pg1_ports = [] # This portgroup contains 2 ports, both of them without VIF for i in range(2): pg1_ports.append(obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:0%d' % i, uuid=uuidutils.generate_uuid(), portgroup_id=pg1.id)) pg2 = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, address='00:54:00:cf:2d:04', name='foo2', uuid=uuidutils.generate_uuid()) pg2_ports = [] # This portgroup contains 3 ports, one of them with 'some-vif' # attached, so the two free ones should be considered standalone for i in range(2, 4): pg2_ports.append(obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:0%d' % i, uuid=uuidutils.generate_uuid(), portgroup_id=pg2.id)) pg2_ports.append(obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:04', extra={'vif_port_id': 'some-vif'}, uuid=uuidutils.generate_uuid(), portgroup_id=pg2.id)) # This portgroup has 'some-vif-2' attached to it and contains one port, # so neither portgroup nor port can be considered free pg3 = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, address='00:54:00:cf:2d:05', name='foo3', uuid=uuidutils.generate_uuid(), internal_info={common.TENANT_VIF_KEY: 'some-vif-2'}) pg3_ports = [obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:05', uuid=uuidutils.generate_uuid(), portgroup_id=pg3.id)] return pg1, pg1_ports, pg2, pg2_ports, pg3, pg3_ports
[docs] def test__get_free_portgroups_and_ports(self): self.node.network_interface = 'flat' self.node.save() pg1, pg1_ports, pg2, pg2_ports, pg3, pg3_ports = self._objects_setup() with task_manager.acquire(self.context, self.node.id) as task: free_portgroups, free_ports = ( common._get_free_portgroups_and_ports(task, self.vif_id)) self.assertItemsEqual( [self.port.uuid] + [p.uuid for p in pg2_ports[:2]], [p.uuid for p in free_ports]) self.assertItemsEqual([pg1.uuid], [p.uuid for p in free_portgroups])
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True)
[docs] def test__get_free_portgroups_and_ports_neutron_missed(self, vpi_mock): vpi_mock.return_value = False with task_manager.acquire(self.context, self.node.id) as task: free_portgroups, free_ports = ( common._get_free_portgroups_and_ports(task, self.vif_id)) self.assertItemsEqual([], free_ports)
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True)
[docs] def test__get_free_portgroups_and_ports_neutron(self, vpi_mock): vpi_mock.return_value = True with task_manager.acquire(self.context, self.node.id) as task: free_portgroups, free_ports = ( common._get_free_portgroups_and_ports(task, self.vif_id)) self.assertItemsEqual( [self.port.uuid], [p.uuid for p in free_ports])
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True)
[docs] def test__get_free_portgroups_and_ports_flat(self, vpi_mock): self.node.network_interface = 'flat' self.node.save() vpi_mock.return_value = True with task_manager.acquire(self.context, self.node.id) as task: free_portgroups, free_ports = ( common._get_free_portgroups_and_ports(task, self.vif_id))
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True, return_value=True)
[docs] def test_get_free_port_like_object_ports(self, vpi_mock): with task_manager.acquire(self.context, self.node.id) as task: res = common.get_free_port_like_object(task, self.vif_id) self.assertEqual(self.port.uuid, res.uuid)
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True, return_value=True)
[docs] def test_get_free_port_like_object_ports_pxe_enabled_first(self, vpi_mock): self.port.pxe_enabled = False self.port.save() other_port = obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:33', uuid=uuidutils.generate_uuid()) with task_manager.acquire(self.context, self.node.id) as task: res = common.get_free_port_like_object(task, self.vif_id) self.assertEqual(other_port.uuid, res.uuid)
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True, return_value=True)
[docs] def test_get_free_port_like_object_portgroup_first(self, vpi_mock): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id) obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:01', uuid=uuidutils.generate_uuid(), portgroup_id=pg.id) with task_manager.acquire(self.context, self.node.id) as task: res = common.get_free_port_like_object(task, self.vif_id) self.assertEqual(pg.uuid, res.uuid)
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True, return_value=True)
[docs] def test_get_free_port_like_object_ignores_empty_portgroup(self, vpi_mock): obj_utils.create_test_portgroup(self.context, node_id=self.node.id) with task_manager.acquire(self.context, self.node.id) as task: res = common.get_free_port_like_object(task, self.vif_id) self.assertEqual(self.port.uuid, res.uuid)
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True, return_value=True)
[docs] def test_get_free_port_like_object_ignores_standalone_portgroup( self, vpi_mock): self.port.destroy() pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id) obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:01', uuid=uuidutils.generate_uuid(), portgroup_id=pg.id, extra={'vif_port_id': 'some-vif'}) free_port = obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:02', uuid=uuidutils.generate_uuid(), portgroup_id=pg.id) with task_manager.acquire(self.context, self.node.id) as task: res = common.get_free_port_like_object(task, self.vif_id) self.assertEqual(free_port.uuid, res.uuid)
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True, return_value=True)
[docs] def test_get_free_port_like_object_vif_attached_to_portgroup( self, vpi_mock): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, internal_info={common.TENANT_VIF_KEY: self.vif_id}) obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:01', uuid=uuidutils.generate_uuid(), portgroup_id=pg.id) with task_manager.acquire(self.context, self.node.id) as task: self.assertRaisesRegex( exception.VifAlreadyAttached, r"already attached to Ironic Portgroup", common.get_free_port_like_object, task, self.vif_id)
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True, return_value=True)
[docs] def test_get_free_port_like_object_vif_attached_to_portgroup_extra( self, vpi_mock): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, extra={'vif_port_id': self.vif_id}) obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:01', uuid=uuidutils.generate_uuid(), portgroup_id=pg.id) with task_manager.acquire(self.context, self.node.id) as task: self.assertRaisesRegex( exception.VifAlreadyAttached, r"already attached to Ironic Portgroup", common.get_free_port_like_object, task, self.vif_id)
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True, return_value=True)
[docs] def test_get_free_port_like_object_vif_attached_to_port(self, vpi_mock): self.port.internal_info = {common.TENANT_VIF_KEY: self.vif_id} self.port.save() with task_manager.acquire(self.context, self.node.id) as task: self.assertRaisesRegex( exception.VifAlreadyAttached, r"already attached to Ironic Port\b", common.get_free_port_like_object, task, self.vif_id)
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True, return_value=True)
[docs] def test_get_free_port_like_object_vif_attached_to_port_extra( self, vpi_mock): self.port.extra = {'vif_port_id': self.vif_id} self.port.save() with task_manager.acquire(self.context, self.node.id) as task: self.assertRaisesRegex( exception.VifAlreadyAttached, r"already attached to Ironic Port\b", common.get_free_port_like_object, task, self.vif_id)
@mock.patch.object(neutron_common, 'validate_port_info', autospec=True, return_value=True)
[docs] def test_get_free_port_like_object_nothing_free(self, vpi_mock): self.port.extra = {'vif_port_id': 'another-vif'} self.port.save() with task_manager.acquire(self.context, self.node.id) as task: self.assertRaises(exception.NoFreePhysicalPorts, common.get_free_port_like_object, task, self.vif_id)
[docs]class TestVifPortIDMixin(db_base.DbTestCase):
[docs] def setUp(self): super(TestVifPortIDMixin, self).setUp() self.config(enabled_drivers=['fake']) mgr_utils.mock_the_extension_manager() self.interface = common.VIFPortIDMixin() self.node = obj_utils.create_test_node(self.context, network_interface='neutron') self.port = obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:32', extra={'vif_port_id': uuidutils.generate_uuid(), 'client-id': 'fake1'}) self.neutron_port = {'id': '132f871f-eaec-4fed-9475-0d54465e0f00', 'mac_address': '52:54:00:cf:2d:32'}
[docs] def test_vif_list_extra(self): vif_id = uuidutils.generate_uuid() self.port.extra = {'vif_port_id': vif_id} self.port.save() pg_vif_id = uuidutils.generate_uuid() portgroup = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, address='52:54:00:00:00:00', internal_info={common.TENANT_VIF_KEY: pg_vif_id}) obj_utils.create_test_port( self.context, node_id=self.node.id, portgroup_id=portgroup.id, address='52:54:00:cf:2d:01', uuid=uuidutils.generate_uuid()) with task_manager.acquire(self.context, self.node.id) as task: vifs = self.interface.vif_list(task) self.assertItemsEqual([{'id': pg_vif_id}, {'id': vif_id}], vifs)
[docs] def test_vif_list_internal(self): vif_id = uuidutils.generate_uuid() self.port.internal_info = {common.TENANT_VIF_KEY: vif_id} self.port.save() pg_vif_id = uuidutils.generate_uuid() portgroup = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, address='52:54:00:00:00:00', internal_info={common.TENANT_VIF_KEY: pg_vif_id}) obj_utils.create_test_port( self.context, node_id=self.node.id, portgroup_id=portgroup.id, address='52:54:00:cf:2d:01', uuid=uuidutils.generate_uuid()) with task_manager.acquire(self.context, self.node.id) as task: vifs = self.interface.vif_list(task) self.assertItemsEqual([{'id': pg_vif_id}, {'id': vif_id}], vifs)
[docs] def test_vif_list_extra_and_internal_priority(self): vif_id = uuidutils.generate_uuid() vif_id2 = uuidutils.generate_uuid() self.port.extra = {'vif_port_id': vif_id2} self.port.internal_info = {common.TENANT_VIF_KEY: vif_id} self.port.save() with task_manager.acquire(self.context, self.node.id) as task: vifs = self.interface.vif_list(task) self.assertEqual([{'id': vif_id}], vifs)
@mock.patch.object(common, 'get_free_port_like_object', autospec=True) @mock.patch.object(neutron_common, 'get_client', autospec=True) @mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_vif_attach(self, mock_upa, mock_client, moc_gfp): self.port.extra = {} self.port.save() vif = {'id': "fake_vif_id"} moc_gfp.return_value = self.port with task_manager.acquire(self.context, self.node.id) as task: self.interface.vif_attach(task, vif) self.port.refresh() self.assertEqual("fake_vif_id", self.port.internal_info.get( common.TENANT_VIF_KEY)) mock_client.assert_called_once_with() mock_upa.assert_called_once_with("fake_vif_id", self.port.address)
@mock.patch.object(common, 'get_free_port_like_object', autospec=True) @mock.patch.object(neutron_common, 'get_client') @mock.patch.object(neutron_common, 'update_port_address')
[docs] def test_vif_attach_portgroup_no_address(self, mock_upa, mock_client, mock_gfp): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, address=None) mock_gfp.return_value = pg obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:01', uuid=uuidutils.generate_uuid(), portgroup_id=pg.id) vif = {'id': "fake_vif_id"} with task_manager.acquire(self.context, self.node.id) as task: self.interface.vif_attach(task, vif) pg.refresh() self.assertEqual(vif['id'], pg.internal_info[common.TENANT_VIF_KEY]) self.assertFalse(mock_upa.called) self.assertFalse(mock_client.called)
@mock.patch.object(neutron_common, 'get_client') @mock.patch.object(neutron_common, 'update_port_address')
[docs] def test_vif_attach_update_port_exception(self, mock_upa, mock_client): self.port.extra = {} self.port.save() vif = {'id': "fake_vif_id"} mock_upa.side_effect = ( exception.FailedToUpdateMacOnPort(port_id='fake')) with task_manager.acquire(self.context, self.node.id) as task: self.assertRaisesRegexp( exception.NetworkError, "can not update Neutron port", self.interface.vif_attach, task, vif) mock_client.assert_called_once_with()
[docs] def test_vif_detach_in_extra(self): with task_manager.acquire(self.context, self.node.id) as task: self.interface.vif_detach( task, self.port.extra['vif_port_id']) self.port.refresh() self.assertFalse('vif_port_id' in self.port.extra) self.assertFalse(common.TENANT_VIF_KEY in self.port.internal_info)
[docs] def test_vif_detach_in_internal_info(self): self.port.internal_info = { common.TENANT_VIF_KEY: self.port.extra['vif_port_id']} self.port.extra = {} self.port.save() with task_manager.acquire(self.context, self.node.id) as task: self.interface.vif_detach( task, self.port.internal_info[common.TENANT_VIF_KEY]) self.port.refresh() self.assertFalse('vif_port_id' in self.port.extra) self.assertFalse(common.TENANT_VIF_KEY in self.port.internal_info)
[docs] def test_vif_detach_in_extra_portgroup(self): vif_id = uuidutils.generate_uuid() pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, extra={'vif_port_id': vif_id}) obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:01', portgroup_id=pg.id, uuid=uuidutils.generate_uuid() ) with task_manager.acquire(self.context, self.node.id) as task: self.interface.vif_detach(task, vif_id) pg.refresh() self.assertFalse('vif_port_id' in pg.extra) self.assertFalse(common.TENANT_VIF_KEY in pg.internal_info)
[docs] def test_vif_detach_in_extra_portgroup_manually_attached_to_port(self): vif_id = uuidutils.generate_uuid() pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id) port = obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:01', portgroup_id=pg.id, uuid=uuidutils.generate_uuid(), extra={'vif_port_id': vif_id} ) with task_manager.acquire(self.context, self.node.id) as task: self.interface.vif_detach(task, vif_id) port.refresh() pg.refresh() self.assertFalse('vif_port_id' in port.extra) self.assertFalse(common.TENANT_VIF_KEY in pg.internal_info)
[docs] def test_vif_detach_in_internal_info_portgroup(self): vif_id = uuidutils.generate_uuid() pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, internal_info={common.TENANT_VIF_KEY: vif_id}) obj_utils.create_test_port( self.context, node_id=self.node.id, address='52:54:00:cf:2d:01', portgroup_id=pg.id, uuid=uuidutils.generate_uuid() ) with task_manager.acquire(self.context, self.node.id) as task: self.interface.vif_detach(task, vif_id) pg.refresh() self.assertFalse('vif_port_id' in pg.extra) self.assertFalse(common.TENANT_VIF_KEY in pg.internal_info)
[docs] def test_vif_detach_not_attached(self): with task_manager.acquire(self.context, self.node.id) as task: self.assertRaisesRegexp( exception.VifNotAttached, "it is not attached to it.", self.interface.vif_detach, task, 'aaa')
[docs] def test_get_current_vif_extra_vif_port_id(self): extra = {'vif_port_id': 'foo'} self.port.extra = extra self.port.save() with task_manager.acquire(self.context, self.node.id) as task: vif = self.interface.get_current_vif(task, self.port) self.assertEqual('foo', vif)
[docs] def test_get_current_vif_internal_info_cleaning(self): internal_info = {'cleaning_vif_port_id': 'foo', 'tenant_vif_port_id': 'bar'} self.port.internal_info = internal_info self.port.save() with task_manager.acquire(self.context, self.node.id) as task: vif = self.interface.get_current_vif(task, self.port) self.assertEqual('foo', vif)
[docs] def test_get_current_vif_internal_info_provisioning(self): internal_info = {'provisioning_vif_port_id': 'foo', 'vif_port_id': 'bar'} self.port.internal_info = internal_info self.port.save() with task_manager.acquire(self.context, self.node.id) as task: vif = self.interface.get_current_vif(task, self.port) self.assertEqual('foo', vif)
[docs] def test_get_current_vif_internal_info_tenant_vif(self): internal_info = {'tenant_vif_port_id': 'bar'} self.port.internal_info = internal_info self.port.save() with task_manager.acquire(self.context, self.node.id) as task: vif = self.interface.get_current_vif(task, self.port) self.assertEqual('bar', vif)
[docs] def test_get_current_vif_none(self): internal_info = extra = {} self.port.internal_info = internal_info self.port.extra = extra self.port.save() with task_manager.acquire(self.context, self.node.id) as task: vif = self.interface.get_current_vif(task, self.port) self.assertIsNone(vif)
@mock.patch.object(common_utils, 'warn_about_deprecated_extra_vif_port_id', autospec=True) @mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_port_changed_address(self, mac_update_mock, mock_warn): new_address = '11:22:33:44:55:bb' self.port.address = new_address with task_manager.acquire(self.context, self.node.id) as task: self.interface.port_changed(task, self.port) mac_update_mock.assert_called_once_with( self.port.extra['vif_port_id'], new_address) self.assertFalse(mock_warn.called)
@mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_port_changed_address_VIF_MAC_update_fail(self, mac_update_mock): new_address = '11:22:33:44:55:bb' self.port.address = new_address mac_update_mock.side_effect = ( exception.FailedToUpdateMacOnPort(port_id=self.port.uuid)) with task_manager.acquire(self.context, self.node.id) as task: self.assertRaises(exception.FailedToUpdateMacOnPort, self.interface.port_changed, task, self.port) mac_update_mock.assert_called_once_with( self.port.extra['vif_port_id'], new_address)
@mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_port_changed_address_no_vif_id(self, mac_update_mock): self.port.extra = {} self.port.save() self.port.address = '11:22:33:44:55:bb' with task_manager.acquire(self.context, self.node.id) as task: self.interface.port_changed(task, self.port) self.assertFalse(mac_update_mock.called)
@mock.patch('ironic.dhcp.neutron.NeutronDHCPApi.update_port_dhcp_opts')
[docs] def test_port_changed_client_id(self, dhcp_update_mock): expected_extra = {'vif_port_id': 'fake-id', 'client-id': 'fake2'} expected_dhcp_opts = [{'opt_name': 'client-id', 'opt_value': 'fake2'}] self.port.extra = expected_extra with task_manager.acquire(self.context, self.node.id) as task: self.interface.port_changed(task, self.port) dhcp_update_mock.assert_called_once_with( 'fake-id', expected_dhcp_opts)
@mock.patch.object(common_utils, 'warn_about_deprecated_extra_vif_port_id', autospec=True) @mock.patch('ironic.dhcp.neutron.NeutronDHCPApi.update_port_dhcp_opts')
[docs] def test_port_changed_vif(self, dhcp_update_mock, mock_warn): expected_extra = {'vif_port_id': 'new_ake-id', 'client-id': 'fake1'} self.port.extra = expected_extra with task_manager.acquire(self.context, self.node.id) as task: self.interface.port_changed(task, self.port) self.assertFalse(dhcp_update_mock.called) self.assertEqual(1, mock_warn.call_count)
@mock.patch.object(common_utils, 'warn_about_deprecated_extra_vif_port_id', autospec=True) @mock.patch('ironic.dhcp.neutron.NeutronDHCPApi.update_port_dhcp_opts')
[docs] def test_port_changed_extra_add_new_key(self, dhcp_update_mock, mock_warn): self.port.extra = {'vif_port_id': 'fake-id'} self.port.save() expected_extra = self.port.extra expected_extra['foo'] = 'bar' self.port.extra = expected_extra with task_manager.acquire(self.context, self.node.id) as task: self.interface.port_changed(task, self.port) self.assertFalse(dhcp_update_mock.called) self.assertEqual(0, mock_warn.call_count)
@mock.patch.object(common_utils, 'warn_about_deprecated_extra_vif_port_id', autospec=True) @mock.patch('ironic.dhcp.neutron.NeutronDHCPApi.update_port_dhcp_opts')
[docs] def test_port_changed_extra_no_deprecation_if_removing_vif( self, dhcp_update_mock, mock_warn): self.port.extra = {'vif_port_id': 'foo'} self.port.save() self.port.extra = {'foo': 'bar'} with task_manager.acquire(self.context, self.node.id) as task: self.interface.port_changed(task, self.port) self.assertFalse(dhcp_update_mock.called) self.assertEqual(0, mock_warn.call_count)
@mock.patch('ironic.dhcp.neutron.NeutronDHCPApi.update_port_dhcp_opts')
[docs] def test_port_changed_client_id_fail(self, dhcp_update_mock): self.port.extra = {'vif_port_id': 'fake-id', 'client-id': 'fake2'} dhcp_update_mock.side_effect = ( exception.FailedToUpdateDHCPOptOnPort(port_id=self.port.uuid)) with task_manager.acquire(self.context, self.node.id) as task: self.assertRaises(exception.FailedToUpdateDHCPOptOnPort, self.interface.port_changed, task, self.port)
@mock.patch('ironic.dhcp.neutron.NeutronDHCPApi.update_port_dhcp_opts')
[docs] def test_port_changed_client_id_no_vif_id(self, dhcp_update_mock): self.port.extra = {'client-id': 'fake1'} self.port.save() self.port.extra = {'client-id': 'fake2'} with task_manager.acquire(self.context, self.node.id) as task: self.interface.port_changed(task, self.port) self.assertFalse(dhcp_update_mock.called)
@mock.patch('ironic.dhcp.neutron.NeutronDHCPApi.update_port_dhcp_opts')
[docs] def test_port_changed_message_format_failure(self, dhcp_update_mock): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, standalone_ports_supported=False) port = obj_utils.create_test_port(self.context, node_id=self.node.id, uuid=uuidutils.generate_uuid(), address="aa:bb:cc:dd:ee:01", extra={'vif_port_id': 'blah'}, pxe_enabled=False) port.portgroup_id = pg.id with task_manager.acquire(self.context, self.node.id) as task: self.assertRaisesRegex(exception.Conflict, "VIF blah is attached to the port", self.interface.port_changed, task, port)
def _test_port_changed(self, has_vif=False, in_portgroup=False, pxe_enabled=True, standalone_ports=True, expect_errors=False): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, standalone_ports_supported=standalone_ports) extra_vif = {'vif_port_id': uuidutils.generate_uuid()} if has_vif: extra = extra_vif opposite_extra = {} else: extra = {} opposite_extra = extra_vif opposite_pxe_enabled = not pxe_enabled pg_id = None if in_portgroup: pg_id = pg.id ports = [] # Update only portgroup id on existed port with different # combinations of pxe_enabled/vif_port_id p1 = obj_utils.create_test_port(self.context, node_id=self.node.id, uuid=uuidutils.generate_uuid(), address="aa:bb:cc:dd:ee:01", extra=extra, pxe_enabled=pxe_enabled) p1.portgroup_id = pg_id ports.append(p1) # Update portgroup_id/pxe_enabled/vif_port_id in one request p2 = obj_utils.create_test_port(self.context, node_id=self.node.id, uuid=uuidutils.generate_uuid(), address="aa:bb:cc:dd:ee:02", extra=opposite_extra, pxe_enabled=opposite_pxe_enabled) p2.extra = extra p2.pxe_enabled = pxe_enabled p2.portgroup_id = pg_id ports.append(p2) # Update portgroup_id and pxe_enabled p3 = obj_utils.create_test_port(self.context, node_id=self.node.id, uuid=uuidutils.generate_uuid(), address="aa:bb:cc:dd:ee:03", extra=extra, pxe_enabled=opposite_pxe_enabled) p3.pxe_enabled = pxe_enabled p3.portgroup_id = pg_id ports.append(p3) # Update portgroup_id and vif_port_id p4 = obj_utils.create_test_port(self.context, node_id=self.node.id, uuid=uuidutils.generate_uuid(), address="aa:bb:cc:dd:ee:04", pxe_enabled=pxe_enabled, extra=opposite_extra) p4.extra = extra p4.portgroup_id = pg_id ports.append(p4) for port in ports: with task_manager.acquire(self.context, self.node.id) as task: if not expect_errors: self.interface.port_changed(task, port) else: self.assertRaises(exception.Conflict, self.interface.port_changed, task, port)
[docs] def test_port_changed_novif_pxe_noportgroup(self): self._test_port_changed(has_vif=False, in_portgroup=False, pxe_enabled=True, expect_errors=False)
[docs] def test_port_changed_novif_nopxe_noportgroup(self): self._test_port_changed(has_vif=False, in_portgroup=False, pxe_enabled=False, expect_errors=False)
[docs] def test_port_changed_vif_pxe_noportgroup(self): self._test_port_changed(has_vif=True, in_portgroup=False, pxe_enabled=True, expect_errors=False)
[docs] def test_port_changed_vif_nopxe_noportgroup(self): self._test_port_changed(has_vif=True, in_portgroup=False, pxe_enabled=False, expect_errors=False)
[docs] def test_port_changed_novif_pxe_portgroup_standalone_ports(self): self._test_port_changed(has_vif=False, in_portgroup=True, pxe_enabled=True, standalone_ports=True, expect_errors=False)
[docs] def test_port_changed_novif_pxe_portgroup_nostandalone_ports(self): self._test_port_changed(has_vif=False, in_portgroup=True, pxe_enabled=True, standalone_ports=False, expect_errors=True)
[docs] def test_port_changed_novif_nopxe_portgroup_standalone_ports(self): self._test_port_changed(has_vif=False, in_portgroup=True, pxe_enabled=False, standalone_ports=True, expect_errors=False)
[docs] def test_port_changed_novif_nopxe_portgroup_nostandalone_ports(self): self._test_port_changed(has_vif=False, in_portgroup=True, pxe_enabled=False, standalone_ports=False, expect_errors=False)
[docs] def test_port_changed_vif_pxe_portgroup_standalone_ports(self): self._test_port_changed(has_vif=True, in_portgroup=True, pxe_enabled=True, standalone_ports=True, expect_errors=False)
[docs] def test_port_changed_vif_pxe_portgroup_nostandalone_ports(self): self._test_port_changed(has_vif=True, in_portgroup=True, pxe_enabled=True, standalone_ports=False, expect_errors=True)
[docs] def test_port_changed_vif_nopxe_portgroup_standalone_ports(self): self._test_port_changed(has_vif=True, in_portgroup=True, pxe_enabled=True, standalone_ports=True, expect_errors=False)
[docs] def test_port_changed_vif_nopxe_portgroup_nostandalone_ports(self): self._test_port_changed(has_vif=True, in_portgroup=True, pxe_enabled=False, standalone_ports=False, expect_errors=True)
@mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_update_portgroup_address(self, mac_update_mock): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, extra={'vif_port_id': 'fake-id'}) new_address = '11:22:33:44:55:bb' pg.address = new_address with task_manager.acquire(self.context, self.node.id) as task: self.interface.portgroup_changed(task, pg) mac_update_mock.assert_called_once_with('fake-id', new_address)
@mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_update_portgroup_remove_address(self, mac_update_mock): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, extra={'vif_port_id': 'fake-id'}) pg.address = None with task_manager.acquire(self.context, self.node.id) as task: self.interface.portgroup_changed(task, pg) self.assertFalse(mac_update_mock.called)
@mock.patch.object(common_utils, 'warn_about_deprecated_extra_vif_port_id', autospec=True) @mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_update_portgroup_vif(self, mac_update_mock, mock_warn): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id) extra = {'vif_port_id': 'foo'} pg.extra = extra with task_manager.acquire(self.context, self.node.id) as task: self.interface.portgroup_changed(task, pg) self.assertFalse(mac_update_mock.called) self.assertEqual(1, mock_warn.call_count)
@mock.patch.object(common_utils, 'warn_about_deprecated_extra_vif_port_id', autospec=True) @mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_update_portgroup_vif_removal_no_deprecation(self, mac_update_mock, mock_warn): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, extra={'vif_port_id': 'foo'}) pg.extra = {} with task_manager.acquire(self.context, self.node.id) as task: self.interface.portgroup_changed(task, pg) self.assertFalse(mac_update_mock.called) self.assertFalse(mock_warn.called)
@mock.patch.object(common_utils, 'warn_about_deprecated_extra_vif_port_id', autospec=True) @mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_update_portgroup_extra_new_key(self, mac_update_mock, mock_warn): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, extra={'vif_port_id': 'vif-id'}) expected_extra = pg.extra expected_extra['foo'] = 'bar' pg.extra = expected_extra with task_manager.acquire(self.context, self.node.id) as task: self.interface.portgroup_changed(task, pg) self.assertFalse(mac_update_mock.called) self.assertFalse(mock_warn.called) self.assertEqual(expected_extra, pg.extra)
@mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_update_portgroup_address_fail(self, mac_update_mock): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, extra={'vif_port_id': 'fake-id'}) new_address = '11:22:33:44:55:bb' pg.address = new_address mac_update_mock.side_effect = ( exception.FailedToUpdateMacOnPort('boom')) with task_manager.acquire(self.context, self.node.id) as task: self.assertRaises(exception.FailedToUpdateMacOnPort, self.interface.portgroup_changed, task, pg) mac_update_mock.assert_called_once_with('fake-id', new_address)
@mock.patch.object(common_utils, 'warn_about_deprecated_extra_vif_port_id', autospec=True) @mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_update_portgroup_address_no_vif(self, mac_update_mock, mock_warn): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id) new_address = '11:22:33:44:55:bb' pg.address = new_address with task_manager.acquire(self.context, self.node.id) as task: self.interface.portgroup_changed(task, pg) self.assertEqual(new_address, pg.address) self.assertFalse(mac_update_mock.called) self.assertFalse(mock_warn.called)
@mock.patch.object(neutron_common, 'update_port_address', autospec=True)
[docs] def test_update_portgroup_nostandalone_ports_pxe_ports_exc( self, mac_update_mock): pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id) extra = {'vif_port_id': 'foo'} obj_utils.create_test_port( self.context, node_id=self.node.id, extra=extra, pxe_enabled=True, portgroup_id=pg.id, address="aa:bb:cc:dd:ee:01", uuid=uuidutils.generate_uuid()) pg.standalone_ports_supported = False with task_manager.acquire(self.context, self.node.id) as task: self.assertRaisesRegex(exception.Conflict, "VIF foo is attached to this port", self.interface.portgroup_changed, task, pg)
def _test_update_portgroup(self, has_vif=False, with_ports=False, pxe_enabled=True, standalone_ports=True, expect_errors=False): # NOTE(vsaienko) make sure that old values are opposite to new, # to guarantee that object.what_changes() returns true. old_standalone_ports_supported = not standalone_ports pg = obj_utils.create_test_portgroup( self.context, node_id=self.node.id, standalone_ports_supported=old_standalone_ports_supported) if with_ports: extra = {} if has_vif: extra = {'vif_port_id': uuidutils.generate_uuid()} obj_utils.create_test_port( self.context, node_id=self.node.id, extra=extra, pxe_enabled=pxe_enabled, portgroup_id=pg.id, address="aa:bb:cc:dd:ee:01", uuid=uuidutils.generate_uuid()) pg.standalone_ports_supported = standalone_ports with task_manager.acquire(self.context, self.node.id) as task: if not expect_errors: self.interface.portgroup_changed(task, pg) else: self.assertRaises(exception.Conflict, self.interface.portgroup_changed, task, pg)
[docs] def test_update_portgroup_standalone_ports_noports(self): self._test_update_portgroup(with_ports=False, standalone_ports=True, expect_errors=False)
[docs] def test_update_portgroup_standalone_ports_novif_pxe_ports(self): self._test_update_portgroup(with_ports=True, standalone_ports=True, has_vif=False, pxe_enabled=True, expect_errors=False)
[docs] def test_update_portgroup_nostandalone_ports_novif_pxe_ports(self): self._test_update_portgroup(with_ports=True, standalone_ports=False, has_vif=False, pxe_enabled=True, expect_errors=True)
[docs] def test_update_portgroup_nostandalone_ports_novif_nopxe_ports(self): self._test_update_portgroup(with_ports=True, standalone_ports=False, has_vif=False, pxe_enabled=False, expect_errors=False)
[docs] def test_update_portgroup_standalone_ports_novif_nopxe_ports(self): self._test_update_portgroup(with_ports=True, standalone_ports=True, has_vif=False, pxe_enabled=False, expect_errors=False)
[docs] def test_update_portgroup_standalone_ports_vif_pxe_ports(self): self._test_update_portgroup(with_ports=True, standalone_ports=True, has_vif=True, pxe_enabled=True, expect_errors=False)
[docs] def test_update_portgroup_nostandalone_ports_vif_pxe_ports(self): self._test_update_portgroup(with_ports=True, standalone_ports=False, has_vif=True, pxe_enabled=True, expect_errors=True)
[docs] def test_update_portgroup_standalone_ports_vif_nopxe_ports(self): self._test_update_portgroup(with_ports=True, standalone_ports=True, has_vif=True, pxe_enabled=False, expect_errors=False)
[docs] def test_update_portgroup_nostandalone_ports_vif_nopxe_ports(self): self._test_update_portgroup(with_ports=True, standalone_ports=False, has_vif=True, pxe_enabled=False, expect_errors=True)