Merge "Handle volume-backed instances in IsolatedHostsFilter"
This commit is contained in:
commit
c3b1d6fc15
@ -59,7 +59,10 @@ class IsolatedHostsFilter(filters.BaseHostFilter):
|
|||||||
return ((not restrict_isolated_hosts_to_isolated_images) or
|
return ((not restrict_isolated_hosts_to_isolated_images) or
|
||||||
(host_state.host not in isolated_hosts))
|
(host_state.host not in isolated_hosts))
|
||||||
|
|
||||||
image_ref = spec_obj.image.id if spec_obj.image else None
|
# Check to see if the image id is set since volume-backed instances
|
||||||
|
# can be created without an imageRef in the server create request.
|
||||||
|
image_ref = spec_obj.image.id \
|
||||||
|
if spec_obj.image and 'id' in spec_obj.image else None
|
||||||
image_isolated = image_ref in isolated_images
|
image_isolated = image_ref in isolated_images
|
||||||
host_isolated = host_state.host in isolated_hosts
|
host_isolated = host_state.host in isolated_hosts
|
||||||
|
|
||||||
|
@ -92,7 +92,11 @@ class TestBootFromVolumeIsolatedHostsFilter(
|
|||||||
# networks='none'.
|
# networks='none'.
|
||||||
with utils.temporary_mutation(self.api, microversion='2.37'):
|
with utils.temporary_mutation(self.api, microversion='2.37'):
|
||||||
server = self.api.post_server(server_req_body)
|
server = self.api.post_server(server_req_body)
|
||||||
server = self._wait_for_state_change(self.api, server, 'ERROR')
|
server = self._wait_for_state_change(self.api, server, 'ACTIVE')
|
||||||
# Due to bug 1746483 we expect scheduling to fail.
|
# NOTE(mriedem): The instance is successfully scheduled but since
|
||||||
self.assertIn("Cannot load 'id' in the base class",
|
# the image_id from the volume_image_metadata isn't stored in the
|
||||||
server['fault']['message'])
|
# RequestSpec.image.id, and restrict_isolated_hosts_to_isolated_images
|
||||||
|
# is True, the isolated host (host1) is filtered out because the
|
||||||
|
# filter doesn't have enough information to know if the image within
|
||||||
|
# the volume can be used on that host.
|
||||||
|
self.assertEqual('host2', server['OS-EXT-SRV-ATTR:host'])
|
||||||
|
Loading…
Reference in New Issue
Block a user