[SVf]: mkhost failure when volume and node are on different iogrp
Attach operation fails when volume and back-end host are on different iogroup. The assignment of the node IP addresses is done outside the try block, and the "for ip_data in lsip_resp" loop. Because of this the loop was not consistent before, so only latest node was detected instead of all nodes. Closes-Bug: #1985065 Change-Id: I72074357140e9817eee704b6e9ebfd7f50343235
This commit is contained in:
parent
a7ea9520f7
commit
54872f9b6c
@ -4994,6 +4994,66 @@ class StorwizeSVCCommonDriverTestCase(test.TestCase):
|
|||||||
# Finally, check with good parameters
|
# Finally, check with good parameters
|
||||||
self.driver.do_setup(None)
|
self.driver.do_setup(None)
|
||||||
|
|
||||||
|
@mock.patch.object(storwize_svc_common.StorwizeSSH,
|
||||||
|
'lsip')
|
||||||
|
@mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
||||||
|
'get_node_info')
|
||||||
|
@mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
||||||
|
'get_system_info')
|
||||||
|
def test_storwize_add_iscsi_ip_address(self, get_system_info,
|
||||||
|
get_node_info, lsip):
|
||||||
|
helper = self.driver._master_backend_helpers
|
||||||
|
helper.state = {'storage_nodes': {}, 'enabled_protocols': set(),
|
||||||
|
'compression_enabled': False, 'available_iogrps': [],
|
||||||
|
'system_name': None, 'system_id': None,
|
||||||
|
'code_level': None}
|
||||||
|
get_system_info.return_value = {'code_level': (8, 5, 0, 0),
|
||||||
|
'topology': 'standard',
|
||||||
|
'system_name': 'storwize-svc-sim',
|
||||||
|
'system_id': '0123456789ABCDEF'}
|
||||||
|
|
||||||
|
get_node_info.return_value = {'1': {'id': '1', 'name': 'node1',
|
||||||
|
'IO_group': 0,
|
||||||
|
'iscsi_name': 'test_iscsi1',
|
||||||
|
'site_id': '1',
|
||||||
|
'site_name': 'site1',
|
||||||
|
'ipv4': [],
|
||||||
|
'ipv6': [],
|
||||||
|
'IP_address': [],
|
||||||
|
'WWPN': [],
|
||||||
|
'enabled_protocols': [],
|
||||||
|
'status': 'online'},
|
||||||
|
'2': {'id': '2', 'name': 'node2',
|
||||||
|
'IO_group': 1,
|
||||||
|
'iscsi_name': 'test_iscsi2',
|
||||||
|
'site_id': '1',
|
||||||
|
'site_name': 'site1',
|
||||||
|
'ipv4': [],
|
||||||
|
'ipv6': [],
|
||||||
|
'IP_address': [],
|
||||||
|
'WWPN': [],
|
||||||
|
'enabled_protocols': [],
|
||||||
|
'status': 'online'}}
|
||||||
|
|
||||||
|
lsip.return_value = [{'node_id': '1', 'IP_address': '1.1.1.1'},
|
||||||
|
{'node_id': '2', 'IP_address': '2.2.2.2'}]
|
||||||
|
|
||||||
|
# Initially the storage_nodes will be empty
|
||||||
|
self.assertEqual(helper.state["storage_nodes"], {})
|
||||||
|
|
||||||
|
# _update_storwize_state will update the code_level
|
||||||
|
# and node info. After that it will call add_iscsi_ip_addrs to
|
||||||
|
# update the IP_address for the corresponding node_id in storage_nodes
|
||||||
|
self.driver._update_storwize_state(helper.state, helper)
|
||||||
|
|
||||||
|
# Now, IPs of both the node_id in storage_nodes is updated correctly
|
||||||
|
# Which means add_iscsi_ip_addrs was successful.
|
||||||
|
self.assertNotEqual(helper.state["storage_nodes"], {})
|
||||||
|
self.assertEqual(helper.state["storage_nodes"]['1']['IP_address'],
|
||||||
|
['1.1.1.1'])
|
||||||
|
self.assertEqual(helper.state["storage_nodes"]['2']['IP_address'],
|
||||||
|
['2.2.2.2'])
|
||||||
|
|
||||||
@mock.patch.object(storwize_svc_common.StorwizeSSH,
|
@mock.patch.object(storwize_svc_common.StorwizeSSH,
|
||||||
'mkhost')
|
'mkhost')
|
||||||
def test_storwize_create_host_with_portset(self, mkhost):
|
def test_storwize_create_host_with_portset(self, mkhost):
|
||||||
|
@ -1105,18 +1105,19 @@ class StorwizeHelpers(object):
|
|||||||
if code_level >= (8, 4, 2, 0):
|
if code_level >= (8, 4, 2, 0):
|
||||||
portset_name = portset if portset else 'portset0'
|
portset_name = portset if portset else 'portset0'
|
||||||
lsip_resp = self.ssh.lsip(portset=portset_name)
|
lsip_resp = self.ssh.lsip(portset=portset_name)
|
||||||
|
# For every node_id there is one IP address in a particular
|
||||||
|
# portset_name. Hence storing that one IP address of the
|
||||||
|
# corresponding node_id in storage_node list.
|
||||||
for node_data in storage_nodes:
|
for node_data in storage_nodes:
|
||||||
ip_addresses = []
|
|
||||||
try:
|
try:
|
||||||
for ip_data in lsip_resp:
|
for ip_data in lsip_resp:
|
||||||
if ip_data['node_id'] in node_data:
|
if ip_data['node_id'] in node_data:
|
||||||
if (ip_data['IP_address']):
|
if ip_data['IP_address']:
|
||||||
ip_addresses.append(ip_data['IP_address'])
|
(storage_nodes[ip_data['node_id']]
|
||||||
|
['IP_address']) = (
|
||||||
|
[ip_data['IP_address']])
|
||||||
except KeyError:
|
except KeyError:
|
||||||
self.handle_keyerror('lsip', ip_data)
|
self.handle_keyerror('lsip', ip_data)
|
||||||
if ip_addresses:
|
|
||||||
storage_nodes[ip_data['node_id']]['IP_address'] = (
|
|
||||||
ip_addresses)
|
|
||||||
else:
|
else:
|
||||||
lsportip_resp = self.ssh.lsportip()
|
lsportip_resp = self.ssh.lsportip()
|
||||||
for ip_data in lsportip_resp:
|
for ip_data in lsportip_resp:
|
||||||
|
@ -0,0 +1,8 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
IBM Spectrum Virtualize Family driver: `Bug #1985065
|
||||||
|
<https://bugs.launchpad.net/cinder/+bug/1985065>`_:
|
||||||
|
Fixed to collect all the IP addresses for all the storage
|
||||||
|
nodes given in lsip command response as volume of any iogrp
|
||||||
|
should be available to the storage nodes in default scenario.
|
Loading…
x
Reference in New Issue
Block a user