Merge "NetApp API failed. Reason - 18177:Relationship is in use by SnapMirror in local cluster"
This commit is contained in:
commit
22e568d1d3
@ -558,7 +558,6 @@ class NetAppCmodeMultiSVMFileStorageLibrary(
|
|||||||
node_network_info = zip(nodes, network_info['network_allocations'])
|
node_network_info = zip(nodes, network_info['network_allocations'])
|
||||||
|
|
||||||
for node_name, network_allocation in node_network_info:
|
for node_name, network_allocation in node_network_info:
|
||||||
|
|
||||||
port = self._get_node_data_port(node_name)
|
port = self._get_node_data_port(node_name)
|
||||||
vlan = network_allocation['segmentation_id']
|
vlan = network_allocation['segmentation_id']
|
||||||
network_mtu = network_allocation.get('mtu')
|
network_mtu = network_allocation.get('mtu')
|
||||||
@ -741,12 +740,24 @@ class NetAppCmodeMultiSVMFileStorageLibrary(
|
|||||||
super(NetAppCmodeMultiSVMFileStorageLibrary, self).delete_replica(
|
super(NetAppCmodeMultiSVMFileStorageLibrary, self).delete_replica(
|
||||||
context, replica_list, replica, share_snapshots)
|
context, replica_list, replica, share_snapshots)
|
||||||
|
|
||||||
|
# Fix for bug 1996907- If snapmirror relationship still exist,
|
||||||
|
# deletes those again.
|
||||||
|
snapmirrors_des_list = self._get_snapmirrors_destinations(
|
||||||
|
vserver, peer_vserver)
|
||||||
|
snapmirrors_des_list_from_peer = self._get_snapmirrors_destinations(
|
||||||
|
peer_vserver, vserver)
|
||||||
|
if snapmirrors_des_list or snapmirrors_des_list_from_peer:
|
||||||
|
super(NetAppCmodeMultiSVMFileStorageLibrary, self).delete_replica(
|
||||||
|
context, replica_list, replica, share_snapshots)
|
||||||
|
|
||||||
# Check if there are no remaining SnapMirror connections and if a
|
# Check if there are no remaining SnapMirror connections and if a
|
||||||
# vserver peering exists and delete it.
|
# vserver peering exists and delete it.
|
||||||
snapmirrors = self._get_snapmirrors(vserver, peer_vserver)
|
snapmirrors_from_local = self._get_snapmirrors(vserver, peer_vserver)
|
||||||
snapmirrors_from_peer = self._get_snapmirrors(peer_vserver, vserver)
|
snapmirrors_from_peer = self._get_snapmirrors(peer_vserver, vserver)
|
||||||
peers = self._get_vserver_peers(peer_vserver, vserver)
|
peers = self._get_vserver_peers(peer_vserver, vserver)
|
||||||
if not (snapmirrors or snapmirrors_from_peer) and peers:
|
if (not (snapmirrors_from_local or snapmirrors_from_peer
|
||||||
|
or snapmirrors_des_list or snapmirrors_des_list_from_peer)
|
||||||
|
and peers):
|
||||||
self._delete_vserver_peer(peer_vserver, vserver)
|
self._delete_vserver_peer(peer_vserver, vserver)
|
||||||
|
|
||||||
def manage_server(self, context, share_server, identifier, driver_options):
|
def manage_server(self, context, share_server, identifier, driver_options):
|
||||||
@ -795,6 +806,10 @@ class NetAppCmodeMultiSVMFileStorageLibrary(
|
|||||||
return self._client.get_snapmirrors(
|
return self._client.get_snapmirrors(
|
||||||
source_vserver=vserver, dest_vserver=peer_vserver)
|
source_vserver=vserver, dest_vserver=peer_vserver)
|
||||||
|
|
||||||
|
def _get_snapmirrors_destinations(self, vserver, peer_vserver):
|
||||||
|
return self._client.get_snapmirror_destinations(
|
||||||
|
source_vserver=vserver, dest_vserver=peer_vserver)
|
||||||
|
|
||||||
def _get_vservers_from_replicas(self, context, replica_list, new_replica):
|
def _get_vservers_from_replicas(self, context, replica_list, new_replica):
|
||||||
active_replica = self.find_active_replica(replica_list)
|
active_replica = self.find_active_replica(replica_list)
|
||||||
|
|
||||||
@ -1175,6 +1190,7 @@ class NetAppCmodeMultiSVMFileStorageLibrary(
|
|||||||
LOG.debug(
|
LOG.debug(
|
||||||
msg, {'operation_id': operation_id, 'status': status})
|
msg, {'operation_id': operation_id, 'status': status})
|
||||||
return
|
return
|
||||||
|
|
||||||
try:
|
try:
|
||||||
wait_for_status()
|
wait_for_status()
|
||||||
except exception.NetAppException:
|
except exception.NetAppException:
|
||||||
@ -2109,9 +2125,9 @@ class NetAppCmodeMultiSVMFileStorageLibrary(
|
|||||||
raise exception.NetAppException(msg)
|
raise exception.NetAppException(msg)
|
||||||
|
|
||||||
(super(NetAppCmodeMultiSVMFileStorageLibrary, self)
|
(super(NetAppCmodeMultiSVMFileStorageLibrary, self)
|
||||||
.validate_provisioning_options_for_share(provisioning_options,
|
.validate_provisioning_options_for_share(provisioning_options,
|
||||||
extra_specs=extra_specs,
|
extra_specs=extra_specs,
|
||||||
qos_specs=qos_specs))
|
qos_specs=qos_specs))
|
||||||
|
|
||||||
def _get_different_keys_for_equal_ss_type(self, current_sec_service,
|
def _get_different_keys_for_equal_ss_type(self, current_sec_service,
|
||||||
new_sec_service):
|
new_sec_service):
|
||||||
|
@ -1478,6 +1478,8 @@ class NetAppFileStorageLibraryTestCase(test.TestCase):
|
|||||||
mock.Mock(return_value=(self.fake_vserver,
|
mock.Mock(return_value=(self.fake_vserver,
|
||||||
self.fake_new_vserver_name)))
|
self.fake_new_vserver_name)))
|
||||||
self.mock_object(base_class, 'delete_replica')
|
self.mock_object(base_class, 'delete_replica')
|
||||||
|
self.mock_object(self.library, '_get_snapmirrors_destinations',
|
||||||
|
mock.Mock(return_value=[]))
|
||||||
self.mock_object(self.library, '_get_snapmirrors',
|
self.mock_object(self.library, '_get_snapmirrors',
|
||||||
mock.Mock(return_value=[]))
|
mock.Mock(return_value=[]))
|
||||||
self.mock_object(self.library, '_get_vserver_peers',
|
self.mock_object(self.library, '_get_vserver_peers',
|
||||||
@ -1491,6 +1493,10 @@ class NetAppFileStorageLibraryTestCase(test.TestCase):
|
|||||||
self.library._get_vservers_from_replicas.assert_called_once_with(
|
self.library._get_vservers_from_replicas.assert_called_once_with(
|
||||||
None, [self.fake_replica], self.fake_new_replica
|
None, [self.fake_replica], self.fake_new_replica
|
||||||
)
|
)
|
||||||
|
self.library._get_snapmirrors_destinations.assert_has_calls(
|
||||||
|
[mock.call(self.fake_vserver, self.fake_new_vserver_name),
|
||||||
|
mock.call(self.fake_new_vserver_name, self.fake_vserver)]
|
||||||
|
)
|
||||||
base_class.delete_replica.assert_called_once_with(
|
base_class.delete_replica.assert_called_once_with(
|
||||||
None, [self.fake_replica], self.fake_new_replica, []
|
None, [self.fake_replica], self.fake_new_replica, []
|
||||||
)
|
)
|
||||||
@ -1602,6 +1608,7 @@ class NetAppFileStorageLibraryTestCase(test.TestCase):
|
|||||||
class FakeDBObj(dict):
|
class FakeDBObj(dict):
|
||||||
def to_dict(self):
|
def to_dict(self):
|
||||||
return self
|
return self
|
||||||
|
|
||||||
fake_parent_share = copy.deepcopy(fake.SHARE)
|
fake_parent_share = copy.deepcopy(fake.SHARE)
|
||||||
fake_parent_share['id'] = fake.SHARE_ID2
|
fake_parent_share['id'] = fake.SHARE_ID2
|
||||||
fake_parent_share['host'] = fake.MANILA_HOST_NAME_2
|
fake_parent_share['host'] = fake.MANILA_HOST_NAME_2
|
||||||
@ -1826,11 +1833,11 @@ class NetAppFileStorageLibraryTestCase(test.TestCase):
|
|||||||
|
|
||||||
@ddt.data(
|
@ddt.data(
|
||||||
{'expected_server': fake.SHARE_SERVER_NO_NFS_NONE,
|
{'expected_server': fake.SHARE_SERVER_NO_NFS_NONE,
|
||||||
'share_group': {'share_server_id':
|
'share_group': {
|
||||||
fake.SHARE_SERVER_NO_NFS_NONE['id']}},
|
'share_server_id': fake.SHARE_SERVER_NO_NFS_NONE['id']}},
|
||||||
{'expected_server': fake.SHARE_SERVER_NO_DETAILS,
|
{'expected_server': fake.SHARE_SERVER_NO_DETAILS,
|
||||||
'share_group': {'share_server_id':
|
'share_group': {
|
||||||
fake.SHARE_SERVER_NO_DETAILS['id']}},
|
'share_server_id': fake.SHARE_SERVER_NO_DETAILS['id']}},
|
||||||
{'expected_server': fake.SHARE_SERVER_NO_DETAILS,
|
{'expected_server': fake.SHARE_SERVER_NO_DETAILS,
|
||||||
'share_group': {
|
'share_group': {
|
||||||
'share_server_id': fake.SHARE_SERVER_NO_DETAILS['id']},
|
'share_server_id': fake.SHARE_SERVER_NO_DETAILS['id']},
|
||||||
@ -2857,7 +2864,7 @@ class NetAppFileStorageLibraryTestCase(test.TestCase):
|
|||||||
|
|
||||||
@ddt.data({'mirror_state': 'snapmirrored', 'status': 'idle'},
|
@ddt.data({'mirror_state': 'snapmirrored', 'status': 'idle'},
|
||||||
{'mirror_state': 'uninitialized', 'status': 'transferring'},
|
{'mirror_state': 'uninitialized', 'status': 'transferring'},
|
||||||
{'mirror_state': 'snapmirrored', 'status': 'quiescing'},)
|
{'mirror_state': 'snapmirrored', 'status': 'quiescing'}, )
|
||||||
@ddt.unpack
|
@ddt.unpack
|
||||||
def test_share_server_migration_continue_svm_dr(self, mirror_state,
|
def test_share_server_migration_continue_svm_dr(self, mirror_state,
|
||||||
status):
|
status):
|
||||||
|
@ -0,0 +1,8 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
NetApp driver `bug #1982808
|
||||||
|
<https://bugs.launchpad.net/manila/+bug/1982808>`_: Fixed issue
|
||||||
|
to add the retry logic to delete and release the snapmirror relationship.
|
||||||
|
Delete the vserver pairing when there is no snapmirror relationship exist
|
||||||
|
on source and destination cluster.
|
Loading…
Reference in New Issue
Block a user