blob: 66763581033def7ad24ca5332afdd455bccbd225 [file] [log] [blame]
ZhiQiang Fan39f97222013-09-20 04:49:44 +08001# Copyright 2012 OpenStack Foundation
Jay Pipes13b479b2012-06-11 14:52:27 -04002# 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
Rohit Karajgidc300b22012-05-04 08:11:00 -070016import sys
Jay Pipes13b479b2012-06-11 14:52:27 -040017
Eric Windischb5538072014-03-09 23:47:35 -040018import testtools
19
Sean Dague1937d092013-05-17 16:36:38 -040020from tempest.api.compute import base
ghanshyam017b5fe2016-04-15 18:49:26 +090021from tempest.common import compute
Andrea Frittolicd368412017-08-14 21:37:56 +010022from tempest.common import utils
Ken'ichi Ohmichi0eb153c2015-07-13 02:18:25 +000023from tempest.common import waiters
Matthew Treinishb0a78fc2014-01-29 16:49:12 +000024from tempest import config
Ken'ichi Ohmichi757833a2017-03-10 10:30:30 -080025from tempest.lib.common.utils import data_utils
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -080026from tempest.lib import decorators
Andrea Frittoli (andreaf)db9672e2016-02-23 14:07:24 -050027from tempest.lib import exceptions as lib_exc
Daryl Walleckadea1fa2011-11-15 18:36:39 -060028
Matthew Treinishb0a78fc2014-01-29 16:49:12 +000029CONF = config.CONF
30
Daryl Walleckadea1fa2011-11-15 18:36:39 -060031
ivan-zhuf2b00502013-10-18 10:06:52 +080032class ServersNegativeTestJSON(base.BaseV2ComputeTest):
zhuflb5603bc2020-05-27 09:18:24 +080033 """Negative tests of servers"""
34
Eric Friedbfaa50f2020-01-09 12:04:54 -060035 create_default_network = True
Daryl Walleckadea1fa2011-11-15 18:36:39 -060036
Ken'ichi Ohmichida306502013-10-08 23:44:55 +090037 def setUp(self):
38 super(ServersNegativeTestJSON, self).setUp()
39 try:
Ken'ichi Ohmichi0eb153c2015-07-13 02:18:25 +000040 waiters.wait_for_server_status(self.client, self.server_id,
41 'ACTIVE')
Ken'ichi Ohmichida306502013-10-08 23:44:55 +090042 except Exception:
zhuflba0e5532017-09-13 10:51:07 +080043 self.__class__.server_id = self.recreate_server(self.server_id)
Ken'ichi Ohmichida306502013-10-08 23:44:55 +090044
Attila Fazekas305e65b2013-10-29 13:23:07 +010045 def tearDown(self):
Attila Fazekas305e65b2013-10-29 13:23:07 +010046 super(ServersNegativeTestJSON, self).tearDown()
zhufle913e462018-07-25 17:16:10 +080047 # NOTE(zhufl): Because server_check_teardown will raise Exception
48 # which will prevent other cleanup steps from being executed, so
49 # server_check_teardown should be called after super's tearDown.
50 self.server_check_teardown()
Attila Fazekas305e65b2013-10-29 13:23:07 +010051
Daryl Walleckadea1fa2011-11-15 18:36:39 -060052 @classmethod
Rohan Kanade60b73092015-02-04 17:58:19 +053053 def setup_clients(cls):
54 super(ServersNegativeTestJSON, cls).setup_clients()
55 cls.client = cls.servers_client
Rohan Kanade60b73092015-02-04 17:58:19 +053056
57 @classmethod
Andrea Frittoli50bb80d2014-09-15 12:34:27 +010058 def resource_setup(cls):
59 super(ServersNegativeTestJSON, cls).resource_setup()
David Kranz0fb14292015-02-11 15:55:20 -050060 server = cls.create_test_server(wait_until='ACTIVE')
Ken'ichi Ohmichida306502013-10-08 23:44:55 +090061 cls.server_id = server['id']
Daryl Walleckadea1fa2011-11-15 18:36:39 -060062
zhufl406e9132017-05-09 16:21:54 +080063 server = cls.create_test_server()
64 cls.client.delete_server(server['id'])
65 waiters.wait_for_server_termination(cls.client, server['id'])
66 cls.deleted_server_id = server['id']
67
Jordan Pittier3b46d272017-04-12 16:17:28 +020068 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -080069 @decorators.idempotent_id('dbbfd247-c40c-449e-8f6c-d2aa7c7da7cf')
Daryl Walleckadea1fa2011-11-15 18:36:39 -060070 def test_server_name_blank(self):
zhuflb5603bc2020-05-27 09:18:24 +080071 """Creating a server with name parameter empty should fail"""
Masayuki Igawa4b29e472015-02-16 10:41:54 +090072 self.assertRaises(lib_exc.BadRequest,
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +090073 self.create_test_server,
Sean Dague22897e12013-02-25 17:54:09 -050074 name='')
Daryl Walleckadea1fa2011-11-15 18:36:39 -060075
Jordan Pittier3b46d272017-04-12 16:17:28 +020076 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -080077 @decorators.idempotent_id('b8a7235e-5246-4a8f-a08e-b34877c6586f')
Takeaki Matsumotod7e04b22015-09-04 15:13:38 +090078 @testtools.skipUnless(CONF.compute_feature_enabled.personality,
79 'Nova personality feature disabled')
Daryl Walleckadea1fa2011-11-15 18:36:39 -060080 def test_personality_file_contents_not_encoded(self):
zhuflb5603bc2020-05-27 09:18:24 +080081 """Using an unencoded injected file to create server should fail"""
Daryl Walleckadea1fa2011-11-15 18:36:39 -060082 file_contents = 'This is a test file.'
Sean Dague9b669e32012-12-13 18:40:08 -050083 person = [{'path': '/etc/testfile.txt',
84 'contents': file_contents}]
Daryl Walleckadea1fa2011-11-15 18:36:39 -060085
Masayuki Igawa4b29e472015-02-16 10:41:54 +090086 self.assertRaises(lib_exc.BadRequest,
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +090087 self.create_test_server,
donald-ngo18edb812013-02-22 11:37:15 -080088 personality=person)
Daryl Walleckadea1fa2011-11-15 18:36:39 -060089
Jordan Pittier3b46d272017-04-12 16:17:28 +020090 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -080091 @decorators.idempotent_id('fcba1052-0a50-4cf3-b1ac-fae241edf02f')
Daryl Walleckadea1fa2011-11-15 18:36:39 -060092 def test_create_with_invalid_image(self):
zhuflb5603bc2020-05-27 09:18:24 +080093 """Creating a server with an unknown image should fail"""
Masayuki Igawa4b29e472015-02-16 10:41:54 +090094 self.assertRaises(lib_exc.BadRequest,
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +090095 self.create_test_server,
Sean Dague22897e12013-02-25 17:54:09 -050096 image_id=-1)
Daryl Walleckadea1fa2011-11-15 18:36:39 -060097
Jordan Pittier3b46d272017-04-12 16:17:28 +020098 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -080099 @decorators.idempotent_id('18f5227f-d155-4429-807c-ccb103887537')
Daryl Walleckadea1fa2011-11-15 18:36:39 -0600100 def test_create_with_invalid_flavor(self):
zhuflb5603bc2020-05-27 09:18:24 +0800101 """Creating a server with an unknown flavor should fail"""
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900102 self.assertRaises(lib_exc.BadRequest,
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +0900103 self.create_test_server,
Sean Dague22897e12013-02-25 17:54:09 -0500104 flavor=-1,)
Daryl Walleckadea1fa2011-11-15 18:36:39 -0600105
Jordan Pittier3b46d272017-04-12 16:17:28 +0200106 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800107 @decorators.idempotent_id('7f70a4d1-608f-4794-9e56-cb182765972c')
Daryl Walleckadea1fa2011-11-15 18:36:39 -0600108 def test_invalid_access_ip_v4_address(self):
zhuflb5603bc2020-05-27 09:18:24 +0800109 """Creating a server with invalid ipv4 ip address should fail
donald-ngo18edb812013-02-22 11:37:15 -0800110
zhuflb5603bc2020-05-27 09:18:24 +0800111 An access IPv4 address must match a valid address pattern
112 """
Sean Dague9b669e32012-12-13 18:40:08 -0500113 IPv4 = '1.1.1.1.1.1'
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900114 self.assertRaises(lib_exc.BadRequest,
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +0900115 self.create_test_server, accessIPv4=IPv4)
Daryl Walleckadea1fa2011-11-15 18:36:39 -0600116
Jordan Pittier3b46d272017-04-12 16:17:28 +0200117 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800118 @decorators.idempotent_id('5226dd80-1e9c-4d8a-b5f9-b26ca4763fd0')
Daryl Walleckadea1fa2011-11-15 18:36:39 -0600119 def test_invalid_ip_v6_address(self):
zhuflb5603bc2020-05-27 09:18:24 +0800120 """Creating a server with invalid ipv6 ip address should fail
donald-ngo18edb812013-02-22 11:37:15 -0800121
zhuflb5603bc2020-05-27 09:18:24 +0800122 An access IPv6 address must match a valid address pattern
123 """
Sean Dague9b669e32012-12-13 18:40:08 -0500124 IPv6 = 'notvalid'
donald-ngo18edb812013-02-22 11:37:15 -0800125
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900126 self.assertRaises(lib_exc.BadRequest,
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +0900127 self.create_test_server, accessIPv6=IPv6)
ravikumar-venkatesan36892e12012-05-11 18:01:41 +0000128
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800129 @decorators.idempotent_id('7ea45b3e-e770-46fa-bfcc-9daaf6d987c0')
Joseph Lanouxb3d956f2014-06-25 14:45:24 +0000130 @testtools.skipUnless(CONF.compute_feature_enabled.resize,
131 'Resize not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200132 @decorators.attr(type=['negative'])
Hoisaleshwara Madan V Sf49bf182013-10-21 10:19:43 +0530133 def test_resize_nonexistent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800134 """Resizing a non-existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900135 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900136 self.assertRaises(lib_exc.NotFound,
Ken'ichi Ohmichi5271b0f2015-08-10 07:53:27 +0000137 self.client.resize_server,
Hoisaleshwara Madan V Sf49bf182013-10-21 10:19:43 +0530138 nonexistent_server, self.flavor_ref)
139
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800140 @decorators.idempotent_id('ced1a1d7-2ab6-45c9-b90f-b27d87b30efd')
Joseph Lanouxb3d956f2014-06-25 14:45:24 +0000141 @testtools.skipUnless(CONF.compute_feature_enabled.resize,
142 'Resize not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200143 @decorators.attr(type=['negative'])
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900144 def test_resize_server_with_non_existent_flavor(self):
zhuflb5603bc2020-05-27 09:18:24 +0800145 """Resizing a server with non existent flavor should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900146 nonexistent_flavor = data_utils.rand_uuid()
Ken'ichi Ohmichi5271b0f2015-08-10 07:53:27 +0000147 self.assertRaises(lib_exc.BadRequest, self.client.resize_server,
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900148 self.server_id, flavor_ref=nonexistent_flavor)
149
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800150 @decorators.idempotent_id('45436a7d-a388-4a35-a9d8-3adc5d0d940b')
Joseph Lanouxb3d956f2014-06-25 14:45:24 +0000151 @testtools.skipUnless(CONF.compute_feature_enabled.resize,
152 'Resize not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200153 @decorators.attr(type=['negative'])
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900154 def test_resize_server_with_null_flavor(self):
zhuflb5603bc2020-05-27 09:18:24 +0800155 """Resizing a server with null flavor should fail"""
Ken'ichi Ohmichi5271b0f2015-08-10 07:53:27 +0000156 self.assertRaises(lib_exc.BadRequest, self.client.resize_server,
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900157 self.server_id, flavor_ref="")
158
Jordan Pittier3b46d272017-04-12 16:17:28 +0200159 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800160 @decorators.idempotent_id('d4c023a0-9c55-4747-9dd5-413b820143c7')
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900161 def test_reboot_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800162 """Rebooting a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900163 nonexistent_server = data_utils.rand_uuid()
Ken'ichi Ohmichi5271b0f2015-08-10 07:53:27 +0000164 self.assertRaises(lib_exc.NotFound, self.client.reboot_server,
Ken'ichi Ohmichi36b714c2015-12-09 08:12:47 +0000165 nonexistent_server, type='SOFT')
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900166
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800167 @decorators.idempotent_id('d1417e7f-a509-41b5-a102-d5eed8613369')
Matt Riedemann992162e2014-03-24 09:11:06 -0700168 @testtools.skipUnless(CONF.compute_feature_enabled.pause,
169 'Pause is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200170 @decorators.attr(type=['negative'])
Anju Tiwari8c789762013-07-22 11:02:05 +0530171 def test_pause_paused_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800172 """Pausing a paused server should fail"""
Anju Tiwari8c789762013-07-22 11:02:05 +0530173 self.client.pause_server(self.server_id)
Ken'ichi Ohmichi0eb153c2015-07-13 02:18:25 +0000174 waiters.wait_for_server_status(self.client, self.server_id, 'PAUSED')
Masayuki Igawad9388762015-01-20 14:56:42 +0900175 self.assertRaises(lib_exc.Conflict,
Anju Tiwari8c789762013-07-22 11:02:05 +0530176 self.client.pause_server,
177 self.server_id)
Attila Fazekas305e65b2013-10-29 13:23:07 +0100178 self.client.unpause_server(self.server_id)
Anju Tiwari8c789762013-07-22 11:02:05 +0530179
Jordan Pittier3b46d272017-04-12 16:17:28 +0200180 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800181 @decorators.idempotent_id('98fa0458-1485-440f-873b-fe7f0d714930')
Joe H. Rahmeb2e01ab2015-10-27 17:30:53 +0100182 def test_rebuild_deleted_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800183 """Rebuilding a deleted server should fail"""
Masayuki Igawabfa07602015-01-20 18:47:17 +0900184 self.assertRaises(lib_exc.NotFound,
Ken'ichi Ohmichi5271b0f2015-08-10 07:53:27 +0000185 self.client.rebuild_server,
zhufl406e9132017-05-09 16:21:54 +0800186 self.deleted_server_id, self.image_ref)
Joe H. Rahmeb2e01ab2015-10-27 17:30:53 +0100187
Jordan Pittierc5665a62017-04-12 16:42:53 +0200188 @decorators.related_bug('1660878', status_code=409)
Jordan Pittier3b46d272017-04-12 16:17:28 +0200189 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800190 @decorators.idempotent_id('581a397d-5eab-486f-9cf9-1014bbd4c984')
Joe H. Rahmeb2e01ab2015-10-27 17:30:53 +0100191 def test_reboot_deleted_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800192 """Rebooting a deleted server should fail"""
Ken'ichi Ohmichi5271b0f2015-08-10 07:53:27 +0000193 self.assertRaises(lib_exc.NotFound, self.client.reboot_server,
zhufl406e9132017-05-09 16:21:54 +0800194 self.deleted_server_id, type='SOFT')
Rohit Karajgidc300b22012-05-04 08:11:00 -0700195
Jordan Pittier3b46d272017-04-12 16:17:28 +0200196 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800197 @decorators.idempotent_id('d86141a7-906e-4731-b187-d64a2ea61422')
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900198 def test_rebuild_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800199 """Rebuilding a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900200 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900201 self.assertRaises(lib_exc.NotFound,
Ken'ichi Ohmichi5271b0f2015-08-10 07:53:27 +0000202 self.client.rebuild_server,
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900203 nonexistent_server,
Emily Hugenbruch589028a2017-02-13 11:26:22 -0500204 self.image_ref)
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900205
Jordan Pittier3b46d272017-04-12 16:17:28 +0200206 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800207 @decorators.idempotent_id('fd57f159-68d6-4c2a-902b-03070828a87e')
Rohit Karajgidc300b22012-05-04 08:11:00 -0700208 def test_create_numeric_server_name(self):
zhuflb5603bc2020-05-27 09:18:24 +0800209 """Creating a server with numeric server name should fail"""
Rohit Karajgidc300b22012-05-04 08:11:00 -0700210 server_name = 12345
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900211 self.assertRaises(lib_exc.BadRequest,
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +0900212 self.create_test_server,
Sean Dague22897e12013-02-25 17:54:09 -0500213 name=server_name)
Rohit Karajgidc300b22012-05-04 08:11:00 -0700214
Jordan Pittier3b46d272017-04-12 16:17:28 +0200215 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800216 @decorators.idempotent_id('c3e0fb12-07fc-4d76-a22e-37409887afe8')
Rohit Karajgidc300b22012-05-04 08:11:00 -0700217 def test_create_server_name_length_exceeds_256(self):
zhuflb5603bc2020-05-27 09:18:24 +0800218 """Creating a server with name length exceeding limit should fail
Rohit Karajgidc300b22012-05-04 08:11:00 -0700219
zhuflb5603bc2020-05-27 09:18:24 +0800220 Create a server with name length exceeding 255 characters, an error is
221 returned.
222 """
Rohit Karajgidc300b22012-05-04 08:11:00 -0700223 server_name = 'a' * 256
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900224 self.assertRaises(lib_exc.BadRequest,
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +0900225 self.create_test_server,
Sean Dague22897e12013-02-25 17:54:09 -0500226 name=server_name)
Rohit Karajgidc300b22012-05-04 08:11:00 -0700227
Jordan Pittier3b46d272017-04-12 16:17:28 +0200228 @decorators.attr(type=['negative'])
Jordan Pittierc5665a62017-04-12 16:42:53 +0200229 @decorators.related_bug('1651064', status_code=500)
Andrea Frittolicd368412017-08-14 21:37:56 +0100230 @utils.services('volume')
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800231 @decorators.idempotent_id('12146ac1-d7df-4928-ad25-b1f99e5286cd')
Ken'ichi Ohmichi8ee59f82016-12-26 17:06:00 -0800232 def test_create_server_invalid_bdm_in_2nd_dict(self):
zhuflb5603bc2020-05-27 09:18:24 +0800233 """Creating a server with invalid block_device_mapping_v2 should fail
234
235 Create a server with invalid block_device_mapping_v2, an error is
236 returned.
237 """
Ken'ichi Ohmichi8ee59f82016-12-26 17:06:00 -0800238 volume = self.create_volume()
239 bdm_1st = {"source_type": "image",
240 "delete_on_termination": True,
241 "boot_index": 0,
242 "uuid": self.image_ref,
243 "destination_type": "local"}
244 bdm_2nd = {"source_type": "volume",
245 "uuid": volume["id"],
246 "destination_type": "invalid"}
247 bdm = [bdm_1st, bdm_2nd]
248
249 self.assertRaises(lib_exc.BadRequest,
250 self.create_test_server,
251 image_id=self.image_ref,
252 block_device_mapping_v2=bdm)
253
Jordan Pittier3b46d272017-04-12 16:17:28 +0200254 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800255 @decorators.idempotent_id('4e72dc2d-44c5-4336-9667-f7972e95c402')
Rohit Karajgidc300b22012-05-04 08:11:00 -0700256 def test_create_with_invalid_network_uuid(self):
zhuflb5603bc2020-05-27 09:18:24 +0800257 """Creating a server with invalid network uuid should fail"""
Sean Dague4dd2c0b2013-01-03 17:50:28 -0500258 # Pass invalid network uuid while creating a server
Chris Yeohfc9e3332013-01-21 09:28:13 +1030259 networks = [{'fixed_ip': '10.0.1.1', 'uuid': 'a-b-c-d-e-f-g-h-i-j'}]
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900260 self.assertRaises(lib_exc.BadRequest,
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +0900261 self.create_test_server,
Zhongyue Luo79d8d362012-09-25 13:49:27 +0800262 networks=networks)
Rohit Karajgidc300b22012-05-04 08:11:00 -0700263
Jordan Pittier3b46d272017-04-12 16:17:28 +0200264 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800265 @decorators.idempotent_id('7a2efc39-530c-47de-b875-2dd01c8d39bd')
nayna-patel179077c2014-01-15 12:27:16 +0000266 def test_create_with_non_existent_keypair(self):
zhuflb5603bc2020-05-27 09:18:24 +0800267 """Creating a server with non-existent keypair should fail"""
Chang Bo Guof099f802013-09-13 19:01:46 -0700268 # Pass a non-existent keypair while creating a server
Masayuki Igawa259c1132013-10-31 17:48:44 +0900269 key_name = data_utils.rand_name('key')
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900270 self.assertRaises(lib_exc.BadRequest,
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +0900271 self.create_test_server,
Zhongyue Luo79d8d362012-09-25 13:49:27 +0800272 key_name=key_name)
Rohit Karajgidc300b22012-05-04 08:11:00 -0700273
Jordan Pittier3b46d272017-04-12 16:17:28 +0200274 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800275 @decorators.idempotent_id('7fc74810-0bd2-4cd7-8244-4f33a9db865a')
Rohit Karajgidc300b22012-05-04 08:11:00 -0700276 def test_create_server_metadata_exceeds_length_limit(self):
zhuflb5603bc2020-05-27 09:18:24 +0800277 """Creating a server with metadata longer than limit should fail """
Sean Dague4dd2c0b2013-01-03 17:50:28 -0500278 # Pass really long metadata while creating a server
Rohit Karajgidc300b22012-05-04 08:11:00 -0700279 metadata = {'a': 'b' * 260}
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900280 self.assertRaises((lib_exc.BadRequest, lib_exc.OverLimit),
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +0900281 self.create_test_server,
Ken'ichi Ohmichif2d436e2015-09-03 01:13:16 +0000282 metadata=metadata)
Rohit Karajgidc300b22012-05-04 08:11:00 -0700283
Jordan Pittier3b46d272017-04-12 16:17:28 +0200284 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800285 @decorators.idempotent_id('aa8eed43-e2cb-4ebf-930b-da14f6a21d81')
Rohit Karajgidc300b22012-05-04 08:11:00 -0700286 def test_update_name_of_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800287 """Updating name of a non-existent server should fail"""
Shuquan Huang74b03462015-08-27 04:06:50 +0000288 nonexistent_server = data_utils.rand_uuid()
zhuflc6ce5392016-08-17 14:34:37 +0800289 new_name = data_utils.rand_name(
290 self.__class__.__name__ + '-server') + '_updated'
Rohit Karajgidc300b22012-05-04 08:11:00 -0700291
Masayuki Igawabfa07602015-01-20 18:47:17 +0900292 self.assertRaises(lib_exc.NotFound, self.client.update_server,
Shuquan Huang74b03462015-08-27 04:06:50 +0000293 nonexistent_server, name=new_name)
Rohit Karajgidc300b22012-05-04 08:11:00 -0700294
Jordan Pittier3b46d272017-04-12 16:17:28 +0200295 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800296 @decorators.idempotent_id('38204696-17c6-44da-9590-40f87fb5a899')
Rohit Karajgidc300b22012-05-04 08:11:00 -0700297 def test_update_server_set_empty_name(self):
zhuflb5603bc2020-05-27 09:18:24 +0800298 """Updating name of the server to an empty string should fail"""
Rohit Karajgidc300b22012-05-04 08:11:00 -0700299 new_name = ''
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900300 self.assertRaises(lib_exc.BadRequest, self.client.update_server,
Shuquan Huang74b03462015-08-27 04:06:50 +0000301 self.server_id, name=new_name)
Rohit Karajgidc300b22012-05-04 08:11:00 -0700302
Jordan Pittier3b46d272017-04-12 16:17:28 +0200303 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800304 @decorators.idempotent_id('5c8e244c-dada-4590-9944-749c455b431f')
Rohit Karajgidc300b22012-05-04 08:11:00 -0700305 def test_update_server_name_length_exceeds_256(self):
zhuflb5603bc2020-05-27 09:18:24 +0800306 """Updating name of server exceeding the name length limit should fail
Rohit Karajgidc300b22012-05-04 08:11:00 -0700307
zhuflb5603bc2020-05-27 09:18:24 +0800308 Update name of server exceeding the name length limit, an error is
309 returned.
310 """
Rohit Karajgidc300b22012-05-04 08:11:00 -0700311 new_name = 'a' * 256
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900312 self.assertRaises(lib_exc.BadRequest,
Zhongyue Luo79d8d362012-09-25 13:49:27 +0800313 self.client.update_server,
Ken'ichi Ohmichida306502013-10-08 23:44:55 +0900314 self.server_id,
Zhongyue Luo79d8d362012-09-25 13:49:27 +0800315 name=new_name)
Rohit Karajgidc300b22012-05-04 08:11:00 -0700316
Jordan Pittier3b46d272017-04-12 16:17:28 +0200317 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800318 @decorators.idempotent_id('1041b4e6-514b-4855-96a5-e974b60870a3')
Rohit Karajgidc300b22012-05-04 08:11:00 -0700319 def test_delete_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800320 """Deleting a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900321 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900322 self.assertRaises(lib_exc.NotFound, self.client.delete_server,
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900323 nonexistent_server)
Rohit Karajgidc300b22012-05-04 08:11:00 -0700324
Jordan Pittier3b46d272017-04-12 16:17:28 +0200325 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800326 @decorators.idempotent_id('75f79124-277c-45e6-a373-a1d6803f4cc4')
Rohit Karajgidc300b22012-05-04 08:11:00 -0700327 def test_delete_server_pass_negative_id(self):
zhuflb5603bc2020-05-27 09:18:24 +0800328 """Passing an invalid string parameter to delete server should fail"""
Masayuki Igawabfa07602015-01-20 18:47:17 +0900329 self.assertRaises(lib_exc.NotFound, self.client.delete_server, -1)
Rohit Karajgidc300b22012-05-04 08:11:00 -0700330
Jordan Pittier3b46d272017-04-12 16:17:28 +0200331 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800332 @decorators.idempotent_id('f4d7279b-5fd2-4bf2-9ba4-ae35df0d18c5')
Rohit Karajgidc300b22012-05-04 08:11:00 -0700333 def test_delete_server_pass_id_exceeding_length_limit(self):
zhuflb5603bc2020-05-27 09:18:24 +0800334 """Deleting server with a server ID exceeding length limit should fail
Rohit Karajgidc300b22012-05-04 08:11:00 -0700335
zhuflb5603bc2020-05-27 09:18:24 +0800336 Pass a server ID that exceeds length limit to delete server, an error
337 is returned.
338 """
Masayuki Igawabfa07602015-01-20 18:47:17 +0900339 self.assertRaises(lib_exc.NotFound, self.client.delete_server,
Sirushti Murugesan12dc9732016-07-13 22:49:17 +0530340 sys.maxsize + 1)
donald-ngo78bd7f52013-02-08 14:35:16 -0800341
Jordan Pittier3b46d272017-04-12 16:17:28 +0200342 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800343 @decorators.idempotent_id('c5fa6041-80cd-483b-aa6d-4e45f19d093c')
donald-ngo78bd7f52013-02-08 14:35:16 -0800344 def test_create_with_nonexistent_security_group(self):
zhuflb5603bc2020-05-27 09:18:24 +0800345 """Creating a server with a nonexistent security group should fail"""
donald-ngo18edb812013-02-22 11:37:15 -0800346 security_groups = [{'name': 'does_not_exist'}]
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900347 self.assertRaises(lib_exc.BadRequest,
Ken'ichi Ohmichicfc052e2013-10-23 11:50:04 +0900348 self.create_test_server,
donald-ngo18edb812013-02-22 11:37:15 -0800349 security_groups=security_groups)
hi2suresh063acbc2013-02-20 09:32:03 +0000350
Jordan Pittier3b46d272017-04-12 16:17:28 +0200351 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800352 @decorators.idempotent_id('3436b02f-1b1e-4f03-881e-c6a602327439')
hi2suresh063acbc2013-02-20 09:32:03 +0000353 def test_get_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800354 """Getting a non existent server details should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900355 nonexistent_server = data_utils.rand_uuid()
Ken'ichi Ohmichi76800242015-07-03 05:12:31 +0000356 self.assertRaises(lib_exc.NotFound, self.client.show_server,
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900357 nonexistent_server)
Sean Daguee623f752013-02-27 14:52:15 -0500358
Jordan Pittier3b46d272017-04-12 16:17:28 +0200359 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800360 @decorators.idempotent_id('a31460a9-49e1-42aa-82ee-06e0bb7c2d03')
Anju Tiwari6c336162013-08-08 12:21:02 +0530361 def test_stop_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800362 """Stopping a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900363 nonexistent_server = data_utils.rand_uuid()
Ken'ichi Ohmichib2631082015-08-27 01:31:00 +0000364 self.assertRaises(lib_exc.NotFound, self.servers_client.stop_server,
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900365 nonexistent_server)
Anju Tiwari6c336162013-08-08 12:21:02 +0530366
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800367 @decorators.idempotent_id('6a8dc0c6-6cd4-4c0a-9f32-413881828091')
Matt Riedemann992162e2014-03-24 09:11:06 -0700368 @testtools.skipUnless(CONF.compute_feature_enabled.pause,
369 'Pause is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200370 @decorators.attr(type=['negative'])
Anju Tiwari6c336162013-08-08 12:21:02 +0530371 def test_pause_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800372 """Pausing a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900373 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900374 self.assertRaises(lib_exc.NotFound, self.client.pause_server,
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900375 nonexistent_server)
LingxianKongb2ca96f2013-09-28 23:09:30 +0800376
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800377 @decorators.idempotent_id('705b8e3a-e8a7-477c-a19b-6868fc24ac75')
Matt Riedemann992162e2014-03-24 09:11:06 -0700378 @testtools.skipUnless(CONF.compute_feature_enabled.pause,
379 'Pause is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200380 @decorators.attr(type=['negative'])
LingxianKongb2ca96f2013-09-28 23:09:30 +0800381 def test_unpause_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800382 """Unpausing a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900383 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900384 self.assertRaises(lib_exc.NotFound, self.client.unpause_server,
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900385 nonexistent_server)
LingxianKongb2ca96f2013-09-28 23:09:30 +0800386
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800387 @decorators.idempotent_id('c8e639a7-ece8-42dd-a2e0-49615917ba4f')
Matt Riedemann992162e2014-03-24 09:11:06 -0700388 @testtools.skipUnless(CONF.compute_feature_enabled.pause,
389 'Pause is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200390 @decorators.attr(type=['negative'])
LingxianKongb2ca96f2013-09-28 23:09:30 +0800391 def test_unpause_server_invalid_state(self):
zhuflb5603bc2020-05-27 09:18:24 +0800392 """Unpausing an active server should fail"""
Masayuki Igawad9388762015-01-20 14:56:42 +0900393 self.assertRaises(lib_exc.Conflict,
LingxianKongb2ca96f2013-09-28 23:09:30 +0800394 self.client.unpause_server,
Ken'ichi Ohmichida306502013-10-08 23:44:55 +0900395 self.server_id)
Anju Tiwari6c336162013-08-08 12:21:02 +0530396
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800397 @decorators.idempotent_id('d1f032d5-7b6e-48aa-b252-d5f16dd994ca')
Matt Riedemannf0cf6952014-03-24 09:08:52 -0700398 @testtools.skipUnless(CONF.compute_feature_enabled.suspend,
399 'Suspend is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200400 @decorators.attr(type=['negative'])
LingxianKong691a5702013-09-29 11:43:45 +0800401 def test_suspend_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800402 """Suspending a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900403 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900404 self.assertRaises(lib_exc.NotFound, self.client.suspend_server,
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900405 nonexistent_server)
LingxianKong691a5702013-09-29 11:43:45 +0800406
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800407 @decorators.idempotent_id('7f323206-05a9-4bf8-996b-dd5b2036501b')
Matt Riedemannf0cf6952014-03-24 09:08:52 -0700408 @testtools.skipUnless(CONF.compute_feature_enabled.suspend,
409 'Suspend is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200410 @decorators.attr(type=['negative'])
LingxianKong691a5702013-09-29 11:43:45 +0800411 def test_suspend_server_invalid_state(self):
zhuflb5603bc2020-05-27 09:18:24 +0800412 """Suspending a suspended server should fail"""
David Kranzae99b9a2015-02-16 13:37:01 -0500413 self.client.suspend_server(self.server_id)
Ken'ichi Ohmichi0eb153c2015-07-13 02:18:25 +0000414 waiters.wait_for_server_status(self.client, self.server_id,
415 'SUSPENDED')
Masayuki Igawad9388762015-01-20 14:56:42 +0900416 self.assertRaises(lib_exc.Conflict,
LingxianKong691a5702013-09-29 11:43:45 +0800417 self.client.suspend_server,
Ken'ichi Ohmichida306502013-10-08 23:44:55 +0900418 self.server_id)
Attila Fazekas305e65b2013-10-29 13:23:07 +0100419 self.client.resume_server(self.server_id)
LingxianKong691a5702013-09-29 11:43:45 +0800420
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800421 @decorators.idempotent_id('221cd282-bddb-4837-a683-89c2487389b6')
Matt Riedemannf0cf6952014-03-24 09:08:52 -0700422 @testtools.skipUnless(CONF.compute_feature_enabled.suspend,
423 'Suspend is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200424 @decorators.attr(type=['negative'])
LingxianKong691a5702013-09-29 11:43:45 +0800425 def test_resume_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800426 """Resuming a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900427 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900428 self.assertRaises(lib_exc.NotFound, self.client.resume_server,
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900429 nonexistent_server)
LingxianKong691a5702013-09-29 11:43:45 +0800430
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800431 @decorators.idempotent_id('ccb6294d-c4c9-498f-8a43-554c098bfadb')
Matt Riedemannf0cf6952014-03-24 09:08:52 -0700432 @testtools.skipUnless(CONF.compute_feature_enabled.suspend,
433 'Suspend is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200434 @decorators.attr(type=['negative'])
LingxianKong691a5702013-09-29 11:43:45 +0800435 def test_resume_server_invalid_state(self):
zhuflb5603bc2020-05-27 09:18:24 +0800436 """Resuming an active server should fail"""
Masayuki Igawad9388762015-01-20 14:56:42 +0900437 self.assertRaises(lib_exc.Conflict,
LingxianKong691a5702013-09-29 11:43:45 +0800438 self.client.resume_server,
Ken'ichi Ohmichida306502013-10-08 23:44:55 +0900439 self.server_id)
LingxianKong691a5702013-09-29 11:43:45 +0800440
Jordan Pittier3b46d272017-04-12 16:17:28 +0200441 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800442 @decorators.idempotent_id('7dd919e7-413f-4198-bebb-35e2a01b13e9')
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900443 def test_get_console_output_of_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800444 """Getting the console output for a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900445 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900446 self.assertRaises(lib_exc.NotFound,
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900447 self.client.get_console_output,
Ken'ichi Ohmichibf4766a2015-12-09 07:48:43 +0000448 nonexistent_server, length=10)
Ken'ichi Ohmichid90c0102013-10-13 23:55:31 +0900449
Jordan Pittier3b46d272017-04-12 16:17:28 +0200450 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800451 @decorators.idempotent_id('6f47992b-5144-4250-9f8b-f00aa33950f3')
Lingxian Kongaecc1092013-10-03 16:18:46 +0800452 def test_force_delete_nonexistent_server_id(self):
zhuflb5603bc2020-05-27 09:18:24 +0800453 """Force-deleting a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900454 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900455 self.assertRaises(lib_exc.NotFound,
Lingxian Kongaecc1092013-10-03 16:18:46 +0800456 self.client.force_delete_server,
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900457 nonexistent_server)
Lingxian Kongaecc1092013-10-03 16:18:46 +0800458
Jordan Pittier3b46d272017-04-12 16:17:28 +0200459 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800460 @decorators.idempotent_id('9c6d38cc-fcfb-437a-85b9-7b788af8bf01')
Lingxian Kongaecc1092013-10-03 16:18:46 +0800461 def test_restore_nonexistent_server_id(self):
zhuflb5603bc2020-05-27 09:18:24 +0800462 """Restore-deleting a non existent server should fail
463
464 We can restore a soft deleted server, but can't restore a non
465 existent server.
466 """
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900467 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900468 self.assertRaises(lib_exc.NotFound,
Lingxian Kongaecc1092013-10-03 16:18:46 +0800469 self.client.restore_soft_deleted_server,
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900470 nonexistent_server)
Lingxian Kongaecc1092013-10-03 16:18:46 +0800471
Jordan Pittier3b46d272017-04-12 16:17:28 +0200472 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800473 @decorators.idempotent_id('7fcadfab-bd6a-4753-8db7-4a51e51aade9')
Lingxian Kongaecc1092013-10-03 16:18:46 +0800474 def test_restore_server_invalid_state(self):
zhuflb5603bc2020-05-27 09:18:24 +0800475 """Restore-deleting a server not in 'soft-delete' state should fail
476
477 We can restore a soft deleted server, but can't restore a server that
478 is not in 'soft-delete' state.
479 """
Masayuki Igawad9388762015-01-20 14:56:42 +0900480 self.assertRaises(lib_exc.Conflict,
Lingxian Kongaecc1092013-10-03 16:18:46 +0800481 self.client.restore_soft_deleted_server,
482 self.server_id)
483
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800484 @decorators.idempotent_id('abca56e2-a892-48ea-b5e5-e07e69774816')
David Shrewsbury25f666f2014-07-22 12:17:59 -0400485 @testtools.skipUnless(CONF.compute_feature_enabled.shelve,
486 'Shelve is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200487 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900488 def test_shelve_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800489 """Shelving a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900490 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900491 self.assertRaises(lib_exc.NotFound, self.client.shelve_server,
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900492 nonexistent_server)
493
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800494 @decorators.idempotent_id('443e4f9b-e6bf-4389-b601-3a710f15fddd')
David Shrewsbury25f666f2014-07-22 12:17:59 -0400495 @testtools.skipUnless(CONF.compute_feature_enabled.shelve,
496 'Shelve is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200497 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900498 def test_shelve_shelved_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800499 """Shelving a shelved server should fail"""
ghanshyam017b5fe2016-04-15 18:49:26 +0900500 compute.shelve_server(self.client, self.server_id)
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900501
zhuflaa270032017-11-27 15:26:49 +0800502 def _unshelve_server():
503 server_info = self.client.show_server(self.server_id)['server']
504 if 'SHELVED' in server_info['status']:
505 self.client.unshelve_server(self.server_id)
zhufl8c9d4362018-04-03 15:45:50 +0800506 self.addCleanup(_unshelve_server)
zhuflaa270032017-11-27 15:26:49 +0800507
ghanshyam0f825252015-08-25 16:02:50 +0900508 server = self.client.show_server(self.server_id)['server']
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900509 image_name = server['name'] + '-shelved'
zhufl66275c22018-03-28 15:32:14 +0800510 if CONF.image_feature_enabled.api_v1:
511 kwargs = {'name': image_name}
512 else:
513 kwargs = {'params': {'name': image_name}}
514 images = self.images_client.list_images(**kwargs)['images']
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900515 self.assertEqual(1, len(images))
516 self.assertEqual(image_name, images[0]['name'])
517
Masayuki Igawad9388762015-01-20 14:56:42 +0900518 self.assertRaises(lib_exc.Conflict,
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900519 self.client.shelve_server,
520 self.server_id)
521
Attila Fazekas305e65b2013-10-29 13:23:07 +0100522 self.client.unshelve_server(self.server_id)
523
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800524 @decorators.idempotent_id('23d23b37-afaf-40d7-aa5d-5726f82d8821')
David Shrewsbury25f666f2014-07-22 12:17:59 -0400525 @testtools.skipUnless(CONF.compute_feature_enabled.shelve,
526 'Shelve is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200527 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900528 def test_unshelve_non_existent_server(self):
zhuflb5603bc2020-05-27 09:18:24 +0800529 """Unshelving a non existent server should fail"""
Ken'ichi Ohmichiaa702b02013-12-18 01:37:21 +0900530 nonexistent_server = data_utils.rand_uuid()
Masayuki Igawabfa07602015-01-20 18:47:17 +0900531 self.assertRaises(lib_exc.NotFound, self.client.unshelve_server,
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900532 nonexistent_server)
533
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800534 @decorators.idempotent_id('8f198ded-1cca-4228-9e65-c6b449c54880')
David Shrewsbury25f666f2014-07-22 12:17:59 -0400535 @testtools.skipUnless(CONF.compute_feature_enabled.shelve,
536 'Shelve is not available.')
Jordan Pittier3b46d272017-04-12 16:17:28 +0200537 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900538 def test_unshelve_server_invalid_state(self):
zhuflb5603bc2020-05-27 09:18:24 +0800539 """Unshelving an active server should fail"""
Masayuki Igawad9388762015-01-20 14:56:42 +0900540 self.assertRaises(lib_exc.Conflict,
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900541 self.client.unshelve_server,
542 self.server_id)
Chris Hoge2718b3a2016-02-23 16:47:14 -0500543
Jordan Pittier3b46d272017-04-12 16:17:28 +0200544 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800545 @decorators.idempotent_id('74085be3-a370-4ca2-bc51-2d0e10e0f573')
Andrea Frittolicd368412017-08-14 21:37:56 +0100546 @utils.services('volume', 'image')
lkuchlanddc59a02016-08-15 14:56:34 +0300547 def test_create_server_from_non_bootable_volume(self):
zhuflb5603bc2020-05-27 09:18:24 +0800548 """Creating a server from a non bootable volume should fail"""
lkuchlanddc59a02016-08-15 14:56:34 +0300549 volume = self.create_volume()
550
551 # Update volume bootable status to false
552 self.volumes_client.set_bootable_volume(volume['id'],
553 bootable=False)
554
555 # Verify bootable flag was updated
556 nonbootable_vol = self.volumes_client.show_volume(
557 volume['id'])['volume']
558 self.assertEqual('false', nonbootable_vol['bootable'])
559
560 # Block device mapping
561 bd_map = [{'boot_index': '0',
562 'uuid': volume['id'],
563 'source_type': 'volume',
564 'destination_type': 'volume',
565 'delete_on_termination': False}]
566
567 # Try creating a server from non-bootable volume
568 self.assertRaises(lib_exc.BadRequest,
569 self.create_test_server,
570 image_id='',
571 wait_until='ACTIVE',
572 block_device_mapping_v2=bd_map)
573
Chris Hoge2718b3a2016-02-23 16:47:14 -0500574
575class ServersNegativeTestMultiTenantJSON(base.BaseV2ComputeTest):
zhuflb5603bc2020-05-27 09:18:24 +0800576 """Negative tests of servers for multiple projects"""
577
Eric Friede85f0292020-01-23 10:42:27 -0600578 create_default_network = True
Chris Hoge2718b3a2016-02-23 16:47:14 -0500579
580 credentials = ['primary', 'alt']
581
582 def setUp(self):
583 super(ServersNegativeTestMultiTenantJSON, self).setUp()
584 try:
zhufl5376ab32017-05-09 15:56:50 +0800585 waiters.wait_for_server_status(self.servers_client, self.server_id,
Chris Hoge2718b3a2016-02-23 16:47:14 -0500586 'ACTIVE')
587 except Exception:
zhuflba0e5532017-09-13 10:51:07 +0800588 self.__class__.server_id = self.recreate_server(self.server_id)
Chris Hoge2718b3a2016-02-23 16:47:14 -0500589
590 @classmethod
591 def setup_clients(cls):
592 super(ServersNegativeTestMultiTenantJSON, cls).setup_clients()
593 cls.alt_client = cls.os_alt.servers_client
594
595 @classmethod
596 def resource_setup(cls):
597 super(ServersNegativeTestMultiTenantJSON, cls).resource_setup()
598 server = cls.create_test_server(wait_until='ACTIVE')
599 cls.server_id = server['id']
600
Jordan Pittier3b46d272017-04-12 16:17:28 +0200601 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800602 @decorators.idempotent_id('543d84c1-dd2e-4c6d-8cb2-b9da0efaa384')
Chris Hoge2718b3a2016-02-23 16:47:14 -0500603 def test_update_server_of_another_tenant(self):
zhuflb5603bc2020-05-27 09:18:24 +0800604 """Updating server that belongs to another project should fail
Chris Hoge2718b3a2016-02-23 16:47:14 -0500605
zhuflb5603bc2020-05-27 09:18:24 +0800606 Update name of a server that belongs to another project, an error is
607 returned.
608 """
Chris Hoge2718b3a2016-02-23 16:47:14 -0500609 new_name = self.server_id + '_new'
610 self.assertRaises(lib_exc.NotFound,
611 self.alt_client.update_server, self.server_id,
612 name=new_name)
613
Jordan Pittier3b46d272017-04-12 16:17:28 +0200614 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi14b0ae12017-01-27 17:18:52 -0800615 @decorators.idempotent_id('5c75009d-3eea-423e-bea3-61b09fd25f9c')
Chris Hoge2718b3a2016-02-23 16:47:14 -0500616 def test_delete_a_server_of_another_tenant(self):
zhuflb5603bc2020-05-27 09:18:24 +0800617 """Deleting a server that belongs to another project should fail"""
Chris Hoge2718b3a2016-02-23 16:47:14 -0500618 self.assertRaises(lib_exc.NotFound,
619 self.alt_client.delete_server,
620 self.server_id)