Merge "Fix migration_success before completing"
This commit is contained in:
commit
741136e3be
@ -1237,18 +1237,9 @@ class ShareManager(manager.SchedulerDependentManager):
|
|||||||
|
|
||||||
helper.apply_new_access_rules(dest_share_instance)
|
helper.apply_new_access_rules(dest_share_instance)
|
||||||
|
|
||||||
self.db.share_instance_update(
|
|
||||||
context, dest_share_instance['id'],
|
|
||||||
{'status': constants.STATUS_AVAILABLE})
|
|
||||||
|
|
||||||
self._migration_delete_instance(context, src_share_instance['id'])
|
|
||||||
|
|
||||||
self.db.share_update(
|
|
||||||
context, dest_share_instance['share_id'],
|
|
||||||
{'task_state': constants.TASK_STATE_MIGRATION_SUCCESS})
|
|
||||||
|
|
||||||
def _migration_delete_instance(self, context, instance_id):
|
def _migration_delete_instance(self, context, instance_id):
|
||||||
|
|
||||||
|
# refresh the share instance model
|
||||||
share_instance = self.db.share_instance_get(
|
share_instance = self.db.share_instance_get(
|
||||||
context, instance_id, with_share_data=True)
|
context, instance_id, with_share_data=True)
|
||||||
|
|
||||||
@ -1336,8 +1327,19 @@ class ShareManager(manager.SchedulerDependentManager):
|
|||||||
{'status': constants.STATUS_AVAILABLE})
|
{'status': constants.STATUS_AVAILABLE})
|
||||||
raise exception.ShareMigrationFailed(reason=msg)
|
raise exception.ShareMigrationFailed(reason=msg)
|
||||||
|
|
||||||
self._update_migrated_share_model(
|
self.db.share_instance_update(
|
||||||
context, share_ref['id'], dest_share_instance)
|
context, dest_share_instance['id'],
|
||||||
|
{'status': constants.STATUS_AVAILABLE})
|
||||||
|
|
||||||
|
self._migration_delete_instance(context, src_share_instance['id'])
|
||||||
|
|
||||||
|
model_update = self._get_extra_specs_from_share_type(
|
||||||
|
context, dest_share_instance['share_type_id'])
|
||||||
|
|
||||||
|
model_update['task_state'] = constants.TASK_STATE_MIGRATION_SUCCESS
|
||||||
|
|
||||||
|
self.db.share_update(
|
||||||
|
context, dest_share_instance['share_id'], model_update)
|
||||||
|
|
||||||
LOG.info(_LI("Share Migration for share %s"
|
LOG.info(_LI("Share Migration for share %s"
|
||||||
" completed successfully."), share_ref['id'])
|
" completed successfully."), share_ref['id'])
|
||||||
@ -1350,19 +1352,9 @@ class ShareManager(manager.SchedulerDependentManager):
|
|||||||
|
|
||||||
return share_api.get_share_attributes_from_share_type(share_type)
|
return share_api.get_share_attributes_from_share_type(share_type)
|
||||||
|
|
||||||
def _update_migrated_share_model(
|
|
||||||
self, context, share_id, dest_share_instance):
|
|
||||||
|
|
||||||
update = self._get_extra_specs_from_share_type(
|
|
||||||
context, dest_share_instance['share_type_id'])
|
|
||||||
|
|
||||||
self.db.share_update(context, share_id, update)
|
|
||||||
|
|
||||||
def _migration_complete_host_assisted(self, context, share_ref,
|
def _migration_complete_host_assisted(self, context, share_ref,
|
||||||
src_instance_id, dest_instance_id):
|
src_instance_id, dest_instance_id):
|
||||||
|
|
||||||
src_share_instance = self.db.share_instance_get(
|
|
||||||
context, src_instance_id, with_share_data=True)
|
|
||||||
dest_share_instance = self.db.share_instance_get(
|
dest_share_instance = self.db.share_instance_get(
|
||||||
context, dest_instance_id, with_share_data=True)
|
context, dest_instance_id, with_share_data=True)
|
||||||
|
|
||||||
@ -1404,6 +1396,10 @@ class ShareManager(manager.SchedulerDependentManager):
|
|||||||
LOG.error(msg)
|
LOG.error(msg)
|
||||||
raise exception.ShareMigrationFailed(reason=msg)
|
raise exception.ShareMigrationFailed(reason=msg)
|
||||||
|
|
||||||
|
self.db.share_update(
|
||||||
|
context, share_ref['id'],
|
||||||
|
{'task_state': constants.TASK_STATE_MIGRATION_COMPLETING})
|
||||||
|
|
||||||
try:
|
try:
|
||||||
helper.apply_new_access_rules(dest_share_instance)
|
helper.apply_new_access_rules(dest_share_instance)
|
||||||
except Exception:
|
except Exception:
|
||||||
@ -1420,24 +1416,6 @@ class ShareManager(manager.SchedulerDependentManager):
|
|||||||
|
|
||||||
raise exception.ShareMigrationFailed(reason=msg)
|
raise exception.ShareMigrationFailed(reason=msg)
|
||||||
|
|
||||||
self.db.share_update(
|
|
||||||
context, share_ref['id'],
|
|
||||||
{'task_state': constants.TASK_STATE_MIGRATION_COMPLETING})
|
|
||||||
|
|
||||||
self.db.share_instance_update(context, dest_instance_id,
|
|
||||||
{'status': constants.STATUS_AVAILABLE})
|
|
||||||
|
|
||||||
self.db.share_instance_update(context, src_instance_id,
|
|
||||||
{'status': constants.STATUS_INACTIVE})
|
|
||||||
|
|
||||||
helper.delete_instance_and_wait(src_share_instance)
|
|
||||||
|
|
||||||
self._check_delete_share_server(context, src_share_instance)
|
|
||||||
|
|
||||||
self.db.share_update(
|
|
||||||
context, share_ref['id'],
|
|
||||||
{'task_state': constants.TASK_STATE_MIGRATION_SUCCESS})
|
|
||||||
|
|
||||||
@utils.require_driver_initialized
|
@utils.require_driver_initialized
|
||||||
def migration_cancel(self, context, src_instance_id, dest_instance_id):
|
def migration_cancel(self, context, src_instance_id, dest_instance_id):
|
||||||
|
|
||||||
|
@ -4423,6 +4423,8 @@ class ShareManagerTestCase(test.TestCase):
|
|||||||
instances=[instance_1, instance_2],
|
instances=[instance_1, instance_2],
|
||||||
task_state=task_state)
|
task_state=task_state)
|
||||||
model_type_update = {'create_share_from_snapshot_support': False}
|
model_type_update = {'create_share_from_snapshot_support': False}
|
||||||
|
share_update = model_type_update
|
||||||
|
share_update['task_state'] = constants.TASK_STATE_MIGRATION_SUCCESS
|
||||||
|
|
||||||
# mocks
|
# mocks
|
||||||
self.mock_object(self.share_manager.db, 'share_get',
|
self.mock_object(self.share_manager.db, 'share_get',
|
||||||
@ -4444,6 +4446,9 @@ class ShareManagerTestCase(test.TestCase):
|
|||||||
self.share_manager, '_migration_complete_host_assisted',
|
self.share_manager, '_migration_complete_host_assisted',
|
||||||
mock.Mock(side_effect=exc))
|
mock.Mock(side_effect=exc))
|
||||||
|
|
||||||
|
si_update = self.mock_object(
|
||||||
|
self.share_manager.db, 'share_instance_update')
|
||||||
|
|
||||||
if exc:
|
if exc:
|
||||||
snapshot = db_utils.create_snapshot(share_id=share['id'])
|
snapshot = db_utils.create_snapshot(share_id=share['id'])
|
||||||
snapshot_ins1 = db_utils.create_snapshot_instance(
|
snapshot_ins1 = db_utils.create_snapshot_instance(
|
||||||
@ -4456,19 +4461,22 @@ class ShareManagerTestCase(test.TestCase):
|
|||||||
status=constants.STATUS_MIGRATING_TO)
|
status=constants.STATUS_MIGRATING_TO)
|
||||||
self.mock_object(manager.LOG, 'exception')
|
self.mock_object(manager.LOG, 'exception')
|
||||||
self.mock_object(self.share_manager.db, 'share_update')
|
self.mock_object(self.share_manager.db, 'share_update')
|
||||||
self.mock_object(self.share_manager.db, 'share_instance_update')
|
|
||||||
self.mock_object(self.share_manager.db,
|
self.mock_object(self.share_manager.db,
|
||||||
'share_snapshot_instance_update')
|
'share_snapshot_instance_update')
|
||||||
self.mock_object(self.share_manager.db,
|
self.mock_object(self.share_manager.db,
|
||||||
'share_snapshot_instance_get_all_with_filters',
|
'share_snapshot_instance_get_all_with_filters',
|
||||||
mock.Mock(
|
mock.Mock(
|
||||||
return_value=[snapshot_ins1, snapshot_ins2]))
|
return_value=[snapshot_ins1, snapshot_ins2]))
|
||||||
|
|
||||||
self.assertRaises(
|
self.assertRaises(
|
||||||
exception.ShareMigrationFailed,
|
exception.ShareMigrationFailed,
|
||||||
self.share_manager.migration_complete,
|
self.share_manager.migration_complete,
|
||||||
self.context, instance_1['id'], instance_2['id'])
|
self.context, instance_1['id'], instance_2['id'])
|
||||||
|
|
||||||
else:
|
else:
|
||||||
|
instance_delete = self.mock_object(
|
||||||
|
self.share_manager, '_migration_delete_instance')
|
||||||
|
|
||||||
self.share_manager.migration_complete(
|
self.share_manager.migration_complete(
|
||||||
self.context, instance_1['id'], instance_2['id'])
|
self.context, instance_1['id'], instance_2['id'])
|
||||||
|
|
||||||
@ -4528,7 +4536,13 @@ class ShareManagerTestCase(test.TestCase):
|
|||||||
share_types.get_share_type.assert_called_once_with(
|
share_types.get_share_type.assert_called_once_with(
|
||||||
self.context, 'fake_type_id')
|
self.context, 'fake_type_id')
|
||||||
self.share_manager.db.share_update.assert_called_once_with(
|
self.share_manager.db.share_update.assert_called_once_with(
|
||||||
self.context, share['id'], model_type_update)
|
self.context, share['id'], share_update)
|
||||||
|
|
||||||
|
instance_delete.assert_called_once_with(
|
||||||
|
self.context, instance_1['id'])
|
||||||
|
si_update.assert_called_once_with(
|
||||||
|
self.context, instance_2['id'],
|
||||||
|
{'status': constants.STATUS_AVAILABLE})
|
||||||
|
|
||||||
@ddt.data(constants.TASK_STATE_DATA_COPYING_ERROR,
|
@ddt.data(constants.TASK_STATE_DATA_COPYING_ERROR,
|
||||||
constants.TASK_STATE_DATA_COPYING_CANCELLED,
|
constants.TASK_STATE_DATA_COPYING_CANCELLED,
|
||||||
@ -4545,7 +4559,7 @@ class ShareManagerTestCase(test.TestCase):
|
|||||||
|
|
||||||
# mocks
|
# mocks
|
||||||
self.mock_object(self.share_manager.db, 'share_instance_get',
|
self.mock_object(self.share_manager.db, 'share_instance_get',
|
||||||
mock.Mock(side_effect=[instance, new_instance]))
|
mock.Mock(return_value=new_instance))
|
||||||
self.mock_object(helper, 'cleanup_new_instance')
|
self.mock_object(helper, 'cleanup_new_instance')
|
||||||
self.mock_object(migration_api, 'ShareMigrationHelper',
|
self.mock_object(migration_api, 'ShareMigrationHelper',
|
||||||
mock.Mock(return_value=helper))
|
mock.Mock(return_value=helper))
|
||||||
@ -4569,10 +4583,8 @@ class ShareManagerTestCase(test.TestCase):
|
|||||||
self.context, share, instance['id'], new_instance['id'])
|
self.context, share, instance['id'], new_instance['id'])
|
||||||
|
|
||||||
# asserts
|
# asserts
|
||||||
self.share_manager.db.share_instance_get.assert_has_calls([
|
self.share_manager.db.share_instance_get.assert_called_once_with(
|
||||||
mock.call(self.context, instance['id'], with_share_data=True),
|
self.context, new_instance['id'], with_share_data=True)
|
||||||
mock.call(self.context, new_instance['id'], with_share_data=True)
|
|
||||||
])
|
|
||||||
|
|
||||||
cancelled = not(status == constants.TASK_STATE_DATA_COPYING_CANCELLED)
|
cancelled = not(status == constants.TASK_STATE_DATA_COPYING_CANCELLED)
|
||||||
if status != 'other':
|
if status != 'other':
|
||||||
@ -4646,9 +4658,7 @@ class ShareManagerTestCase(test.TestCase):
|
|||||||
self.mock_object(
|
self.mock_object(
|
||||||
self.share_manager.access_helper, '_check_needs_refresh',
|
self.share_manager.access_helper, '_check_needs_refresh',
|
||||||
mock.Mock(return_value=True))
|
mock.Mock(return_value=True))
|
||||||
self.mock_object(self.share_manager.db, 'share_instance_update')
|
|
||||||
self.mock_object(self.share_manager.db, 'share_update')
|
self.mock_object(self.share_manager.db, 'share_update')
|
||||||
self.mock_object(self.share_manager, '_migration_delete_instance')
|
|
||||||
self.mock_object(migration_api.ShareMigrationHelper,
|
self.mock_object(migration_api.ShareMigrationHelper,
|
||||||
'apply_new_access_rules')
|
'apply_new_access_rules')
|
||||||
self.mock_object(
|
self.mock_object(
|
||||||
@ -4678,18 +4688,11 @@ class ShareManagerTestCase(test.TestCase):
|
|||||||
snapshot_mappings, src_server, dest_server)
|
snapshot_mappings, src_server, dest_server)
|
||||||
(migration_api.ShareMigrationHelper.apply_new_access_rules.
|
(migration_api.ShareMigrationHelper.apply_new_access_rules.
|
||||||
assert_called_once_with(dest_instance))
|
assert_called_once_with(dest_instance))
|
||||||
self.share_manager._migration_delete_instance.assert_called_once_with(
|
|
||||||
self.context, src_instance['id'])
|
self.share_manager.db.share_update.assert_called_once_with(
|
||||||
self.share_manager.db.share_instance_update.assert_called_once_with(
|
self.context, dest_instance['share_id'],
|
||||||
self.context, dest_instance['id'],
|
{'task_state': constants.TASK_STATE_MIGRATION_COMPLETING})
|
||||||
{'status': constants.STATUS_AVAILABLE})
|
|
||||||
self.share_manager.db.share_update.assert_has_calls([
|
|
||||||
mock.call(
|
|
||||||
self.context, dest_instance['share_id'],
|
|
||||||
{'task_state': constants.TASK_STATE_MIGRATION_COMPLETING}),
|
|
||||||
mock.call(
|
|
||||||
self.context, dest_instance['share_id'],
|
|
||||||
{'task_state': constants.TASK_STATE_MIGRATION_SUCCESS})])
|
|
||||||
(self.share_manager.db.share_snapshot_instance_get_all_with_filters.
|
(self.share_manager.db.share_snapshot_instance_get_all_with_filters.
|
||||||
assert_has_calls([
|
assert_has_calls([
|
||||||
mock.call(self.context,
|
mock.call(self.context,
|
||||||
@ -4725,11 +4728,8 @@ class ShareManagerTestCase(test.TestCase):
|
|||||||
|
|
||||||
# mocks
|
# mocks
|
||||||
self.mock_object(self.share_manager.db, 'share_instance_get',
|
self.mock_object(self.share_manager.db, 'share_instance_get',
|
||||||
mock.Mock(side_effect=[instance, new_instance]))
|
mock.Mock(return_value=new_instance))
|
||||||
self.mock_object(self.share_manager.db, 'share_instance_update')
|
|
||||||
self.mock_object(self.share_manager.db, 'share_update')
|
self.mock_object(self.share_manager.db, 'share_update')
|
||||||
self.mock_object(migration_api.ShareMigrationHelper,
|
|
||||||
'delete_instance_and_wait')
|
|
||||||
self.mock_object(migration_api.ShareMigrationHelper,
|
self.mock_object(migration_api.ShareMigrationHelper,
|
||||||
'apply_new_access_rules')
|
'apply_new_access_rules')
|
||||||
|
|
||||||
@ -4738,29 +4738,14 @@ class ShareManagerTestCase(test.TestCase):
|
|||||||
self.context, share, instance['id'], new_instance['id'])
|
self.context, share, instance['id'], new_instance['id'])
|
||||||
|
|
||||||
# asserts
|
# asserts
|
||||||
self.share_manager.db.share_instance_get.assert_has_calls([
|
self.share_manager.db.share_instance_get.assert_called_once_with(
|
||||||
mock.call(self.context, instance['id'], with_share_data=True),
|
self.context, new_instance['id'], with_share_data=True)
|
||||||
mock.call(self.context, new_instance['id'], with_share_data=True)
|
|
||||||
])
|
|
||||||
|
|
||||||
self.share_manager.db.share_instance_update.assert_has_calls([
|
self.share_manager.db.share_update.assert_called_once_with(
|
||||||
mock.call(self.context, new_instance['id'],
|
self.context, share['id'],
|
||||||
{'status': constants.STATUS_AVAILABLE}),
|
{'task_state': constants.TASK_STATE_MIGRATION_COMPLETING})
|
||||||
mock.call(self.context, instance['id'],
|
|
||||||
{'status': constants.STATUS_INACTIVE})
|
|
||||||
])
|
|
||||||
self.share_manager.db.share_update.assert_has_calls([
|
|
||||||
mock.call(
|
|
||||||
self.context, share['id'],
|
|
||||||
{'task_state': constants.TASK_STATE_MIGRATION_COMPLETING}),
|
|
||||||
mock.call(
|
|
||||||
self.context, share['id'],
|
|
||||||
{'task_state': constants.TASK_STATE_MIGRATION_SUCCESS}),
|
|
||||||
])
|
|
||||||
migration_api.ShareMigrationHelper.apply_new_access_rules.\
|
migration_api.ShareMigrationHelper.apply_new_access_rules.\
|
||||||
assert_called_once_with(new_instance)
|
assert_called_once_with(new_instance)
|
||||||
migration_api.ShareMigrationHelper.delete_instance_and_wait.\
|
|
||||||
assert_called_once_with(instance)
|
|
||||||
|
|
||||||
@ddt.data(constants.TASK_STATE_MIGRATION_DRIVER_IN_PROGRESS,
|
@ddt.data(constants.TASK_STATE_MIGRATION_DRIVER_IN_PROGRESS,
|
||||||
constants.TASK_STATE_MIGRATION_DRIVER_PHASE1_DONE,
|
constants.TASK_STATE_MIGRATION_DRIVER_PHASE1_DONE,
|
||||||
|
@ -0,0 +1,6 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- Fixed ``task_state`` field in the share model
|
||||||
|
being set to ``migration_success`` before actually
|
||||||
|
completing a share migration.
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user