blob: c405a508f239d74698f361ccae43e7de1471630c [file] [log] [blame]
ZhiQiang Fan39f97222013-09-20 04:49:44 +08001# Copyright 2012 OpenStack Foundation
Rohit Karajgidd47d7e2012-07-31 04:11:01 -07002# 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
songwenping8c3dac12021-02-22 09:12:37 +080016import io
jeremy.zhang0a427162017-04-21 12:47:56 +080017
Sean Dague1937d092013-05-17 16:36:38 -040018from tempest.api.volume import base
Andrea Frittolicd368412017-08-14 21:37:56 +010019from tempest.common import utils
jeremy.zhang0a427162017-04-21 12:47:56 +080020from tempest.common import waiters
21from tempest import config
Ken'ichi Ohmichief1c1ce2017-03-10 11:07:10 -080022from tempest.lib.common.utils import data_utils
jeremy.zhang0a427162017-04-21 12:47:56 +080023from tempest.lib.common.utils import test_utils
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080024from tempest.lib import decorators
Andrea Frittoli (andreaf)db9672e2016-02-23 14:07:24 -050025from tempest.lib import exceptions as lib_exc
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070026
jeremy.zhang0a427162017-04-21 12:47:56 +080027CONF = config.CONF
28
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070029
Ken'ichi Ohmichie8afb8c2017-03-27 11:25:37 -070030class VolumesNegativeTest(base.BaseVolumeTest):
zhufla5682372020-08-14 14:56:57 +080031 """Negative tests of volumes"""
Attila Fazekas3dcdae12013-02-14 12:50:04 +010032
Sofiia Tavrovskac817edd2025-04-22 17:43:12 +020033 create_default_network = True
34
Attila Fazekas3dcdae12013-02-14 12:50:04 +010035 @classmethod
Andrea Frittoli61a12e22014-09-15 13:14:54 +010036 def resource_setup(cls):
Ken'ichi Ohmichie8afb8c2017-03-27 11:25:37 -070037 super(VolumesNegativeTest, cls).resource_setup()
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070038
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080039 # Create a test shared instance and volume for attach/detach tests
Ken'ichi Ohmichi5687d552013-12-26 19:00:12 +090040 cls.volume = cls.create_volume()
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080041
lkuchlan13736ae2017-04-24 14:49:45 +030042 def create_image(self):
43 # Create image
Martin Kopec213d0a42023-11-30 10:28:14 +010044 image_name = data_utils.rand_name(
45 prefix=CONF.resource_name_prefix,
46 name=self.__class__.__name__ + "-image")
lkuchlan13736ae2017-04-24 14:49:45 +030047 image = self.images_client.create_image(
48 name=image_name,
49 container_format=CONF.image.container_formats[0],
Dan Smith507d0de2024-09-26 06:59:19 -070050 disk_format='raw',
lkuchlan13736ae2017-04-24 14:49:45 +030051 visibility='private',
Martin Kopec37c4bd32021-06-24 15:46:00 +000052 min_disk=CONF.volume.volume_size + CONF.volume.volume_size_extend)
lkuchlan13736ae2017-04-24 14:49:45 +030053 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
54 self.images_client.delete_image, image['id'])
55
56 # Upload image with 1KB data
songwenping8c3dac12021-02-22 09:12:37 +080057 image_file = io.BytesIO(data_utils.random_bytes())
lkuchlan13736ae2017-04-24 14:49:45 +030058 self.images_client.store_image_file(image['id'], image_file)
59 waiters.wait_for_image_status(self.images_client,
60 image['id'], 'active')
61 return image
62
Jordan Pittier3b46d272017-04-12 16:17:28 +020063 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080064 @decorators.idempotent_id('f131c586-9448-44a4-a8b0-54ca838aa43e')
nayna-patel179077c2014-01-15 12:27:16 +000065 def test_volume_get_nonexistent_volume_id(self):
zhufla5682372020-08-14 14:56:57 +080066 """Test getting non existent volume should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +020067 self.assertRaises(lib_exc.NotFound, self.volumes_client.show_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -070068 data_utils.rand_uuid())
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070069
Jordan Pittier3b46d272017-04-12 16:17:28 +020070 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080071 @decorators.idempotent_id('555efa6e-efcd-44ef-8a3b-4a7ca4837a29')
nayna-patel179077c2014-01-15 12:27:16 +000072 def test_volume_delete_nonexistent_volume_id(self):
zhufla5682372020-08-14 14:56:57 +080073 """Test deleting non existent volume should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +020074 self.assertRaises(lib_exc.NotFound, self.volumes_client.delete_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -070075 data_utils.rand_uuid())
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070076
Jordan Pittier3b46d272017-04-12 16:17:28 +020077 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080078 @decorators.idempotent_id('1ed83a8a-682d-4dfb-a30e-ee63ffd6c049')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070079 def test_create_volume_with_invalid_size(self):
zhufla5682372020-08-14 14:56:57 +080080 """Test creating volume with invalid size should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +020081 self.assertRaises(lib_exc.BadRequest,
zhufl9751b3d2017-03-29 18:01:01 +080082 self.volumes_client.create_volume, size='#$%')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070083
Jordan Pittier3b46d272017-04-12 16:17:28 +020084 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080085 @decorators.idempotent_id('9387686f-334f-4d31-a439-33494b9e2683')
zhufle2fb43e2016-11-24 10:52:16 +080086 def test_create_volume_without_passing_size(self):
zhufla5682372020-08-14 14:56:57 +080087 """Test creating volume with empty size should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +020088 self.assertRaises(lib_exc.BadRequest,
zhufl9751b3d2017-03-29 18:01:01 +080089 self.volumes_client.create_volume, size='')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070090
Jordan Pittier3b46d272017-04-12 16:17:28 +020091 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080092 @decorators.idempotent_id('41331caa-eaf4-4001-869d-bc18c1869360')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070093 def test_create_volume_with_size_zero(self):
zhufla5682372020-08-14 14:56:57 +080094 """Test creating volume with zero size should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +020095 self.assertRaises(lib_exc.BadRequest,
zhufl9751b3d2017-03-29 18:01:01 +080096 self.volumes_client.create_volume, size='0')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070097
Jordan Pittier3b46d272017-04-12 16:17:28 +020098 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080099 @decorators.idempotent_id('8b472729-9eba-446e-a83b-916bdb34bef7')
wanghaoc2abb6c2013-09-29 19:14:09 +0800100 def test_create_volume_with_size_negative(self):
zhufla5682372020-08-14 14:56:57 +0800101 """Test creating volume with negative size should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +0200102 self.assertRaises(lib_exc.BadRequest,
zhufl9751b3d2017-03-29 18:01:01 +0800103 self.volumes_client.create_volume, size='-1')
wanghaoc2abb6c2013-09-29 19:14:09 +0800104
Jordan Pittier3b46d272017-04-12 16:17:28 +0200105 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800106 @decorators.idempotent_id('10254ed8-3849-454e-862e-3ab8e6aa01d2')
nayna-patel179077c2014-01-15 12:27:16 +0000107 def test_create_volume_with_nonexistent_volume_type(self):
zhufla5682372020-08-14 14:56:57 +0800108 """Test creating volume with non existent volume type should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +0200109 self.assertRaises(lib_exc.NotFound, self.volumes_client.create_volume,
TommyLikefcda77b2018-01-18 15:25:12 +0800110 size=CONF.volume.volume_size,
111 volume_type=data_utils.rand_uuid())
zhangyanzib866f052013-10-12 11:41:32 +0800112
Jordan Pittier3b46d272017-04-12 16:17:28 +0200113 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800114 @decorators.idempotent_id('0c36f6ae-4604-4017-b0a9-34fdc63096f9')
nayna-patel179077c2014-01-15 12:27:16 +0000115 def test_create_volume_with_nonexistent_snapshot_id(self):
zhufla5682372020-08-14 14:56:57 +0800116 """Test creating volume with non existent snapshot should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +0200117 self.assertRaises(lib_exc.NotFound, self.volumes_client.create_volume,
TommyLikefcda77b2018-01-18 15:25:12 +0800118 size=CONF.volume.volume_size,
119 snapshot_id=data_utils.rand_uuid())
zhangyanzib866f052013-10-12 11:41:32 +0800120
Jordan Pittier3b46d272017-04-12 16:17:28 +0200121 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800122 @decorators.idempotent_id('47c73e08-4be8-45bb-bfdf-0c4e79b88344')
nayna-patel179077c2014-01-15 12:27:16 +0000123 def test_create_volume_with_nonexistent_source_volid(self):
zhufla5682372020-08-14 14:56:57 +0800124 """Test creating volume with non existent source volume should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +0200125 self.assertRaises(lib_exc.NotFound, self.volumes_client.create_volume,
TommyLikefcda77b2018-01-18 15:25:12 +0800126 size=CONF.volume.volume_size,
127 source_volid=data_utils.rand_uuid())
zhangyanzib866f052013-10-12 11:41:32 +0800128
Jordan Pittier3b46d272017-04-12 16:17:28 +0200129 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800130 @decorators.idempotent_id('0186422c-999a-480e-a026-6a665744c30c')
nayna-patel179077c2014-01-15 12:27:16 +0000131 def test_update_volume_with_nonexistent_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800132 """Test updating non existent volume should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +0200133 self.assertRaises(lib_exc.NotFound, self.volumes_client.update_volume,
zhufl06729552020-06-03 16:41:03 +0800134 volume_id=data_utils.rand_uuid(), name="n")
wanghaoc2abb6c2013-09-29 19:14:09 +0800135
Jordan Pittier3b46d272017-04-12 16:17:28 +0200136 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800137 @decorators.idempotent_id('e66e40d6-65e6-4e75-bdc7-636792fa152d')
wanghaoc2abb6c2013-09-29 19:14:09 +0800138 def test_update_volume_with_invalid_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800139 """Test updating volume with invalid volume id should fail"""
Martin Kopec213d0a42023-11-30 10:28:14 +0100140 self.assertRaises(
141 lib_exc.NotFound, self.volumes_client.update_volume,
142 volume_id=data_utils.rand_name(
143 prefix=CONF.resource_name_prefix,
144 name='invalid'), name="n")
wanghaoc2abb6c2013-09-29 19:14:09 +0800145
Jordan Pittier3b46d272017-04-12 16:17:28 +0200146 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800147 @decorators.idempotent_id('72aeca85-57a5-4c1f-9057-f320f9ea575b')
wanghaoc2abb6c2013-09-29 19:14:09 +0800148 def test_update_volume_with_empty_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800149 """Test updating volume with empty volume id should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +0200150 self.assertRaises(lib_exc.NotFound, self.volumes_client.update_volume,
zhufl9751b3d2017-03-29 18:01:01 +0800151 volume_id='')
wanghaoc2abb6c2013-09-29 19:14:09 +0800152
Jordan Pittier3b46d272017-04-12 16:17:28 +0200153 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800154 @decorators.idempotent_id('30799cfd-7ee4-446c-b66c-45b383ed211b')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700155 def test_get_invalid_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800156 """Test getting volume with invalid volume id should fail"""
Martin Kopec213d0a42023-11-30 10:28:14 +0100157 self.assertRaises(
158 lib_exc.NotFound, self.volumes_client.show_volume,
159 data_utils.rand_name(
160 prefix=CONF.resource_name_prefix, name='invalid'))
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700161
Jordan Pittier3b46d272017-04-12 16:17:28 +0200162 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800163 @decorators.idempotent_id('c6c3db06-29ad-4e91-beb0-2ab195fe49e3')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700164 def test_get_volume_without_passing_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800165 """Test getting volume with empty volume id should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +0200166 self.assertRaises(lib_exc.NotFound,
167 self.volumes_client.show_volume, '')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700168
Jordan Pittier3b46d272017-04-12 16:17:28 +0200169 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800170 @decorators.idempotent_id('1f035827-7c32-4019-9240-b4ec2dbd9dfd')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700171 def test_delete_invalid_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800172 """Test deleting volume with invalid volume id should fail"""
Martin Kopec213d0a42023-11-30 10:28:14 +0100173 self.assertRaises(
174 lib_exc.NotFound, self.volumes_client.delete_volume,
175 data_utils.rand_name(
176 prefix=CONF.resource_name_prefix, name='invalid'))
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700177
Jordan Pittier3b46d272017-04-12 16:17:28 +0200178 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800179 @decorators.idempotent_id('441a1550-5d44-4b30-af0f-a6d402f52026')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700180 def test_delete_volume_without_passing_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800181 """Test deleting volume with empty volume id should fail"""
lkuchlanb21fc572016-11-28 12:25:22 +0200182 self.assertRaises(lib_exc.NotFound,
183 self.volumes_client.delete_volume, '')
Matthew Treinish9854d5b2012-09-20 10:22:13 -0400184
Jordan Pittier3b46d272017-04-12 16:17:28 +0200185 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800186 @decorators.idempotent_id('f5e56b0a-5d02-43c1-a2a7-c9b792c2e3f6')
Andrea Frittolicd368412017-08-14 21:37:56 +0100187 @utils.services('compute')
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800188 def test_attach_volumes_with_nonexistent_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800189 """Test attaching non existent volume to server should fail"""
lkuchland4ecd0e2017-06-11 12:01:27 +0300190 server = self.create_server()
Joseph Lanouxa074c012015-08-04 15:44:07 +0000191
Masayuki Igawabfa07602015-01-20 18:47:17 +0900192 self.assertRaises(lib_exc.NotFound,
lkuchlanb21fc572016-11-28 12:25:22 +0200193 self.volumes_client.attach_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -0700194 data_utils.rand_uuid(),
Ghanshyam8fc0ed22015-12-18 10:25:14 +0900195 instance_uuid=server['id'],
lkuchlana54f1702017-09-11 11:06:55 +0300196 mountpoint="/dev/vdc")
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800197
Jordan Pittier3b46d272017-04-12 16:17:28 +0200198 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800199 @decorators.idempotent_id('9f9c24e4-011d-46b5-b992-952140ce237a')
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800200 def test_detach_volumes_with_invalid_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800201 """Test detaching volume with invalid volume id should fail"""
Masayuki Igawabfa07602015-01-20 18:47:17 +0900202 self.assertRaises(lib_exc.NotFound,
lkuchlanb21fc572016-11-28 12:25:22 +0200203 self.volumes_client.detach_volume,
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800204 'xxx')
205
Jordan Pittier3b46d272017-04-12 16:17:28 +0200206 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800207 @decorators.idempotent_id('e0c75c74-ee34-41a9-9288-2a2051452854')
wanghao5b981752013-10-22 11:41:41 +0800208 def test_volume_extend_with_size_smaller_than_original_size(self):
zhufla5682372020-08-14 14:56:57 +0800209 """Test extending volume with decreasing size should fail"""
wanghao5b981752013-10-22 11:41:41 +0800210 extend_size = 0
lkuchlanb21fc572016-11-28 12:25:22 +0200211 self.assertRaises(lib_exc.BadRequest,
212 self.volumes_client.extend_volume,
Ghanshyam58a9e872015-12-18 10:46:07 +0900213 self.volume['id'], new_size=extend_size)
wanghao5b981752013-10-22 11:41:41 +0800214
Jordan Pittier3b46d272017-04-12 16:17:28 +0200215 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800216 @decorators.idempotent_id('5d0b480d-e833-439f-8a5a-96ad2ed6f22f')
wanghao5b981752013-10-22 11:41:41 +0800217 def test_volume_extend_with_non_number_size(self):
zhufla5682372020-08-14 14:56:57 +0800218 """Test extending volume with non-integer size should fail"""
wanghao5b981752013-10-22 11:41:41 +0800219 extend_size = 'abc'
lkuchlanb21fc572016-11-28 12:25:22 +0200220 self.assertRaises(lib_exc.BadRequest,
221 self.volumes_client.extend_volume,
Ghanshyam58a9e872015-12-18 10:46:07 +0900222 self.volume['id'], new_size=extend_size)
wanghao5b981752013-10-22 11:41:41 +0800223
Jordan Pittier3b46d272017-04-12 16:17:28 +0200224 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800225 @decorators.idempotent_id('355218f1-8991-400a-a6bb-971239287d92')
wanghao5b981752013-10-22 11:41:41 +0800226 def test_volume_extend_with_None_size(self):
zhufla5682372020-08-14 14:56:57 +0800227 """Test extending volume with none size should fail"""
wanghao5b981752013-10-22 11:41:41 +0800228 extend_size = None
lkuchlanb21fc572016-11-28 12:25:22 +0200229 self.assertRaises(lib_exc.BadRequest,
230 self.volumes_client.extend_volume,
Ghanshyam58a9e872015-12-18 10:46:07 +0900231 self.volume['id'], new_size=extend_size)
wanghao5b981752013-10-22 11:41:41 +0800232
Jordan Pittier3b46d272017-04-12 16:17:28 +0200233 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800234 @decorators.idempotent_id('8f05a943-013c-4063-ac71-7baf561e82eb')
wanghao5b981752013-10-22 11:41:41 +0800235 def test_volume_extend_with_nonexistent_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800236 """Test extending non existent volume should fail"""
Martin Kopec37c4bd32021-06-24 15:46:00 +0000237 extend_size = self.volume['size'] + CONF.volume.volume_size_extend
lkuchlanb21fc572016-11-28 12:25:22 +0200238 self.assertRaises(lib_exc.NotFound, self.volumes_client.extend_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -0700239 data_utils.rand_uuid(), new_size=extend_size)
wanghao5b981752013-10-22 11:41:41 +0800240
Jordan Pittier3b46d272017-04-12 16:17:28 +0200241 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800242 @decorators.idempotent_id('aff8ba64-6d6f-4f2e-bc33-41a08ee9f115')
wanghao5b981752013-10-22 11:41:41 +0800243 def test_volume_extend_without_passing_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800244 """Test extending volume without passing volume id should fail"""
Martin Kopec37c4bd32021-06-24 15:46:00 +0000245 extend_size = self.volume['size'] + CONF.volume.volume_size_extend
lkuchlanb21fc572016-11-28 12:25:22 +0200246 self.assertRaises(lib_exc.NotFound, self.volumes_client.extend_volume,
Ghanshyam58a9e872015-12-18 10:46:07 +0900247 None, new_size=extend_size)
wanghao5b981752013-10-22 11:41:41 +0800248
Jordan Pittier3b46d272017-04-12 16:17:28 +0200249 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800250 @decorators.idempotent_id('ac6084c0-0546-45f9-b284-38a367e0e0e2')
zhangyanzi6b632432013-10-24 19:08:50 +0800251 def test_reserve_volume_with_nonexistent_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800252 """Test reserving non existent volume should fail"""
Masayuki Igawabfa07602015-01-20 18:47:17 +0900253 self.assertRaises(lib_exc.NotFound,
lkuchlanb21fc572016-11-28 12:25:22 +0200254 self.volumes_client.reserve_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -0700255 data_utils.rand_uuid())
zhangyanzi6b632432013-10-24 19:08:50 +0800256
Jordan Pittier3b46d272017-04-12 16:17:28 +0200257 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800258 @decorators.idempotent_id('eb467654-3dc1-4a72-9b46-47c29d22654c')
zhangyanzi6b632432013-10-24 19:08:50 +0800259 def test_unreserve_volume_with_nonexistent_volume_id(self):
zhufla5682372020-08-14 14:56:57 +0800260 """Test unreserving non existent volume should fail"""
Masayuki Igawabfa07602015-01-20 18:47:17 +0900261 self.assertRaises(lib_exc.NotFound,
lkuchlanb21fc572016-11-28 12:25:22 +0200262 self.volumes_client.unreserve_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -0700263 data_utils.rand_uuid())
zhangyanzi6b632432013-10-24 19:08:50 +0800264
Jordan Pittier3b46d272017-04-12 16:17:28 +0200265 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800266 @decorators.idempotent_id('449c4ed2-ecdd-47bb-98dc-072aeccf158c')
zhangyanzi6b632432013-10-24 19:08:50 +0800267 def test_reserve_volume_with_negative_volume_status(self):
zhufla5682372020-08-14 14:56:57 +0800268 """Test reserving already reserved volume should fail"""
Roman Bubyred1f02b2022-08-03 13:49:37 +0300269
270 # Skip test if the volume has "multiattach" property
271 volume = self.volumes_client.show_volume(self.volume['id'])
272 if volume['multiattach']:
273 raise self.skipException('Reserving multiattach volumes is not'
274 ' supported.')
275
zhangyanzi6b632432013-10-24 19:08:50 +0800276 # Mark volume as reserved.
lkuchlanb21fc572016-11-28 12:25:22 +0200277 self.volumes_client.reserve_volume(self.volume['id'])
zhangyanzi6b632432013-10-24 19:08:50 +0800278 # Mark volume which is marked as reserved before
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900279 self.assertRaises(lib_exc.BadRequest,
lkuchlanb21fc572016-11-28 12:25:22 +0200280 self.volumes_client.reserve_volume,
zhangyanzi6b632432013-10-24 19:08:50 +0800281 self.volume['id'])
282 # Unmark volume as reserved.
lkuchlanb21fc572016-11-28 12:25:22 +0200283 self.volumes_client.unreserve_volume(self.volume['id'])
zhangyanzi6b632432013-10-24 19:08:50 +0800284
Jordan Pittier3b46d272017-04-12 16:17:28 +0200285 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800286 @decorators.idempotent_id('0f4aa809-8c7b-418f-8fb3-84c7a5dfc52f')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800287 def test_list_volumes_with_nonexistent_name(self):
zhufla5682372020-08-14 14:56:57 +0800288 """Test listing volumes with non existent name should get nothing"""
Martin Kopec213d0a42023-11-30 10:28:14 +0100289 v_name = data_utils.rand_name(
290 prefix=CONF.resource_name_prefix,
291 name=self.__class__.__name__ + '-Volume')
zhufla57530c2017-03-23 11:38:12 +0800292 params = {'name': v_name}
lkuchlanb21fc572016-11-28 12:25:22 +0200293 fetched_volume = self.volumes_client.list_volumes(
294 params=params)['volumes']
Masayuki Igawaf9009b42017-04-10 14:49:29 +0900295 self.assertEmpty(fetched_volume)
Zhi Kun Liu42403182013-10-11 18:05:08 +0800296
Jordan Pittier3b46d272017-04-12 16:17:28 +0200297 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800298 @decorators.idempotent_id('9ca17820-a0e7-4cbd-a7fa-f4468735e359')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800299 def test_list_volumes_detail_with_nonexistent_name(self):
zhufla5682372020-08-14 14:56:57 +0800300 """Test listing volume details with non existent name
301
302 Listing volume details with non existent name should get nothing.
303 """
Martin Kopec213d0a42023-11-30 10:28:14 +0100304 v_name = data_utils.rand_name(
305 prefix=CONF.resource_name_prefix,
306 name=self.__class__.__name__ + '-Volume')
zhufla57530c2017-03-23 11:38:12 +0800307 params = {'name': v_name}
Joseph Lanoux6809bab2014-12-18 14:57:18 +0000308 fetched_volume = \
lkuchlanb21fc572016-11-28 12:25:22 +0200309 self.volumes_client.list_volumes(
310 detail=True, params=params)['volumes']
Masayuki Igawaf9009b42017-04-10 14:49:29 +0900311 self.assertEmpty(fetched_volume)
Zhi Kun Liu42403182013-10-11 18:05:08 +0800312
Jordan Pittier3b46d272017-04-12 16:17:28 +0200313 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800314 @decorators.idempotent_id('143b279b-7522-466b-81be-34a87d564a7c')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800315 def test_list_volumes_with_invalid_status(self):
zhufla5682372020-08-14 14:56:57 +0800316 """Test listing volumes with invalid status should get nothing"""
Zhi Kun Liu42403182013-10-11 18:05:08 +0800317 params = {'status': 'null'}
lkuchlanb21fc572016-11-28 12:25:22 +0200318 fetched_volume = self.volumes_client.list_volumes(
319 params=params)['volumes']
Masayuki Igawaf9009b42017-04-10 14:49:29 +0900320 self.assertEmpty(fetched_volume)
Zhi Kun Liu42403182013-10-11 18:05:08 +0800321
Jordan Pittier3b46d272017-04-12 16:17:28 +0200322 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800323 @decorators.idempotent_id('ba94b27b-be3f-496c-a00e-0283b373fa75')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800324 def test_list_volumes_detail_with_invalid_status(self):
zhufla5682372020-08-14 14:56:57 +0800325 """Test listing volume details with invalid status
326
327 Listing volume details with invalid status should get nothing
328 """
Zhi Kun Liu42403182013-10-11 18:05:08 +0800329 params = {'status': 'null'}
Joseph Lanoux6809bab2014-12-18 14:57:18 +0000330 fetched_volume = \
lkuchlanb21fc572016-11-28 12:25:22 +0200331 self.volumes_client.list_volumes(detail=True,
332 params=params)['volumes']
Masayuki Igawaf9009b42017-04-10 14:49:29 +0900333 self.assertEmpty(fetched_volume)
jeremy.zhang0a427162017-04-21 12:47:56 +0800334
335 @decorators.attr(type=['negative'])
336 @decorators.idempotent_id('5b810c91-0ad1-47ce-aee8-615f789be78f')
Andrea Frittolicd368412017-08-14 21:37:56 +0100337 @utils.services('image')
jeremy.zhang0a427162017-04-21 12:47:56 +0800338 def test_create_volume_from_image_with_decreasing_size(self):
zhufla5682372020-08-14 14:56:57 +0800339 """Test creating volume from image with decreasing size should fail"""
jeremy.zhang0a427162017-04-21 12:47:56 +0800340 # Create image
lkuchlan13736ae2017-04-24 14:49:45 +0300341 image = self.create_image()
jeremy.zhang0a427162017-04-21 12:47:56 +0800342
343 # Note(jeremyZ): To shorten the test time (uploading a big size image
344 # is time-consuming), here just consider the scenario that volume size
345 # is smaller than the min_disk of image.
346 self.assertRaises(lib_exc.BadRequest,
347 self.volumes_client.create_volume,
348 size=CONF.volume.volume_size,
349 imageRef=image['id'])
lkuchlan13736ae2017-04-24 14:49:45 +0300350
351 @decorators.attr(type=['negative'])
352 @decorators.idempotent_id('d15e7f35-2cfc-48c8-9418-c8223a89bcbb')
Andrea Frittolicd368412017-08-14 21:37:56 +0100353 @utils.services('image')
lkuchlan13736ae2017-04-24 14:49:45 +0300354 def test_create_volume_from_deactivated_image(self):
zhufla5682372020-08-14 14:56:57 +0800355 """Test creating volume from deactivated image should fail"""
lkuchlan13736ae2017-04-24 14:49:45 +0300356 # Create image
357 image = self.create_image()
358
359 # Deactivate the image
360 self.images_client.deactivate_image(image['id'])
Felix Huettnerd05536b2021-03-08 08:48:43 +0100361 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
362 self.images_client.reactivate_image, image['id'])
363
lkuchlan13736ae2017-04-24 14:49:45 +0300364 body = self.images_client.show_image(image['id'])
365 self.assertEqual("deactivated", body['status'])
366 # Try creating a volume from deactivated image
367 self.assertRaises(lib_exc.BadRequest,
368 self.create_volume,
369 imageRef=image['id'])