nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 1 | # Copyright 2013 Hewlett-Packard Development Company, L.P. |
| 2 | # All Rights Reserved. |
| 3 | # |
| 4 | # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| 5 | # not use this file except in compliance with the License. You may obtain |
| 6 | # a copy of the License at |
| 7 | # |
| 8 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | # |
| 10 | # Unless required by applicable law or agreed to in writing, software |
| 11 | # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| 12 | # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| 13 | # License for the specific language governing permissions and limitations |
| 14 | # under the License. |
| 15 | |
zhufl | 6b7040a | 2017-01-18 16:38:34 +0800 | [diff] [blame] | 16 | import testtools |
| 17 | |
Sean Dague | 1937d09 | 2013-05-17 16:36:38 -0400 | [diff] [blame] | 18 | from tempest.api.compute import base |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 19 | from tempest.common import compute |
Slawek Kaplonski | bc360ae | 2020-11-13 10:09:43 +0100 | [diff] [blame] | 20 | from tempest.common import utils |
Ken'ichi Ohmichi | 0eb153c | 2015-07-13 02:18:25 +0000 | [diff] [blame] | 21 | from tempest.common import waiters |
Adam Gandelman | 2e37b4f | 2014-06-18 17:34:21 -0700 | [diff] [blame] | 22 | from tempest import config |
Ken'ichi Ohmichi | 757833a | 2017-03-10 10:30:30 -0800 | [diff] [blame] | 23 | from tempest.lib.common.utils import data_utils |
Ken'ichi Ohmichi | 14b0ae1 | 2017-01-27 17:18:52 -0800 | [diff] [blame] | 24 | from tempest.lib import decorators |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 25 | |
Adam Gandelman | 2e37b4f | 2014-06-18 17:34:21 -0700 | [diff] [blame] | 26 | CONF = config.CONF |
| 27 | |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 28 | |
zhufl | 3cf7aa2 | 2018-08-02 10:38:31 +0800 | [diff] [blame] | 29 | class ServerRescueTestBase(base.BaseV2ComputeTest): |
Ghanshyam Mann | 2c22e28 | 2020-04-21 21:37:54 -0500 | [diff] [blame] | 30 | create_default_network = True |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 31 | |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 32 | @classmethod |
Emily Hugenbruch | e7991d9 | 2014-12-12 16:53:36 +0000 | [diff] [blame] | 33 | def skip_checks(cls): |
zhufl | 3cf7aa2 | 2018-08-02 10:38:31 +0800 | [diff] [blame] | 34 | super(ServerRescueTestBase, cls).skip_checks() |
Adam Gandelman | 2e37b4f | 2014-06-18 17:34:21 -0700 | [diff] [blame] | 35 | if not CONF.compute_feature_enabled.rescue: |
| 36 | msg = "Server rescue not available." |
| 37 | raise cls.skipException(msg) |
| 38 | |
Emily Hugenbruch | e7991d9 | 2014-12-12 16:53:36 +0000 | [diff] [blame] | 39 | @classmethod |
| 40 | def setup_credentials(cls): |
Attila Fazekas | 6909597 | 2014-02-06 16:46:18 +0100 | [diff] [blame] | 41 | cls.set_network_resources(network=True, subnet=True, router=True) |
zhufl | 3cf7aa2 | 2018-08-02 10:38:31 +0800 | [diff] [blame] | 42 | super(ServerRescueTestBase, cls).setup_credentials() |
Emily Hugenbruch | e7991d9 | 2014-12-12 16:53:36 +0000 | [diff] [blame] | 43 | |
| 44 | @classmethod |
| 45 | def resource_setup(cls): |
zhufl | 3cf7aa2 | 2018-08-02 10:38:31 +0800 | [diff] [blame] | 46 | super(ServerRescueTestBase, cls).resource_setup() |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 47 | |
zhufl | 0c042a5 | 2017-05-10 16:24:00 +0800 | [diff] [blame] | 48 | password = data_utils.rand_password() |
| 49 | server = cls.create_test_server(adminPass=password, |
zhufl | 3b9e42e | 2017-02-24 15:59:01 +0800 | [diff] [blame] | 50 | wait_until='ACTIVE') |
zhufl | 0c042a5 | 2017-05-10 16:24:00 +0800 | [diff] [blame] | 51 | cls.servers_client.rescue_server(server['id'], adminPass=password) |
| 52 | waiters.wait_for_server_status(cls.servers_client, server['id'], |
| 53 | 'RESCUE') |
| 54 | cls.rescued_server_id = server['id'] |
Matthew Treinish | 149142e | 2013-03-20 16:25:55 -0400 | [diff] [blame] | 55 | |
zhufl | 3cf7aa2 | 2018-08-02 10:38:31 +0800 | [diff] [blame] | 56 | |
| 57 | class ServerRescueTestJSON(ServerRescueTestBase): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 58 | """Test server rescue""" |
zhufl | 3cf7aa2 | 2018-08-02 10:38:31 +0800 | [diff] [blame] | 59 | |
Ken'ichi Ohmichi | 14b0ae1 | 2017-01-27 17:18:52 -0800 | [diff] [blame] | 60 | @decorators.idempotent_id('fd032140-714c-42e4-a8fd-adcd8df06be6') |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 61 | def test_rescue_unrescue_instance(self): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 62 | """Test rescue/unrescue server""" |
zhufl | 0c042a5 | 2017-05-10 16:24:00 +0800 | [diff] [blame] | 63 | password = data_utils.rand_password() |
| 64 | server = self.create_test_server(adminPass=password, |
| 65 | wait_until='ACTIVE') |
| 66 | self.servers_client.rescue_server(server['id'], adminPass=password) |
| 67 | waiters.wait_for_server_status(self.servers_client, server['id'], |
Ken'ichi Ohmichi | 0eb153c | 2015-07-13 02:18:25 +0000 | [diff] [blame] | 68 | 'RESCUE') |
zhufl | 0c042a5 | 2017-05-10 16:24:00 +0800 | [diff] [blame] | 69 | self.servers_client.unrescue_server(server['id']) |
| 70 | waiters.wait_for_server_status(self.servers_client, server['id'], |
Ken'ichi Ohmichi | 0eb153c | 2015-07-13 02:18:25 +0000 | [diff] [blame] | 71 | 'ACTIVE') |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 72 | |
zhufl | 3cf7aa2 | 2018-08-02 10:38:31 +0800 | [diff] [blame] | 73 | |
| 74 | class ServerRescueTestJSONUnderV235(ServerRescueTestBase): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 75 | """Test server rescue with compute microversion less than 2.36""" |
zhufl | 3cf7aa2 | 2018-08-02 10:38:31 +0800 | [diff] [blame] | 76 | |
| 77 | max_microversion = '2.35' |
| 78 | |
| 79 | # TODO(zhufl): After 2.35 we should switch to neutron client to create |
| 80 | # floating ip, but that will need admin credential, so the testcases will |
| 81 | # have to be added in somewhere in admin directory. |
| 82 | |
Ken'ichi Ohmichi | 14b0ae1 | 2017-01-27 17:18:52 -0800 | [diff] [blame] | 83 | @decorators.idempotent_id('4842e0cf-e87d-4d9d-b61f-f4791da3cacc') |
zhufl | 6b7040a | 2017-01-18 16:38:34 +0800 | [diff] [blame] | 84 | @testtools.skipUnless(CONF.network.public_network_id, |
| 85 | 'The public_network_id option must be specified.') |
Matthew Treinish | 3312de3 | 2017-05-19 12:08:17 -0400 | [diff] [blame] | 86 | @testtools.skipUnless(CONF.network_feature_enabled.floating_ips, |
| 87 | "Floating ips are not available") |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 88 | def test_rescued_vm_associate_dissociate_floating_ip(self): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 89 | """Test associate/dissociate floating ip for rescued server""" |
zhufl | 0c042a5 | 2017-05-10 16:24:00 +0800 | [diff] [blame] | 90 | floating_ip_body = self.floating_ips_client.create_floating_ip( |
| 91 | pool=CONF.network.floating_network_name)['floating_ip'] |
| 92 | self.addCleanup(self.floating_ips_client.delete_floating_ip, |
| 93 | floating_ip_body['id']) |
| 94 | |
| 95 | self.floating_ips_client.associate_floating_ip_to_server( |
| 96 | str(floating_ip_body['ip']).strip(), self.rescued_server_id) |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 97 | |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 98 | # Disassociation of floating IP that was associated in this method |
zhufl | 0c042a5 | 2017-05-10 16:24:00 +0800 | [diff] [blame] | 99 | self.floating_ips_client.disassociate_floating_ip_from_server( |
| 100 | str(floating_ip_body['ip']).strip(), self.rescued_server_id) |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 101 | |
Ken'ichi Ohmichi | 14b0ae1 | 2017-01-27 17:18:52 -0800 | [diff] [blame] | 102 | @decorators.idempotent_id('affca41f-7195-492d-8065-e09eee245404') |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 103 | def test_rescued_vm_add_remove_security_group(self): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 104 | """Test add/remove security group to for rescued server""" |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 105 | # Add Security group |
zhufl | 0c042a5 | 2017-05-10 16:24:00 +0800 | [diff] [blame] | 106 | sg = self.create_security_group() |
| 107 | self.servers_client.add_security_group(self.rescued_server_id, |
| 108 | name=sg['name']) |
nithya-ganesan | e6a36c8 | 2013-02-15 14:38:27 +0000 | [diff] [blame] | 109 | |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 110 | # Delete Security group |
zhufl | 0c042a5 | 2017-05-10 16:24:00 +0800 | [diff] [blame] | 111 | self.servers_client.remove_security_group(self.rescued_server_id, |
| 112 | name=sg['name']) |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 113 | |
| 114 | |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 115 | class BaseServerStableDeviceRescueTest(base.BaseV2ComputeTest): |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 116 | |
| 117 | @classmethod |
zhufl | 40e5eaa | 2020-05-21 12:54:16 +0800 | [diff] [blame] | 118 | def skip_checks(cls): |
| 119 | super(BaseServerStableDeviceRescueTest, cls).skip_checks() |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 120 | if not CONF.compute_feature_enabled.rescue: |
| 121 | msg = "Server rescue not available." |
zhufl | 40e5eaa | 2020-05-21 12:54:16 +0800 | [diff] [blame] | 122 | raise cls.skipException(msg) |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 123 | if not CONF.compute_feature_enabled.stable_rescue: |
| 124 | msg = "Stable rescue not available." |
zhufl | 40e5eaa | 2020-05-21 12:54:16 +0800 | [diff] [blame] | 125 | raise cls.skipException(msg) |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 126 | |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 127 | @classmethod |
| 128 | def setup_credentials(cls): |
| 129 | cls.set_network_resources(network=True, subnet=True, router=True, |
| 130 | dhcp=True) |
| 131 | super(BaseServerStableDeviceRescueTest, cls).setup_credentials() |
| 132 | |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 133 | def _create_server_and_rescue_image(self, hw_rescue_device=None, |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 134 | hw_rescue_bus=None, |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 135 | block_device_mapping_v2=None, |
| 136 | validatable=False, |
| 137 | validation_resources=None, |
| 138 | wait_until='ACTIVE'): |
| 139 | server = self.create_test_server( |
| 140 | wait_until=wait_until, |
| 141 | validatable=validatable, |
| 142 | validation_resources=validation_resources) |
Lee Yarwood | 2fd745f | 2020-05-05 11:24:56 +0100 | [diff] [blame] | 143 | image_id = self.create_image_from_server( |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 144 | server['id'], wait_until='ACTIVE')['id'] |
Lee Yarwood | 2fd745f | 2020-05-05 11:24:56 +0100 | [diff] [blame] | 145 | |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 146 | if block_device_mapping_v2: |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 147 | server = self.create_test_server( |
| 148 | wait_until=wait_until, |
| 149 | validatable=validatable, |
| 150 | validation_resources=validation_resources, |
| 151 | block_device_mapping_v2=block_device_mapping_v2) |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 152 | |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 153 | if hw_rescue_bus: |
| 154 | self.images_client.update_image( |
| 155 | image_id, [dict(add='/hw_rescue_bus', |
| 156 | value=hw_rescue_bus)]) |
| 157 | if hw_rescue_device: |
| 158 | self.images_client.update_image( |
| 159 | image_id, [dict(add='/hw_rescue_device', |
| 160 | value=hw_rescue_device)]) |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 161 | return server, image_id |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 162 | |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 163 | def _test_stable_device_rescue( |
| 164 | self, server, rescue_image_id, |
| 165 | validation_resources=None): |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 166 | self.servers_client.rescue_server( |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 167 | server['id'], rescue_image_ref=rescue_image_id) |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 168 | waiters.wait_for_server_status( |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 169 | self.servers_client, server['id'], 'RESCUE') |
| 170 | self.servers_client.unrescue_server(server['id']) |
| 171 | # NOTE(gmann) In next addCleanup, server unrescue is called before the |
| 172 | # detach volume is called in cleanup (added by self.attach_volume() |
| 173 | # method) so to make sure server is ready before detach operation, we |
| 174 | # need to perform ssh on it, more details are in bug#1960346. |
| 175 | if validation_resources and CONF.validation.run_validation: |
| 176 | tenant_network = self.get_tenant_network() |
| 177 | compute.wait_for_ssh_or_ping( |
| 178 | server, self.os_primary, tenant_network, |
| 179 | True, validation_resources, "SSHABLE", True) |
| 180 | else: |
| 181 | waiters.wait_for_server_status( |
| 182 | self.servers_client, server['id'], 'ACTIVE') |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 183 | |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 184 | |
Lee Yarwood | 56a446d | 2021-02-15 13:34:35 +0000 | [diff] [blame] | 185 | class ServerStableDeviceRescueTestIDE(BaseServerStableDeviceRescueTest): |
| 186 | """Test rescuing server using an IDE device for the rescue disk""" |
| 187 | |
| 188 | @classmethod |
| 189 | def skip_checks(cls): |
| 190 | super().skip_checks() |
| 191 | if not CONF.compute_feature_enabled.ide_bus: |
| 192 | raise cls.skipException("IDE bus not available.") |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 193 | |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 194 | @decorators.idempotent_id('947004c3-e8ef-47d9-9f00-97b74f9eaf96') |
ricolin | 9d2effc | 2021-04-04 14:08:29 +0800 | [diff] [blame] | 195 | @testtools.skipIf("aarch64" in CONF.scenario.img_file, |
| 196 | "Aarch64 does not support ide bus for cdrom") |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 197 | def test_stable_device_rescue_cdrom_ide(self): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 198 | """Test rescuing server with cdrom and ide as the rescue disk""" |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 199 | server, rescue_image_id = self._create_server_and_rescue_image( |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 200 | hw_rescue_device='cdrom', hw_rescue_bus='ide') |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 201 | self._test_stable_device_rescue(server, rescue_image_id) |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 202 | |
Lee Yarwood | 56a446d | 2021-02-15 13:34:35 +0000 | [diff] [blame] | 203 | |
| 204 | class ServerStableDeviceRescueTest(BaseServerStableDeviceRescueTest): |
| 205 | """Test rescuing server specifying type of device for the rescue disk""" |
| 206 | |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 207 | @decorators.idempotent_id('16865750-1417-4854-bcf7-496e6753c01e') |
| 208 | def test_stable_device_rescue_disk_virtio(self): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 209 | """Test rescuing server with disk and virtio as the rescue disk""" |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 210 | server, rescue_image_id = self._create_server_and_rescue_image( |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 211 | hw_rescue_device='disk', hw_rescue_bus='virtio') |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 212 | self._test_stable_device_rescue(server, rescue_image_id) |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 213 | |
| 214 | @decorators.idempotent_id('12340157-6306-4745-bdda-cfa019908b48') |
| 215 | def test_stable_device_rescue_disk_scsi(self): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 216 | """Test rescuing server with disk and scsi as the rescue disk""" |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 217 | server, rescue_image_id = self._create_server_and_rescue_image( |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 218 | hw_rescue_device='disk', hw_rescue_bus='scsi') |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 219 | self._test_stable_device_rescue(server, rescue_image_id) |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 220 | |
| 221 | @decorators.idempotent_id('647d04cf-ad35-4956-89ab-b05c5c16f30c') |
| 222 | def test_stable_device_rescue_disk_usb(self): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 223 | """Test rescuing server with disk and usb as the rescue disk""" |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 224 | server, rescue_image_id = self._create_server_and_rescue_image( |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 225 | hw_rescue_device='disk', hw_rescue_bus='usb') |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 226 | self._test_stable_device_rescue(server, rescue_image_id) |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 227 | |
| 228 | @decorators.idempotent_id('a3772b42-00bf-4310-a90b-1cc6fd3e7eab') |
Slawek Kaplonski | bc360ae | 2020-11-13 10:09:43 +0100 | [diff] [blame] | 229 | @utils.services('volume') |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 230 | def test_stable_device_rescue_disk_virtio_with_volume_attached(self): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 231 | """Test rescuing server with volume attached |
| 232 | |
| 233 | Attach a volume to the server and then rescue the server with disk |
| 234 | and virtio as the rescue disk. |
| 235 | """ |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 236 | # This test just check detach fail and does not |
| 237 | # perfom the detach operation but in cleanup from |
| 238 | # self.attach_volume() it will try to detach the server |
| 239 | # after unrescue the server. Due to that we need to make |
| 240 | # server SSHable before it try to detach, more details are |
| 241 | # in bug#1960346 |
Dan Smith | 5e2019f | 2023-07-21 10:38:59 -0700 | [diff] [blame] | 242 | volume = self.create_volume(wait_for_available=False) |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 243 | validation_resources = self.get_class_validation_resources( |
| 244 | self.os_primary) |
| 245 | server, rescue_image_id = self._create_server_and_rescue_image( |
| 246 | hw_rescue_device='disk', hw_rescue_bus='virtio', validatable=True, |
| 247 | validation_resources=validation_resources, wait_until="SSHABLE") |
| 248 | server = self.servers_client.show_server(server['id'])['server'] |
Dan Smith | 5e2019f | 2023-07-21 10:38:59 -0700 | [diff] [blame] | 249 | waiters.wait_for_volume_resource_status(self.volumes_client, |
| 250 | volume['id'], 'available') |
Lee Yarwood | c0ad55c | 2019-12-06 13:39:19 +0000 | [diff] [blame] | 251 | self.attach_volume(server, volume) |
| 252 | waiters.wait_for_volume_resource_status(self.volumes_client, |
| 253 | volume['id'], 'in-use') |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 254 | self._test_stable_device_rescue( |
| 255 | server, rescue_image_id, |
| 256 | validation_resources=validation_resources) |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 257 | |
| 258 | |
| 259 | class ServerBootFromVolumeStableRescueTest(BaseServerStableDeviceRescueTest): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 260 | """Test rescuing server specifying type of device for the rescue disk |
| 261 | |
| 262 | Test rescuing server specifying type of device for the rescue disk with |
| 263 | compute microversion greater than 2.86. |
| 264 | """ |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 265 | |
| 266 | min_microversion = '2.87' |
| 267 | |
Slawek Kaplonski | bc360ae | 2020-11-13 10:09:43 +0100 | [diff] [blame] | 268 | @classmethod |
| 269 | def skip_checks(cls): |
| 270 | super(ServerBootFromVolumeStableRescueTest, cls).skip_checks() |
| 271 | if not CONF.service_available.cinder: |
| 272 | skip_msg = ("%s skipped as Cinder is not available" % cls.__name__) |
| 273 | raise cls.skipException(skip_msg) |
| 274 | |
Lee Yarwood | 2fd745f | 2020-05-05 11:24:56 +0100 | [diff] [blame] | 275 | @decorators.attr(type='slow') |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 276 | @decorators.idempotent_id('48f123cb-922a-4065-8db6-b9a9074a556b') |
| 277 | def test_stable_device_rescue_bfv_blank_volume(self): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 278 | """Test rescuing server with blank volume as block_device_mapping_v2 |
| 279 | |
| 280 | Create a server with block_device_mapping_v2 with blank volume, |
| 281 | then rescue the server with disk and virtio as the rescue disk. |
| 282 | """ |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 283 | block_device_mapping_v2 = [{ |
| 284 | "boot_index": "0", |
| 285 | "source_type": "blank", |
Martin Kopec | abda871 | 2020-05-11 15:31:13 +0000 | [diff] [blame] | 286 | "volume_size": CONF.volume.volume_size, |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 287 | "destination_type": "volume"}] |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 288 | server, rescue_image_id = self._create_server_and_rescue_image( |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 289 | hw_rescue_device='disk', hw_rescue_bus='virtio', |
| 290 | block_device_mapping_v2=block_device_mapping_v2) |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 291 | self._test_stable_device_rescue(server, rescue_image_id) |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 292 | |
Lee Yarwood | 2fd745f | 2020-05-05 11:24:56 +0100 | [diff] [blame] | 293 | @decorators.attr(type='slow') |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 294 | @decorators.idempotent_id('e4636333-c928-40fc-98b7-70a23eef4224') |
| 295 | def test_stable_device_rescue_bfv_image_volume(self): |
zhufl | 735e169 | 2020-08-13 16:46:50 +0800 | [diff] [blame] | 296 | """Test rescuing server with blank volume as block_device_mapping_v2 |
| 297 | |
| 298 | Create a server with block_device_mapping_v2 with image volume, |
| 299 | then rescue the server with disk and virtio as the rescue disk. |
| 300 | """ |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 301 | block_device_mapping_v2 = [{ |
| 302 | "boot_index": "0", |
| 303 | "source_type": "image", |
Martin Kopec | abda871 | 2020-05-11 15:31:13 +0000 | [diff] [blame] | 304 | "volume_size": CONF.volume.volume_size, |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 305 | "uuid": CONF.compute.image_ref, |
| 306 | "destination_type": "volume"}] |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 307 | server, rescue_image_id = self._create_server_and_rescue_image( |
Lee Yarwood | 2ad7ca4 | 2020-01-07 13:06:25 +0000 | [diff] [blame] | 308 | hw_rescue_device='disk', hw_rescue_bus='virtio', |
| 309 | block_device_mapping_v2=block_device_mapping_v2) |
Ghanshyam Mann | 7304e3a | 2022-03-18 13:58:25 -0500 | [diff] [blame] | 310 | self._test_stable_device_rescue(server, rescue_image_id) |