Merge "NetApp ONTAP: Fix revert-to-snapshot"
This commit is contained in:
		| @@ -879,7 +879,8 @@ class NetAppCmodeFileStorageLibrary(object): | |||||||
|         """Reverts a share (in place) to the specified snapshot.""" |         """Reverts a share (in place) to the specified snapshot.""" | ||||||
|         vserver, vserver_client = self._get_vserver(share_server=share_server) |         vserver, vserver_client = self._get_vserver(share_server=share_server) | ||||||
|         share_name = self._get_backend_share_name(snapshot['share_id']) |         share_name = self._get_backend_share_name(snapshot['share_id']) | ||||||
|         snapshot_name = self._get_backend_snapshot_name(snapshot['id']) |         snapshot_name = (snapshot.get('provider_location') or | ||||||
|  |                          self._get_backend_snapshot_name(snapshot['id'])) | ||||||
|         LOG.debug('Restoring snapshot %s', snapshot_name) |         LOG.debug('Restoring snapshot %s', snapshot_name) | ||||||
|         vserver_client.restore_snapshot(share_name, snapshot_name) |         vserver_client.restore_snapshot(share_name, snapshot_name) | ||||||
|  |  | ||||||
| @@ -1824,8 +1825,10 @@ class NetAppCmodeFileStorageLibrary(object): | |||||||
|         vserver, vserver_client = self._get_vserver(share_server=share_server) |         vserver, vserver_client = self._get_vserver(share_server=share_server) | ||||||
|         share_name = self._get_backend_share_name( |         share_name = self._get_backend_share_name( | ||||||
|             active_replica_snapshot['share_id']) |             active_replica_snapshot['share_id']) | ||||||
|         snapshot_name = self._get_backend_snapshot_name( |         snapshot_name = ( | ||||||
|             active_replica_snapshot['id']) |             active_replica_snapshot.get('provider_location') or | ||||||
|  |             self._get_backend_snapshot_name(active_replica_snapshot['id'])) | ||||||
|  |  | ||||||
|         LOG.debug('Restoring snapshot %s', snapshot_name) |         LOG.debug('Restoring snapshot %s', snapshot_name) | ||||||
|  |  | ||||||
|         dm_session = data_motion.DataMotionSession() |         dm_session = data_motion.DataMotionSession() | ||||||
|   | |||||||
| @@ -1309,22 +1309,29 @@ class NetAppFileStorageLibraryTestCase(test.TestCase): | |||||||
|                                                                snapshot_name) |                                                                snapshot_name) | ||||||
|         self.assertEqual(snapshot_name, model_update['provider_location']) |         self.assertEqual(snapshot_name, model_update['provider_location']) | ||||||
|  |  | ||||||
|     def test_revert_to_snapshot(self): |     @ddt.data(True, False) | ||||||
|  |     def test_revert_to_snapshot(self, use_snap_provider_location): | ||||||
|  |  | ||||||
|         vserver_client = mock.Mock() |         vserver_client = mock.Mock() | ||||||
|         self.mock_object(self.library, |         self.mock_object(self.library, | ||||||
|                          '_get_vserver', |                          '_get_vserver', | ||||||
|                          mock.Mock(return_value=(fake.VSERVER1, |                          mock.Mock(return_value=(fake.VSERVER1, | ||||||
|                                                  vserver_client))) |                                                  vserver_client))) | ||||||
|  |         fake_snapshot = copy.deepcopy(fake.SNAPSHOT) | ||||||
|  |         if use_snap_provider_location: | ||||||
|  |             fake_snapshot['provider_location'] = 'fake-provider-location' | ||||||
|  |         else: | ||||||
|  |             del fake_snapshot['provider_location'] | ||||||
|  |  | ||||||
|         result = self.library.revert_to_snapshot( |         result = self.library.revert_to_snapshot( | ||||||
|             self.context, fake.SNAPSHOT, share_server=fake.SHARE_SERVER) |             self.context, fake_snapshot, share_server=fake.SHARE_SERVER) | ||||||
|  |  | ||||||
|         self.assertIsNone(result) |         self.assertIsNone(result) | ||||||
|         share_name = self.library._get_backend_share_name( |         share_name = self.library._get_backend_share_name( | ||||||
|             fake.SNAPSHOT['share_id']) |             fake_snapshot['share_id']) | ||||||
|         snapshot_name = self.library._get_backend_snapshot_name( |         snapshot_name = (self.library._get_backend_snapshot_name( | ||||||
|             fake.SNAPSHOT['id']) |             fake_snapshot['id']) if not use_snap_provider_location | ||||||
|  |             else 'fake-provider-location') | ||||||
|         vserver_client.restore_snapshot.assert_called_once_with(share_name, |         vserver_client.restore_snapshot.assert_called_once_with(share_name, | ||||||
|                                                                 snapshot_name) |                                                                 snapshot_name) | ||||||
|  |  | ||||||
| @@ -3919,11 +3926,18 @@ class NetAppFileStorageLibraryTestCase(test.TestCase): | |||||||
|         snapshot_list = [fake_snapshot, fake_snapshot_2, fake_snapshot_3] |         snapshot_list = [fake_snapshot, fake_snapshot_2, fake_snapshot_3] | ||||||
|         return replica_list, snapshot_list |         return replica_list, snapshot_list | ||||||
|  |  | ||||||
|     def test_revert_to_replicated_snapshot(self): |     @ddt.data(True, False) | ||||||
|  |     def test_revert_to_replicated_snapshot(self, use_snap_provider_location): | ||||||
|  |  | ||||||
|         replica_list, snapshot_list = self._get_fake_replicas_and_snapshots() |         replica_list, snapshot_list = self._get_fake_replicas_and_snapshots() | ||||||
|         fake_replica, fake_replica_2, fake_replica_3 = replica_list |         fake_replica, fake_replica_2, fake_replica_3 = replica_list | ||||||
|         fake_snapshot, fake_snapshot_2, fake_snapshot_3 = snapshot_list |         fake_snapshot, fake_snapshot_2, fake_snapshot_3 = snapshot_list | ||||||
|  |  | ||||||
|  |         if not use_snap_provider_location: | ||||||
|  |             del fake_snapshot['provider_location'] | ||||||
|  |             del fake_snapshot_2['provider_location'] | ||||||
|  |             del fake_snapshot_3['provider_location'] | ||||||
|  |  | ||||||
|         share_name = self.library._get_backend_share_name( |         share_name = self.library._get_backend_share_name( | ||||||
|             fake_snapshot['share_id']) |             fake_snapshot['share_id']) | ||||||
|         snapshot_name = self.library._get_backend_snapshot_name( |         snapshot_name = self.library._get_backend_snapshot_name( | ||||||
|   | |||||||
| @@ -0,0 +1,4 @@ | |||||||
|  | --- | ||||||
|  | fixes: | ||||||
|  |   - Fixed the NetApp ONTAP driver to handle reverting to replicated | ||||||
|  |     and migrated snapshots. | ||||||
		Reference in New Issue
	
	Block a user
	 Jenkins
					Jenkins