Merge "Add exception handling to share server deletion"
This commit is contained in:
commit
56a14a045f
@ -3813,7 +3813,14 @@ class ShareManager(manager.SchedulerDependentManager):
|
|||||||
self.host,
|
self.host,
|
||||||
updated_before)
|
updated_before)
|
||||||
for server in servers:
|
for server in servers:
|
||||||
|
try:
|
||||||
self.delete_share_server(ctxt, server)
|
self.delete_share_server(ctxt, server)
|
||||||
|
except exception.ShareServerNotFound:
|
||||||
|
continue
|
||||||
|
except Exception:
|
||||||
|
LOG.exception(
|
||||||
|
"Unable to delete share server %s, will retry in the next "
|
||||||
|
"run.", server['id'])
|
||||||
|
|
||||||
@periodic_task.periodic_task(
|
@periodic_task.periodic_task(
|
||||||
spacing=CONF.check_for_expired_shares_in_recycle_bin_interval)
|
spacing=CONF.check_for_expired_shares_in_recycle_bin_interval)
|
||||||
@ -4689,6 +4696,12 @@ class ShareManager(manager.SchedulerDependentManager):
|
|||||||
# this method starts executing when amount of dependent shares
|
# this method starts executing when amount of dependent shares
|
||||||
# has been changed.
|
# has been changed.
|
||||||
server_id = share_server['id']
|
server_id = share_server['id']
|
||||||
|
try:
|
||||||
|
self.db.share_server_get(
|
||||||
|
context, server_id)
|
||||||
|
except exception.ShareServerNotFound:
|
||||||
|
raise
|
||||||
|
|
||||||
shares = self.db.share_instance_get_all_by_share_server(
|
shares = self.db.share_instance_get_all_by_share_server(
|
||||||
context, server_id)
|
context, server_id)
|
||||||
|
|
||||||
|
@ -4672,6 +4672,85 @@ class ShareManagerTestCase(test.TestCase):
|
|||||||
with test_utils.create_temp_config_with_opts(data):
|
with test_utils.create_temp_config_with_opts(data):
|
||||||
manager.ShareManager()
|
manager.ShareManager()
|
||||||
|
|
||||||
|
def test_delete_share_server_server_not_found(self):
|
||||||
|
share_server = db_utils.create_share_server()
|
||||||
|
self.share_manager.driver.initialized = True
|
||||||
|
|
||||||
|
mock_server_get = self.mock_object(
|
||||||
|
self.share_manager.db, 'share_server_get',
|
||||||
|
mock.Mock(side_effect=exception.ShareServerNotFound(
|
||||||
|
share_server_id=share_server['id'])))
|
||||||
|
|
||||||
|
self.assertRaises(
|
||||||
|
exception.ShareServerNotFound,
|
||||||
|
self.share_manager.delete_share_server,
|
||||||
|
self.context,
|
||||||
|
share_server
|
||||||
|
)
|
||||||
|
|
||||||
|
mock_server_get.assert_called_once_with(
|
||||||
|
self.context, share_server['id'])
|
||||||
|
|
||||||
|
def test_delete_share_server_server_in_use(self):
|
||||||
|
share_server = db_utils.create_share_server()
|
||||||
|
share_server_shares = [db_utils.create_share()]
|
||||||
|
self.share_manager.driver.initialized = True
|
||||||
|
|
||||||
|
mock_server_get = self.mock_object(
|
||||||
|
self.share_manager.db, 'share_server_get',
|
||||||
|
mock.Mock(return_value=share_server))
|
||||||
|
mock_instances_get = self.mock_object(
|
||||||
|
self.share_manager.db, 'share_instance_get_all_by_share_server',
|
||||||
|
mock.Mock(return_value=share_server_shares))
|
||||||
|
|
||||||
|
self.assertRaises(
|
||||||
|
exception.ShareServerInUse,
|
||||||
|
self.share_manager.delete_share_server,
|
||||||
|
self.context,
|
||||||
|
share_server
|
||||||
|
)
|
||||||
|
|
||||||
|
mock_server_get.assert_called_once_with(
|
||||||
|
self.context, share_server['id'])
|
||||||
|
mock_instances_get.assert_called_once_with(
|
||||||
|
self.context, share_server['id'])
|
||||||
|
|
||||||
|
def test_delete_share_server_teardown_failure(self):
|
||||||
|
share_server = db_utils.create_share_server()
|
||||||
|
self.share_manager.driver.initialized = True
|
||||||
|
|
||||||
|
mock_server_get = self.mock_object(
|
||||||
|
self.share_manager.db, 'share_server_get',
|
||||||
|
mock.Mock(return_value=share_server))
|
||||||
|
mock_instances_get = self.mock_object(
|
||||||
|
self.share_manager.db, 'share_instance_get_all_by_share_server',
|
||||||
|
mock.Mock(return_value=[]))
|
||||||
|
mock_teardown_server = self.mock_object(
|
||||||
|
self.share_manager.driver, 'teardown_server',
|
||||||
|
mock.Mock(side_effect=exception.ShareBackendException(msg='fake')))
|
||||||
|
mock_server_update = self.mock_object(
|
||||||
|
self.share_manager.db, 'share_server_update')
|
||||||
|
|
||||||
|
self.assertRaises(
|
||||||
|
exception.ShareBackendException,
|
||||||
|
self.share_manager.delete_share_server,
|
||||||
|
self.context,
|
||||||
|
share_server
|
||||||
|
)
|
||||||
|
|
||||||
|
mock_server_get.assert_called_once_with(
|
||||||
|
self.context, share_server['id'])
|
||||||
|
mock_instances_get.assert_called_once_with(
|
||||||
|
self.context, share_server['id'])
|
||||||
|
mock_teardown_server.assert_called_once_with(
|
||||||
|
server_details=share_server['backend_details'],
|
||||||
|
security_services=[]
|
||||||
|
)
|
||||||
|
mock_server_update.assert_called_with(
|
||||||
|
self.context, share_server['id'],
|
||||||
|
{'status': constants.STATUS_ERROR}
|
||||||
|
)
|
||||||
|
|
||||||
@mock.patch.object(db, 'share_server_get_all_unused_deletable',
|
@mock.patch.object(db, 'share_server_get_all_unused_deletable',
|
||||||
mock.Mock())
|
mock.Mock())
|
||||||
@mock.patch.object(manager.ShareManager, 'delete_share_server',
|
@mock.patch.object(manager.ShareManager, 'delete_share_server',
|
||||||
|
Loading…
Reference in New Issue
Block a user