ZhiQiang Fan | 39f9722 | 2013-09-20 04:49:44 +0800 | [diff] [blame] | 1 | # Copyright 2012 OpenStack Foundation |
Jay Pipes | 13b479b | 2012-06-11 14:52:27 -0400 | [diff] [blame] | 2 | # |
| 3 | # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| 4 | # not use this file except in compliance with the License. You may obtain |
| 5 | # a copy of the License at |
| 6 | # |
| 7 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | # |
| 9 | # Unless required by applicable law or agreed to in writing, software |
| 10 | # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| 11 | # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| 12 | # License for the specific language governing permissions and limitations |
| 13 | # under the License. |
| 14 | |
Soniya Vyas | faa1634 | 2020-01-15 19:34:57 +0530 | [diff] [blame] | 15 | import testtools |
| 16 | |
Sean Dague | 1937d09 | 2013-05-17 16:36:38 -0400 | [diff] [blame] | 17 | from tempest.api.compute import base |
Joe H. Rahme | 66793a3 | 2015-10-09 18:36:26 +0200 | [diff] [blame] | 18 | from tempest.common import waiters |
Matthew Treinish | b0a78fc | 2014-01-29 16:49:12 +0000 | [diff] [blame] | 19 | from tempest import config |
Ken'ichi Ohmichi | 757833a | 2017-03-10 10:30:30 -0800 | [diff] [blame] | 20 | from tempest.lib.common.utils import data_utils |
Ken'ichi Ohmichi | 6c92edf | 2017-01-27 17:32:10 -0800 | [diff] [blame] | 21 | from tempest.lib import decorators |
Soniya Vyas | faa1634 | 2020-01-15 19:34:57 +0530 | [diff] [blame] | 22 | from tempest.lib import exceptions as lib_exceptions |
Jay Pipes | 7f75763 | 2011-12-02 15:53:32 -0500 | [diff] [blame] | 23 | |
Matthew Treinish | b0a78fc | 2014-01-29 16:49:12 +0000 | [diff] [blame] | 24 | CONF = config.CONF |
| 25 | |
Daryl Walleck | 73a9e7a | 2011-11-15 17:43:31 -0600 | [diff] [blame] | 26 | |
ivan-zhu | f2b0050 | 2013-10-18 10:06:52 +0800 | [diff] [blame] | 27 | class ImagesTestJSON(base.BaseV2ComputeTest): |
zhufl | b5603bc | 2020-05-27 09:18:24 +0800 | [diff] [blame] | 28 | """Test server images""" |
| 29 | |
Ghanshyam Mann | 7d91b69 | 2020-03-03 10:21:50 -0600 | [diff] [blame] | 30 | create_default_network = True |
Attila Fazekas | 19044d5 | 2013-02-16 07:35:06 +0100 | [diff] [blame] | 31 | |
| 32 | @classmethod |
Rohan Kanade | 60b7309 | 2015-02-04 17:58:19 +0530 | [diff] [blame] | 33 | def skip_checks(cls): |
| 34 | super(ImagesTestJSON, cls).skip_checks() |
Matthew Treinish | b0a78fc | 2014-01-29 16:49:12 +0000 | [diff] [blame] | 35 | if not CONF.service_available.glance: |
Matthew Treinish | 853ae44 | 2013-07-19 16:36:07 -0400 | [diff] [blame] | 36 | skip_msg = ("%s skipped as glance is not available" % cls.__name__) |
| 37 | raise cls.skipException(skip_msg) |
Adam Gandelman | fbc95ac | 2014-06-19 17:33:43 -0700 | [diff] [blame] | 38 | if not CONF.compute_feature_enabled.snapshot: |
| 39 | skip_msg = ("%s skipped as instance snapshotting is not supported" |
| 40 | % cls.__name__) |
| 41 | raise cls.skipException(skip_msg) |
| 42 | |
Rohan Kanade | 60b7309 | 2015-02-04 17:58:19 +0530 | [diff] [blame] | 43 | @classmethod |
| 44 | def setup_clients(cls): |
| 45 | super(ImagesTestJSON, cls).setup_clients() |
zhufl | 66275c2 | 2018-03-28 15:32:14 +0800 | [diff] [blame] | 46 | if cls.is_requested_microversion_compatible('2.35'): |
| 47 | cls.client = cls.compute_images_client |
| 48 | else: |
| 49 | cls.client = cls.images_client |
Attila Fazekas | 19044d5 | 2013-02-16 07:35:06 +0100 | [diff] [blame] | 50 | |
Ken'ichi Ohmichi | 6c92edf | 2017-01-27 17:32:10 -0800 | [diff] [blame] | 51 | @decorators.idempotent_id('aa06b52b-2db5-4807-b218-9441f75d74e3') |
Liu, Zhi Kun | 3fb3695 | 2013-07-18 00:05:05 +0800 | [diff] [blame] | 52 | def test_delete_saving_image(self): |
zhufl | b5603bc | 2020-05-27 09:18:24 +0800 | [diff] [blame] | 53 | """Test deleting server image while it is in 'SAVING' state""" |
David Kranz | 0fb1429 | 2015-02-11 15:55:20 -0500 | [diff] [blame] | 54 | server = self.create_test_server(wait_until='ACTIVE') |
Liu, Zhi Kun | 3fb3695 | 2013-07-18 00:05:05 +0800 | [diff] [blame] | 55 | self.addCleanup(self.servers_client.delete_server, server['id']) |
zhufl | c3cd87a | 2019-08-06 11:26:57 +0800 | [diff] [blame] | 56 | # wait for server active to avoid conflict when deleting server |
| 57 | # in task_state image_snapshot |
| 58 | self.addCleanup(waiters.wait_for_server_status, self.servers_client, |
| 59 | server['id'], 'ACTIVE') |
Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 60 | snapshot_name = data_utils.rand_name( |
| 61 | prefix=CONF.resource_name_prefix, name='test-snap') |
Soniya Vyas | faa1634 | 2020-01-15 19:34:57 +0530 | [diff] [blame] | 62 | try: |
| 63 | image = self.create_image_from_server(server['id'], |
| 64 | name=snapshot_name, |
| 65 | wait_until='SAVING') |
| 66 | self.client.delete_image(image['id']) |
| 67 | msg = ('The image with ID {image_id} failed to be deleted' |
| 68 | .format(image_id=image['id'])) |
| 69 | self.assertTrue(self.client.is_resource_deleted(image['id']), |
| 70 | msg) |
| 71 | self.assertEqual(snapshot_name, image['name']) |
| 72 | except lib_exceptions.TimeoutException as ex: |
| 73 | # If timeout is reached, we don't need to check state, |
Rajesh Tailor | a85bdb4 | 2024-04-02 12:01:53 +0530 | [diff] [blame] | 74 | # since, it wouldn't be a 'SAVING' state at least and apart from |
Soniya Vyas | faa1634 | 2020-01-15 19:34:57 +0530 | [diff] [blame] | 75 | # it, this testcase doesn't have scope for other state transition |
| 76 | # Hence, skip the test. |
| 77 | raise self.skipException("This test is skipped because " + str(ex)) |
Joe H. Rahme | 66793a3 | 2015-10-09 18:36:26 +0200 | [diff] [blame] | 78 | |
Ken'ichi Ohmichi | 6c92edf | 2017-01-27 17:32:10 -0800 | [diff] [blame] | 79 | @decorators.idempotent_id('aaacd1d0-55a2-4ce8-818a-b5439df8adc9') |
Joe H. Rahme | 66793a3 | 2015-10-09 18:36:26 +0200 | [diff] [blame] | 80 | def test_create_image_from_stopped_server(self): |
zhufl | b5603bc | 2020-05-27 09:18:24 +0800 | [diff] [blame] | 81 | """Test creating server image from stopped server""" |
Joe H. Rahme | 66793a3 | 2015-10-09 18:36:26 +0200 | [diff] [blame] | 82 | server = self.create_test_server(wait_until='ACTIVE') |
| 83 | self.servers_client.stop_server(server['id']) |
| 84 | waiters.wait_for_server_status(self.servers_client, |
| 85 | server['id'], 'SHUTOFF') |
| 86 | self.addCleanup(self.servers_client.delete_server, server['id']) |
Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 87 | snapshot_name = data_utils.rand_name( |
| 88 | prefix=CONF.resource_name_prefix, name='test-snap') |
Joe H. Rahme | 66793a3 | 2015-10-09 18:36:26 +0200 | [diff] [blame] | 89 | image = self.create_image_from_server(server['id'], |
| 90 | name=snapshot_name, |
Bob Ball | 5fe6239 | 2017-02-20 09:51:00 +0000 | [diff] [blame] | 91 | wait_until='ACTIVE', |
| 92 | wait_for_server=False) |
Joe H. Rahme | 66793a3 | 2015-10-09 18:36:26 +0200 | [diff] [blame] | 93 | self.addCleanup(self.client.delete_image, image['id']) |
| 94 | self.assertEqual(snapshot_name, image['name']) |
lianghao | c080786 | 2017-03-06 20:02:15 +0800 | [diff] [blame] | 95 | |
| 96 | @decorators.idempotent_id('71bcb732-0261-11e7-9086-fa163e4fa634') |
Eric Berglund | dde9de4 | 2017-03-22 15:19:48 -0500 | [diff] [blame] | 97 | @testtools.skipUnless(CONF.compute_feature_enabled.pause, |
| 98 | 'Pause is not available.') |
lianghao | c080786 | 2017-03-06 20:02:15 +0800 | [diff] [blame] | 99 | def test_create_image_from_paused_server(self): |
zhufl | b5603bc | 2020-05-27 09:18:24 +0800 | [diff] [blame] | 100 | """Test creating server image from paused server""" |
lianghao | c080786 | 2017-03-06 20:02:15 +0800 | [diff] [blame] | 101 | server = self.create_test_server(wait_until='ACTIVE') |
| 102 | self.servers_client.pause_server(server['id']) |
| 103 | waiters.wait_for_server_status(self.servers_client, |
| 104 | server['id'], 'PAUSED') |
| 105 | self.addCleanup(self.servers_client.delete_server, server['id']) |
| 106 | |
Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 107 | snapshot_name = data_utils.rand_name( |
| 108 | prefix=CONF.resource_name_prefix, name='test-snap') |
lianghao | c080786 | 2017-03-06 20:02:15 +0800 | [diff] [blame] | 109 | image = self.create_image_from_server(server['id'], |
| 110 | name=snapshot_name, |
| 111 | wait_until='ACTIVE', |
| 112 | wait_for_server=False) |
| 113 | self.addCleanup(self.client.delete_image, image['id']) |
| 114 | self.assertEqual(snapshot_name, image['name']) |
| 115 | |
| 116 | @decorators.idempotent_id('8ca07fec-0262-11e7-907e-fa163e4fa634') |
Eric Berglund | dde9de4 | 2017-03-22 15:19:48 -0500 | [diff] [blame] | 117 | @testtools.skipUnless(CONF.compute_feature_enabled.suspend, |
| 118 | 'Suspend is not available.') |
lianghao | c080786 | 2017-03-06 20:02:15 +0800 | [diff] [blame] | 119 | def test_create_image_from_suspended_server(self): |
zhufl | b5603bc | 2020-05-27 09:18:24 +0800 | [diff] [blame] | 120 | """Test creating server image from suspended server""" |
lianghao | c080786 | 2017-03-06 20:02:15 +0800 | [diff] [blame] | 121 | server = self.create_test_server(wait_until='ACTIVE') |
| 122 | self.servers_client.suspend_server(server['id']) |
| 123 | waiters.wait_for_server_status(self.servers_client, |
| 124 | server['id'], 'SUSPENDED') |
| 125 | self.addCleanup(self.servers_client.delete_server, server['id']) |
| 126 | |
Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 127 | snapshot_name = data_utils.rand_name( |
| 128 | prefix=CONF.resource_name_prefix, name='test-snap') |
lianghao | c080786 | 2017-03-06 20:02:15 +0800 | [diff] [blame] | 129 | image = self.create_image_from_server(server['id'], |
| 130 | name=snapshot_name, |
| 131 | wait_until='ACTIVE', |
| 132 | wait_for_server=False) |
| 133 | self.addCleanup(self.client.delete_image, image['id']) |
| 134 | self.assertEqual(snapshot_name, image['name']) |
Dan Smith | 6714b65 | 2022-10-05 15:05:31 -0700 | [diff] [blame] | 135 | |
| 136 | @decorators.idempotent_id('f3cac456-e3fe-4183-a7a7-a59f7f017088') |
| 137 | def test_create_server_from_snapshot(self): |
| 138 | # Create one server normally |
| 139 | server = self.create_test_server(wait_until='ACTIVE') |
| 140 | self.addCleanup(self.servers_client.delete_server, server['id']) |
| 141 | |
| 142 | # Snapshot it |
Martin Kopec | 213d0a4 | 2023-11-30 10:28:14 +0100 | [diff] [blame] | 143 | snapshot_name = data_utils.rand_name( |
| 144 | prefix=CONF.resource_name_prefix, name='test-snap') |
Dan Smith | 6714b65 | 2022-10-05 15:05:31 -0700 | [diff] [blame] | 145 | image = self.create_image_from_server(server['id'], |
| 146 | name=snapshot_name, |
| 147 | wait_until='ACTIVE', |
| 148 | wait_for_server=False) |
| 149 | self.addCleanup(self.client.delete_image, image['id']) |
| 150 | |
| 151 | # Try to create another server from that snapshot |
| 152 | server2 = self.create_test_server(wait_until='ACTIVE', |
| 153 | image_id=image['id']) |
| 154 | |
| 155 | # Delete server 2 before we finish otherwise we'll race with |
| 156 | # the cleanup which tries to delete the image before the |
| 157 | # server is gone. |
| 158 | self.servers_client.delete_server(server2['id']) |
| 159 | waiters.wait_for_server_termination(self.servers_client, server2['id']) |