Merge "Return 400 when compute host is not found"

This commit is contained in:
Zuul 2018-03-07 13:42:56 +00:00 committed by Gerrit Code Review
commit 450be218da
2 changed files with 22 additions and 2 deletions

View File

@ -108,7 +108,6 @@ class MigrateServerController(wsgi.Controller):
raise exc.HTTPNotFound(explanation=e.format_message()) raise exc.HTTPNotFound(explanation=e.format_message())
except (exception.NoValidHost, except (exception.NoValidHost,
exception.ComputeServiceUnavailable, exception.ComputeServiceUnavailable,
exception.ComputeHostNotFound,
exception.InvalidHypervisorType, exception.InvalidHypervisorType,
exception.InvalidCPUInfo, exception.InvalidCPUInfo,
exception.UnableToMigrateToSelf, exception.UnableToMigrateToSelf,
@ -127,6 +126,8 @@ class MigrateServerController(wsgi.Controller):
raise exc.HTTPBadRequest(explanation=ex.format_message()) raise exc.HTTPBadRequest(explanation=ex.format_message())
except exception.InstanceIsLocked as e: except exception.InstanceIsLocked as e:
raise exc.HTTPConflict(explanation=e.format_message()) raise exc.HTTPConflict(explanation=e.format_message())
except exception.ComputeHostNotFound as e:
raise exc.HTTPBadRequest(explanation=e.format_message())
except exception.InstanceInvalidState as state_error: except exception.InstanceInvalidState as state_error:
common.raise_http_conflict_for_instance_invalid_state(state_error, common.raise_http_conflict_for_instance_invalid_state(state_error,
'os-migrateLive', id) 'os-migrateLive', id)

View File

@ -427,8 +427,27 @@ class MigrateServerTestsV234(MigrateServerTestsV230):
def test_migrate_live_migration_with_old_nova_not_supported(self): def test_migrate_live_migration_with_old_nova_not_supported(self):
pass pass
def test_migrate_live_compute_host_not_found(self):
exc = exception.ComputeHostNotFound(
reason="Compute host %(host)s could not be found.",
host='hostname')
self.mox.StubOutWithMock(self.compute_api, 'live_migrate')
instance = self._stub_instance_get()
self.compute_api.live_migrate(self.context, instance, None,
self.disk_over_commit, 'hostname',
self.force, self.async).AndRaise(exc)
self.mox.ReplayAll()
body = {'os-migrateLive':
{'host': 'hostname', 'block_migration': 'auto'}}
self.assertRaises(webob.exc.HTTPBadRequest,
self.controller._migrate_live,
self.req, instance.uuid, body=body)
def test_migrate_live_unexpected_error(self): def test_migrate_live_unexpected_error(self):
exc = exception.NoValidHost(reason="No valid host found") exc = exception.InvalidHypervisorType(
reason="The supplied hypervisor type of is invalid.")
self.mox.StubOutWithMock(self.compute_api, 'live_migrate') self.mox.StubOutWithMock(self.compute_api, 'live_migrate')
instance = self._stub_instance_get() instance = self._stub_instance_get()
self.compute_api.live_migrate(self.context, instance, None, self.compute_api.live_migrate(self.context, instance, None,