[Ironic]Match vif-pif mac address before setting 'vif_port_id'
When booting an ironic instance with multi networks, the ironic port 'vif_port_id' may mismatch with the corresponding neutron port. Closes-Bug: #1549068 Co-Authored-By: Sivaramakrishna Garimella (sivaramakrishna.garimella@hp.com) Change-Id: Id5f033136283987eef8de4ce2f6be256e48cdbf8
This commit is contained in:
parent
6b2e8ed9bd
commit
e147a63cb3
@ -1321,7 +1321,8 @@ class IronicDriverTestCase(test.NoDBTestCase):
|
|||||||
def test_plug_vifs_with_port(self, mock_uvifs, mock_port_udt, mock_lp):
|
def test_plug_vifs_with_port(self, mock_uvifs, mock_port_udt, mock_lp):
|
||||||
node_uuid = 'aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee'
|
node_uuid = 'aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee'
|
||||||
node = ironic_utils.get_test_node(uuid=node_uuid)
|
node = ironic_utils.get_test_node(uuid=node_uuid)
|
||||||
port = ironic_utils.get_test_port()
|
# make the address be consistent with network_info's
|
||||||
|
port = ironic_utils.get_test_port(address='fake')
|
||||||
|
|
||||||
mock_lp.return_value = [port]
|
mock_lp.return_value = [port]
|
||||||
|
|
||||||
@ -1356,6 +1357,46 @@ class IronicDriverTestCase(test.NoDBTestCase):
|
|||||||
fields=ironic_driver._NODE_FIELDS)
|
fields=ironic_driver._NODE_FIELDS)
|
||||||
mock__plug_vifs.assert_called_once_with(node, instance, network_info)
|
mock__plug_vifs.assert_called_once_with(node, instance, network_info)
|
||||||
|
|
||||||
|
@mock.patch.object(FAKE_CLIENT.port, 'update')
|
||||||
|
@mock.patch.object(FAKE_CLIENT.node, 'list_ports')
|
||||||
|
@mock.patch.object(ironic_driver.IronicDriver, '_unplug_vifs')
|
||||||
|
def test_plug_vifs_multiple_ports(self, mock_uvifs, mock_lp,
|
||||||
|
mock_port_udt):
|
||||||
|
node_uuid = 'aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee'
|
||||||
|
node = ironic_utils.get_test_node(uuid=node_uuid)
|
||||||
|
first_ironic_port_uuid = 'aaaaaaaa-bbbb-1111-dddd-eeeeeeeeeeee'
|
||||||
|
first_port = ironic_utils.get_test_port(uuid=first_ironic_port_uuid,
|
||||||
|
node_uuid=node_uuid,
|
||||||
|
address='11:FF:FF:FF:FF:FF')
|
||||||
|
second_ironic_port_uuid = 'aaaaaaaa-bbbb-2222-dddd-eeeeeeeeeeee'
|
||||||
|
second_port = ironic_utils.get_test_port(uuid=second_ironic_port_uuid,
|
||||||
|
node_uuid=node_uuid,
|
||||||
|
address='22:FF:FF:FF:FF:FF')
|
||||||
|
mock_lp.return_value = [second_port, first_port]
|
||||||
|
instance = fake_instance.fake_instance_obj(self.ctx,
|
||||||
|
node=node_uuid)
|
||||||
|
first_vif_id = 'aaaaaaaa-vv11-cccc-dddd-eeeeeeeeeeee'
|
||||||
|
second_vif_id = 'aaaaaaaa-vv22-cccc-dddd-eeeeeeeeeeee'
|
||||||
|
first_vif = ironic_utils.get_test_vif(
|
||||||
|
address='22:FF:FF:FF:FF:FF',
|
||||||
|
id=second_vif_id)
|
||||||
|
second_vif = ironic_utils.get_test_vif(
|
||||||
|
address='11:FF:FF:FF:FF:FF',
|
||||||
|
id=first_vif_id)
|
||||||
|
network_info = [first_vif, second_vif]
|
||||||
|
self.driver._plug_vifs(node, instance, network_info)
|
||||||
|
|
||||||
|
# asserts
|
||||||
|
mock_uvifs.assert_called_once_with(node, instance, network_info)
|
||||||
|
mock_lp.assert_called_once_with(node_uuid)
|
||||||
|
calls = (mock.call(first_ironic_port_uuid,
|
||||||
|
[{'op': 'add', 'path': '/extra/vif_port_id',
|
||||||
|
'value': first_vif_id}]),
|
||||||
|
mock.call(second_ironic_port_uuid,
|
||||||
|
[{'op': 'add', 'path': '/extra/vif_port_id',
|
||||||
|
'value': second_vif_id}]))
|
||||||
|
mock_port_udt.assert_has_calls(calls, any_order=True)
|
||||||
|
|
||||||
@mock.patch.object(FAKE_CLIENT.port, 'update')
|
@mock.patch.object(FAKE_CLIENT.port, 'update')
|
||||||
@mock.patch.object(FAKE_CLIENT.node, 'list_ports')
|
@mock.patch.object(FAKE_CLIENT.node, 'list_ports')
|
||||||
@mock.patch.object(ironic_driver.IronicDriver, '_unplug_vifs')
|
@mock.patch.object(ironic_driver.IronicDriver, '_unplug_vifs')
|
||||||
|
@ -61,6 +61,24 @@ def get_test_port(**kw):
|
|||||||
'updated_at': kw.get('updated_at')})()
|
'updated_at': kw.get('updated_at')})()
|
||||||
|
|
||||||
|
|
||||||
|
def get_test_vif(**kw):
|
||||||
|
return {
|
||||||
|
'profile': kw.get('profile', {}),
|
||||||
|
'ovs_interfaceid': kw.get('ovs_interfaceid'),
|
||||||
|
'preserve_on_delete': kw.get('preserve_on_delete', False),
|
||||||
|
'network': kw.get('network', {}),
|
||||||
|
'devname': kw.get('devname', 'tapaaaaaaaa-00'),
|
||||||
|
'vnic_type': kw.get('vnic_type', 'baremetal'),
|
||||||
|
'qbh_params': kw.get('qbh_params'),
|
||||||
|
'meta': kw.get('meta', {}),
|
||||||
|
'details': kw.get('details', {}),
|
||||||
|
'address': kw.get('address', 'FF:FF:FF:FF:FF:FF'),
|
||||||
|
'active': kw.get('active', True),
|
||||||
|
'type': kw.get('type', 'ironic'),
|
||||||
|
'id': kw.get('id', 'aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee'),
|
||||||
|
'qbg_params': kw.get('qbg_params')}
|
||||||
|
|
||||||
|
|
||||||
def get_test_flavor(**kw):
|
def get_test_flavor(**kw):
|
||||||
default_extra_specs = {'baremetal:deploy_kernel_id':
|
default_extra_specs = {'baremetal:deploy_kernel_id':
|
||||||
'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa',
|
'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa',
|
||||||
|
@ -1012,13 +1012,16 @@ class IronicDriver(virt_driver.ComputeDriver):
|
|||||||
|
|
||||||
if len(network_info) > 0:
|
if len(network_info) > 0:
|
||||||
# not needed if no vif are defined
|
# not needed if no vif are defined
|
||||||
for vif, pif in zip(network_info, ports):
|
for vif in network_info:
|
||||||
# attach what neutron needs directly to the port
|
for pif in ports:
|
||||||
port_id = six.text_type(vif['id'])
|
if vif['address'] == pif.address:
|
||||||
patch = [{'op': 'add',
|
# attach what neutron needs directly to the port
|
||||||
'path': '/extra/vif_port_id',
|
port_id = six.text_type(vif['id'])
|
||||||
'value': port_id}]
|
patch = [{'op': 'add',
|
||||||
self.ironicclient.call("port.update", pif.uuid, patch)
|
'path': '/extra/vif_port_id',
|
||||||
|
'value': port_id}]
|
||||||
|
self.ironicclient.call("port.update", pif.uuid, patch)
|
||||||
|
break
|
||||||
|
|
||||||
def _unplug_vifs(self, node, instance, network_info):
|
def _unplug_vifs(self, node, instance, network_info):
|
||||||
# NOTE(PhilDay): Accessing network_info will block if the thread
|
# NOTE(PhilDay): Accessing network_info will block if the thread
|
||||||
@ -1033,7 +1036,7 @@ class IronicDriver(virt_driver.ComputeDriver):
|
|||||||
detail=True)
|
detail=True)
|
||||||
|
|
||||||
# not needed if no vif are defined
|
# not needed if no vif are defined
|
||||||
for vif, pif in zip(network_info, ports):
|
for pif in ports:
|
||||||
if 'vif_port_id' in pif.extra:
|
if 'vif_port_id' in pif.extra:
|
||||||
# we can not attach a dict directly
|
# we can not attach a dict directly
|
||||||
patch = [{'op': 'remove', 'path': '/extra/vif_port_id'}]
|
patch = [{'op': 'remove', 'path': '/extra/vif_port_id'}]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user