Copy default image before setting props
In order to avoid setting image properties on the default image, copy it first. Change-Id: I36eb2ea0c849285bf51c7abf28abcedeea211982
This commit is contained in:
parent
2b3cc2d891
commit
2f7c1fdb85
@ -13,6 +13,7 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
|
import six
|
||||||
import xml.etree.ElementTree as ET
|
import xml.etree.ElementTree as ET
|
||||||
|
|
||||||
from oslo_log import log as logging
|
from oslo_log import log as logging
|
||||||
@ -36,6 +37,7 @@ class BaseWhiteboxComputeTest(base.BaseV2ComputeAdminTest):
|
|||||||
cls.servers_client = cls.os_admin.servers_client
|
cls.servers_client = cls.os_admin.servers_client
|
||||||
cls.flavors_client = cls.os_admin.flavors_client
|
cls.flavors_client = cls.os_admin.flavors_client
|
||||||
cls.hypervisor_client = cls.os_admin.hypervisor_client
|
cls.hypervisor_client = cls.os_admin.hypervisor_client
|
||||||
|
cls.image_client = cls.os_admin.image_client_v2
|
||||||
|
|
||||||
def create_test_server(self, *args, **kwargs):
|
def create_test_server(self, *args, **kwargs):
|
||||||
# override the function to return the admin view of the created server
|
# override the function to return the admin view of the created server
|
||||||
@ -67,6 +69,32 @@ class BaseWhiteboxComputeTest(base.BaseV2ComputeAdminTest):
|
|||||||
|
|
||||||
return self.servers_client.show_server(server_id)['server']
|
return self.servers_client.show_server(server_id)['server']
|
||||||
|
|
||||||
|
def copy_default_image(self, **kwargs):
|
||||||
|
"""Creates a new image by downloading the default image's bits and
|
||||||
|
uploading them to a new image. Any kwargs are set as image properties
|
||||||
|
on the new image.
|
||||||
|
|
||||||
|
:return image_id: The UUID of the newly created image.
|
||||||
|
"""
|
||||||
|
image = self.image_client.show_image(CONF.compute.image_ref)
|
||||||
|
image_data = self.image_client.show_image_file(
|
||||||
|
CONF.compute.image_ref).data
|
||||||
|
image_file = six.BytesIO(image_data)
|
||||||
|
|
||||||
|
create_dict = {
|
||||||
|
'container_format': image['container_format'],
|
||||||
|
'disk_format': image['disk_format'],
|
||||||
|
'min_disk': image['min_disk'],
|
||||||
|
'min_ram': image['min_ram'],
|
||||||
|
'visibility': 'public',
|
||||||
|
}
|
||||||
|
create_dict.update(kwargs)
|
||||||
|
new_image = self.image_client.create_image(**create_dict)
|
||||||
|
self.addCleanup(self.image_client.delete_image, new_image['id'])
|
||||||
|
self.image_client.store_image_file(new_image['id'], image_file)
|
||||||
|
|
||||||
|
return new_image['id']
|
||||||
|
|
||||||
def get_hypervisor_ip(self, server_id):
|
def get_hypervisor_ip(self, server_id):
|
||||||
server = self.servers_client.show_server(server_id)
|
server = self.servers_client.show_server(server_id)
|
||||||
host = server['server']['OS-EXT-SRV-ATTR:host']
|
host = server['server']['OS-EXT-SRV-ATTR:host']
|
||||||
|
@ -32,13 +32,6 @@ class PointerDeviceTypeFromImages(base.BaseWhiteboxComputeTest):
|
|||||||
super(PointerDeviceTypeFromImages, cls).setup_clients()
|
super(PointerDeviceTypeFromImages, cls).setup_clients()
|
||||||
cls.compute_images_client = cls.os_admin.compute_images_client
|
cls.compute_images_client = cls.os_admin.compute_images_client
|
||||||
|
|
||||||
def _set_image_metadata_item(self, image):
|
|
||||||
req_metadata = {'hw_pointer_model': 'usbtablet'}
|
|
||||||
self.compute_images_client.set_image_metadata(image, req_metadata)
|
|
||||||
resp_metadata = (self.compute_images_client.list_image_metadata(image)
|
|
||||||
['metadata'])
|
|
||||||
self.assertEqual(req_metadata, resp_metadata)
|
|
||||||
|
|
||||||
def _verify_pointer_device_type_from_images(self, server_id):
|
def _verify_pointer_device_type_from_images(self, server_id):
|
||||||
domain = self.get_server_xml(server_id).text
|
domain = self.get_server_xml(server_id).text
|
||||||
tablet = domain.find('./input[@type="tablet"][@bus="usb"]')
|
tablet = domain.find('./input[@type="tablet"][@bus="usb"]')
|
||||||
@ -47,10 +40,7 @@ class PointerDeviceTypeFromImages(base.BaseWhiteboxComputeTest):
|
|||||||
self.assertTrue(mouse)
|
self.assertTrue(mouse)
|
||||||
|
|
||||||
def test_pointer_device_type_from_images(self):
|
def test_pointer_device_type_from_images(self):
|
||||||
# TODO(stephenfin): I'm pretty sure this modifying the main image. We
|
image_id = self.copy_default_image(hw_pointer_model='usbtablet')
|
||||||
# shouldn't be doing that.
|
|
||||||
image_id = CONF.compute.image_ref
|
|
||||||
self._set_image_metadata_item(image_id)
|
|
||||||
server = self.create_test_server(image_id=image_id,
|
server = self.create_test_server(image_id=image_id,
|
||||||
wait_until='ACTIVE')
|
wait_until='ACTIVE')
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user