180 lines
7.9 KiB
Python
180 lines
7.9 KiB
Python
# Copyright 2013 Hewlett-Packard Development Company, L.P.
|
|
# All Rights Reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
import testtools
|
|
|
|
from tempest.api.compute import base
|
|
from tempest.common import waiters
|
|
from tempest import config
|
|
from tempest.lib.common.utils import data_utils
|
|
from tempest.lib import decorators
|
|
|
|
CONF = config.CONF
|
|
|
|
|
|
class ServerRescueTestBase(base.BaseV2ComputeTest):
|
|
create_default_network = True
|
|
|
|
@classmethod
|
|
def skip_checks(cls):
|
|
super(ServerRescueTestBase, cls).skip_checks()
|
|
if not CONF.compute_feature_enabled.rescue:
|
|
msg = "Server rescue not available."
|
|
raise cls.skipException(msg)
|
|
|
|
@classmethod
|
|
def setup_credentials(cls):
|
|
cls.set_network_resources(network=True, subnet=True, router=True)
|
|
super(ServerRescueTestBase, cls).setup_credentials()
|
|
|
|
@classmethod
|
|
def resource_setup(cls):
|
|
super(ServerRescueTestBase, cls).resource_setup()
|
|
|
|
password = data_utils.rand_password()
|
|
server = cls.create_test_server(adminPass=password,
|
|
wait_until='ACTIVE')
|
|
cls.servers_client.rescue_server(server['id'], adminPass=password)
|
|
waiters.wait_for_server_status(cls.servers_client, server['id'],
|
|
'RESCUE')
|
|
cls.rescued_server_id = server['id']
|
|
|
|
|
|
class ServerRescueTestJSON(ServerRescueTestBase):
|
|
|
|
@decorators.idempotent_id('fd032140-714c-42e4-a8fd-adcd8df06be6')
|
|
def test_rescue_unrescue_instance(self):
|
|
password = data_utils.rand_password()
|
|
server = self.create_test_server(adminPass=password,
|
|
wait_until='ACTIVE')
|
|
self.servers_client.rescue_server(server['id'], adminPass=password)
|
|
waiters.wait_for_server_status(self.servers_client, server['id'],
|
|
'RESCUE')
|
|
self.servers_client.unrescue_server(server['id'])
|
|
waiters.wait_for_server_status(self.servers_client, server['id'],
|
|
'ACTIVE')
|
|
|
|
|
|
class ServerRescueTestJSONUnderV235(ServerRescueTestBase):
|
|
|
|
max_microversion = '2.35'
|
|
|
|
# TODO(zhufl): After 2.35 we should switch to neutron client to create
|
|
# floating ip, but that will need admin credential, so the testcases will
|
|
# have to be added in somewhere in admin directory.
|
|
|
|
@decorators.idempotent_id('4842e0cf-e87d-4d9d-b61f-f4791da3cacc')
|
|
@testtools.skipUnless(CONF.network.public_network_id,
|
|
'The public_network_id option must be specified.')
|
|
@testtools.skipUnless(CONF.network_feature_enabled.floating_ips,
|
|
"Floating ips are not available")
|
|
def test_rescued_vm_associate_dissociate_floating_ip(self):
|
|
# Association of floating IP to a rescued vm
|
|
floating_ip_body = self.floating_ips_client.create_floating_ip(
|
|
pool=CONF.network.floating_network_name)['floating_ip']
|
|
self.addCleanup(self.floating_ips_client.delete_floating_ip,
|
|
floating_ip_body['id'])
|
|
|
|
self.floating_ips_client.associate_floating_ip_to_server(
|
|
str(floating_ip_body['ip']).strip(), self.rescued_server_id)
|
|
|
|
# Disassociation of floating IP that was associated in this method
|
|
self.floating_ips_client.disassociate_floating_ip_from_server(
|
|
str(floating_ip_body['ip']).strip(), self.rescued_server_id)
|
|
|
|
@decorators.idempotent_id('affca41f-7195-492d-8065-e09eee245404')
|
|
def test_rescued_vm_add_remove_security_group(self):
|
|
# Add Security group
|
|
sg = self.create_security_group()
|
|
self.servers_client.add_security_group(self.rescued_server_id,
|
|
name=sg['name'])
|
|
|
|
# Delete Security group
|
|
self.servers_client.remove_security_group(self.rescued_server_id,
|
|
name=sg['name'])
|
|
|
|
|
|
class ServerStableDeviceRescueTest(base.BaseV2ComputeTest):
|
|
create_default_network = True
|
|
|
|
@classmethod
|
|
def skip_checks(self):
|
|
super(ServerStableDeviceRescueTest, self).skip_checks()
|
|
if not CONF.compute_feature_enabled.rescue:
|
|
msg = "Server rescue not available."
|
|
raise self.skipException(msg)
|
|
if not CONF.compute_feature_enabled.stable_rescue:
|
|
msg = "Stable rescue not available."
|
|
raise self.skipException(msg)
|
|
|
|
def _create_server_and_rescue_image(self, hw_rescue_device=None,
|
|
hw_rescue_bus=None):
|
|
server_id = self.create_test_server(wait_until='ACTIVE')['id']
|
|
image_id = self.create_image_from_server(server_id,
|
|
wait_until='ACTIVE')['id']
|
|
if hw_rescue_bus:
|
|
self.images_client.update_image(
|
|
image_id, [dict(add='/hw_rescue_bus',
|
|
value=hw_rescue_bus)])
|
|
if hw_rescue_device:
|
|
self.images_client.update_image(
|
|
image_id, [dict(add='/hw_rescue_device',
|
|
value=hw_rescue_device)])
|
|
return server_id, image_id
|
|
|
|
def _test_stable_device_rescue(self, server_id, rescue_image_id):
|
|
self.servers_client.rescue_server(
|
|
server_id, rescue_image_ref=rescue_image_id)
|
|
waiters.wait_for_server_status(
|
|
self.servers_client, server_id, 'RESCUE')
|
|
self.servers_client.unrescue_server(server_id)
|
|
waiters.wait_for_server_status(
|
|
self.servers_client, server_id, 'ACTIVE')
|
|
|
|
@decorators.idempotent_id('947004c3-e8ef-47d9-9f00-97b74f9eaf96')
|
|
def test_stable_device_rescue_cdrom_ide(self):
|
|
server_id, rescue_image_id = self._create_server_and_rescue_image(
|
|
hw_rescue_device='cdrom', hw_rescue_bus='ide')
|
|
self._test_stable_device_rescue(server_id, rescue_image_id)
|
|
|
|
@decorators.idempotent_id('16865750-1417-4854-bcf7-496e6753c01e')
|
|
def test_stable_device_rescue_disk_virtio(self):
|
|
server_id, rescue_image_id = self._create_server_and_rescue_image(
|
|
hw_rescue_device='disk', hw_rescue_bus='virtio')
|
|
self._test_stable_device_rescue(server_id, rescue_image_id)
|
|
|
|
@decorators.idempotent_id('12340157-6306-4745-bdda-cfa019908b48')
|
|
def test_stable_device_rescue_disk_scsi(self):
|
|
server_id, rescue_image_id = self._create_server_and_rescue_image(
|
|
hw_rescue_device='disk', hw_rescue_bus='scsi')
|
|
self._test_stable_device_rescue(server_id, rescue_image_id)
|
|
|
|
@decorators.idempotent_id('647d04cf-ad35-4956-89ab-b05c5c16f30c')
|
|
def test_stable_device_rescue_disk_usb(self):
|
|
server_id, rescue_image_id = self._create_server_and_rescue_image(
|
|
hw_rescue_device='disk', hw_rescue_bus='usb')
|
|
self._test_stable_device_rescue(server_id, rescue_image_id)
|
|
|
|
@decorators.idempotent_id('a3772b42-00bf-4310-a90b-1cc6fd3e7eab')
|
|
def test_stable_device_rescue_disk_virtio_with_volume_attached(self):
|
|
server_id, rescue_image_id = self._create_server_and_rescue_image(
|
|
hw_rescue_device='disk', hw_rescue_bus='virtio')
|
|
server = self.servers_client.show_server(server_id)['server']
|
|
volume = self.create_volume()
|
|
self.attach_volume(server, volume)
|
|
waiters.wait_for_volume_resource_status(self.volumes_client,
|
|
volume['id'], 'in-use')
|
|
self._test_stable_device_rescue(server_id, rescue_image_id)
|