blob: 4e19e620fd32ad5fb18098ddf185f1abf5138159 [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
jeremy.zhang0a427162017-04-21 12:47:56 +080016import six
17
Sean Dague1937d092013-05-17 16:36:38 -040018from tempest.api.volume import base
jeremy.zhang0a427162017-04-21 12:47:56 +080019from tempest.common import waiters
20from tempest import config
Ken'ichi Ohmichief1c1ce2017-03-10 11:07:10 -080021from tempest.lib.common.utils import data_utils
jeremy.zhang0a427162017-04-21 12:47:56 +080022from tempest.lib.common.utils import test_utils
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080023from tempest.lib import decorators
Andrea Frittoli (andreaf)db9672e2016-02-23 14:07:24 -050024from tempest.lib import exceptions as lib_exc
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090025from tempest import test
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):
Attila Fazekas3dcdae12013-02-14 12:50:04 +010031
32 @classmethod
Andrea Frittoli61a12e22014-09-15 13:14:54 +010033 def resource_setup(cls):
Ken'ichi Ohmichie8afb8c2017-03-27 11:25:37 -070034 super(VolumesNegativeTest, cls).resource_setup()
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070035
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080036 # Create a test shared instance and volume for attach/detach tests
Ken'ichi Ohmichi5687d552013-12-26 19:00:12 +090037 cls.volume = cls.create_volume()
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080038 cls.mountpoint = "/dev/vdc"
39
lkuchlan13736ae2017-04-24 14:49:45 +030040 def create_image(self):
41 # Create image
42 image_name = data_utils.rand_name(self.__class__.__name__ + "-image")
43 image = self.images_client.create_image(
44 name=image_name,
45 container_format=CONF.image.container_formats[0],
46 disk_format=CONF.image.disk_formats[0],
47 visibility='private',
48 min_disk=CONF.volume.volume_size + 1)
49 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
50 self.images_client.delete_image, image['id'])
51
52 # Upload image with 1KB data
53 image_file = six.BytesIO(data_utils.random_bytes())
54 self.images_client.store_image_file(image['id'], image_file)
55 waiters.wait_for_image_status(self.images_client,
56 image['id'], 'active')
57 return image
58
Jordan Pittier3b46d272017-04-12 16:17:28 +020059 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080060 @decorators.idempotent_id('f131c586-9448-44a4-a8b0-54ca838aa43e')
nayna-patel179077c2014-01-15 12:27:16 +000061 def test_volume_get_nonexistent_volume_id(self):
62 # Should not be able to get a non-existent volume
lkuchlanb21fc572016-11-28 12:25:22 +020063 self.assertRaises(lib_exc.NotFound, self.volumes_client.show_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -070064 data_utils.rand_uuid())
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070065
Jordan Pittier3b46d272017-04-12 16:17:28 +020066 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080067 @decorators.idempotent_id('555efa6e-efcd-44ef-8a3b-4a7ca4837a29')
nayna-patel179077c2014-01-15 12:27:16 +000068 def test_volume_delete_nonexistent_volume_id(self):
69 # Should not be able to delete a non-existent Volume
lkuchlanb21fc572016-11-28 12:25:22 +020070 self.assertRaises(lib_exc.NotFound, self.volumes_client.delete_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -070071 data_utils.rand_uuid())
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070072
Jordan Pittier3b46d272017-04-12 16:17:28 +020073 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080074 @decorators.idempotent_id('1ed83a8a-682d-4dfb-a30e-ee63ffd6c049')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070075 def test_create_volume_with_invalid_size(self):
zhufl9751b3d2017-03-29 18:01:01 +080076 # Should not be able to create volume with invalid size in request
lkuchlanb21fc572016-11-28 12:25:22 +020077 self.assertRaises(lib_exc.BadRequest,
zhufl9751b3d2017-03-29 18:01:01 +080078 self.volumes_client.create_volume, size='#$%')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070079
Jordan Pittier3b46d272017-04-12 16:17:28 +020080 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080081 @decorators.idempotent_id('9387686f-334f-4d31-a439-33494b9e2683')
zhufle2fb43e2016-11-24 10:52:16 +080082 def test_create_volume_without_passing_size(self):
Sean Dague72a00382013-01-03 17:53:38 -050083 # Should not be able to create volume without passing size
84 # in request
lkuchlanb21fc572016-11-28 12:25:22 +020085 self.assertRaises(lib_exc.BadRequest,
zhufl9751b3d2017-03-29 18:01:01 +080086 self.volumes_client.create_volume, size='')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070087
Jordan Pittier3b46d272017-04-12 16:17:28 +020088 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080089 @decorators.idempotent_id('41331caa-eaf4-4001-869d-bc18c1869360')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070090 def test_create_volume_with_size_zero(self):
Sean Dague72a00382013-01-03 17:53:38 -050091 # Should not be able to create volume with size zero
lkuchlanb21fc572016-11-28 12:25:22 +020092 self.assertRaises(lib_exc.BadRequest,
zhufl9751b3d2017-03-29 18:01:01 +080093 self.volumes_client.create_volume, size='0')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070094
Jordan Pittier3b46d272017-04-12 16:17:28 +020095 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -080096 @decorators.idempotent_id('8b472729-9eba-446e-a83b-916bdb34bef7')
wanghaoc2abb6c2013-09-29 19:14:09 +080097 def test_create_volume_with_size_negative(self):
98 # Should not be able to create volume with size negative
lkuchlanb21fc572016-11-28 12:25:22 +020099 self.assertRaises(lib_exc.BadRequest,
zhufl9751b3d2017-03-29 18:01:01 +0800100 self.volumes_client.create_volume, size='-1')
wanghaoc2abb6c2013-09-29 19:14:09 +0800101
Jordan Pittier3b46d272017-04-12 16:17:28 +0200102 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800103 @decorators.idempotent_id('10254ed8-3849-454e-862e-3ab8e6aa01d2')
nayna-patel179077c2014-01-15 12:27:16 +0000104 def test_create_volume_with_nonexistent_volume_type(self):
105 # Should not be able to create volume with non-existent volume type
lkuchlanb21fc572016-11-28 12:25:22 +0200106 self.assertRaises(lib_exc.NotFound, self.volumes_client.create_volume,
zhufl9751b3d2017-03-29 18:01:01 +0800107 size='1', volume_type=data_utils.rand_uuid())
zhangyanzib866f052013-10-12 11:41:32 +0800108
Jordan Pittier3b46d272017-04-12 16:17:28 +0200109 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800110 @decorators.idempotent_id('0c36f6ae-4604-4017-b0a9-34fdc63096f9')
nayna-patel179077c2014-01-15 12:27:16 +0000111 def test_create_volume_with_nonexistent_snapshot_id(self):
112 # Should not be able to create volume with non-existent snapshot
lkuchlanb21fc572016-11-28 12:25:22 +0200113 self.assertRaises(lib_exc.NotFound, self.volumes_client.create_volume,
zhufl9751b3d2017-03-29 18:01:01 +0800114 size='1', snapshot_id=data_utils.rand_uuid())
zhangyanzib866f052013-10-12 11:41:32 +0800115
Jordan Pittier3b46d272017-04-12 16:17:28 +0200116 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800117 @decorators.idempotent_id('47c73e08-4be8-45bb-bfdf-0c4e79b88344')
nayna-patel179077c2014-01-15 12:27:16 +0000118 def test_create_volume_with_nonexistent_source_volid(self):
119 # Should not be able to create volume with non-existent source volume
lkuchlanb21fc572016-11-28 12:25:22 +0200120 self.assertRaises(lib_exc.NotFound, self.volumes_client.create_volume,
zhufl9751b3d2017-03-29 18:01:01 +0800121 size='1', source_volid=data_utils.rand_uuid())
zhangyanzib866f052013-10-12 11:41:32 +0800122
Jordan Pittier3b46d272017-04-12 16:17:28 +0200123 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800124 @decorators.idempotent_id('0186422c-999a-480e-a026-6a665744c30c')
nayna-patel179077c2014-01-15 12:27:16 +0000125 def test_update_volume_with_nonexistent_volume_id(self):
lkuchlanb21fc572016-11-28 12:25:22 +0200126 self.assertRaises(lib_exc.NotFound, self.volumes_client.update_volume,
zhufl9751b3d2017-03-29 18:01:01 +0800127 volume_id=data_utils.rand_uuid())
wanghaoc2abb6c2013-09-29 19:14:09 +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('e66e40d6-65e6-4e75-bdc7-636792fa152d')
wanghaoc2abb6c2013-09-29 19:14:09 +0800131 def test_update_volume_with_invalid_volume_id(self):
lkuchlanb21fc572016-11-28 12:25:22 +0200132 self.assertRaises(lib_exc.NotFound, self.volumes_client.update_volume,
zhufl9751b3d2017-03-29 18:01:01 +0800133 volume_id=data_utils.rand_name('invalid'))
wanghaoc2abb6c2013-09-29 19:14:09 +0800134
Jordan Pittier3b46d272017-04-12 16:17:28 +0200135 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800136 @decorators.idempotent_id('72aeca85-57a5-4c1f-9057-f320f9ea575b')
wanghaoc2abb6c2013-09-29 19:14:09 +0800137 def test_update_volume_with_empty_volume_id(self):
lkuchlanb21fc572016-11-28 12:25:22 +0200138 self.assertRaises(lib_exc.NotFound, self.volumes_client.update_volume,
zhufl9751b3d2017-03-29 18:01:01 +0800139 volume_id='')
wanghaoc2abb6c2013-09-29 19:14:09 +0800140
Jordan Pittier3b46d272017-04-12 16:17:28 +0200141 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800142 @decorators.idempotent_id('30799cfd-7ee4-446c-b66c-45b383ed211b')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700143 def test_get_invalid_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500144 # Should not be able to get volume with invalid id
lkuchlanb21fc572016-11-28 12:25:22 +0200145 self.assertRaises(lib_exc.NotFound, self.volumes_client.show_volume,
ghanshyam9e294c42017-01-12 06:52:41 +0000146 data_utils.rand_name('invalid'))
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700147
Jordan Pittier3b46d272017-04-12 16:17:28 +0200148 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800149 @decorators.idempotent_id('c6c3db06-29ad-4e91-beb0-2ab195fe49e3')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700150 def test_get_volume_without_passing_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500151 # Should not be able to get volume when empty ID is passed
lkuchlanb21fc572016-11-28 12:25:22 +0200152 self.assertRaises(lib_exc.NotFound,
153 self.volumes_client.show_volume, '')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700154
Jordan Pittier3b46d272017-04-12 16:17:28 +0200155 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800156 @decorators.idempotent_id('1f035827-7c32-4019-9240-b4ec2dbd9dfd')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700157 def test_delete_invalid_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500158 # Should not be able to delete volume when invalid ID is passed
lkuchlanb21fc572016-11-28 12:25:22 +0200159 self.assertRaises(lib_exc.NotFound, self.volumes_client.delete_volume,
ghanshyam9e294c42017-01-12 06:52:41 +0000160 data_utils.rand_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('441a1550-5d44-4b30-af0f-a6d402f52026')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700164 def test_delete_volume_without_passing_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500165 # Should not be able to delete volume when empty ID is passed
lkuchlanb21fc572016-11-28 12:25:22 +0200166 self.assertRaises(lib_exc.NotFound,
167 self.volumes_client.delete_volume, '')
Matthew Treinish9854d5b2012-09-20 10:22:13 -0400168
Jordan Pittier3b46d272017-04-12 16:17:28 +0200169 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800170 @decorators.idempotent_id('f5e56b0a-5d02-43c1-a2a7-c9b792c2e3f6')
Matthew Treinish7ea69e62014-06-03 17:23:50 -0400171 @test.services('compute')
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800172 def test_attach_volumes_with_nonexistent_volume_id(self):
lkuchland4ecd0e2017-06-11 12:01:27 +0300173 server = self.create_server()
Joseph Lanouxa074c012015-08-04 15:44:07 +0000174
Masayuki Igawabfa07602015-01-20 18:47:17 +0900175 self.assertRaises(lib_exc.NotFound,
lkuchlanb21fc572016-11-28 12:25:22 +0200176 self.volumes_client.attach_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -0700177 data_utils.rand_uuid(),
Ghanshyam8fc0ed22015-12-18 10:25:14 +0900178 instance_uuid=server['id'],
179 mountpoint=self.mountpoint)
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800180
Jordan Pittier3b46d272017-04-12 16:17:28 +0200181 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800182 @decorators.idempotent_id('9f9c24e4-011d-46b5-b992-952140ce237a')
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800183 def test_detach_volumes_with_invalid_volume_id(self):
Masayuki Igawabfa07602015-01-20 18:47:17 +0900184 self.assertRaises(lib_exc.NotFound,
lkuchlanb21fc572016-11-28 12:25:22 +0200185 self.volumes_client.detach_volume,
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800186 'xxx')
187
Jordan Pittier3b46d272017-04-12 16:17:28 +0200188 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800189 @decorators.idempotent_id('e0c75c74-ee34-41a9-9288-2a2051452854')
wanghao5b981752013-10-22 11:41:41 +0800190 def test_volume_extend_with_size_smaller_than_original_size(self):
191 # Extend volume with smaller size than original size.
192 extend_size = 0
lkuchlanb21fc572016-11-28 12:25:22 +0200193 self.assertRaises(lib_exc.BadRequest,
194 self.volumes_client.extend_volume,
Ghanshyam58a9e872015-12-18 10:46:07 +0900195 self.volume['id'], new_size=extend_size)
wanghao5b981752013-10-22 11:41:41 +0800196
Jordan Pittier3b46d272017-04-12 16:17:28 +0200197 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800198 @decorators.idempotent_id('5d0b480d-e833-439f-8a5a-96ad2ed6f22f')
wanghao5b981752013-10-22 11:41:41 +0800199 def test_volume_extend_with_non_number_size(self):
200 # Extend volume when size is non number.
201 extend_size = 'abc'
lkuchlanb21fc572016-11-28 12:25:22 +0200202 self.assertRaises(lib_exc.BadRequest,
203 self.volumes_client.extend_volume,
Ghanshyam58a9e872015-12-18 10:46:07 +0900204 self.volume['id'], new_size=extend_size)
wanghao5b981752013-10-22 11:41:41 +0800205
Jordan Pittier3b46d272017-04-12 16:17:28 +0200206 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800207 @decorators.idempotent_id('355218f1-8991-400a-a6bb-971239287d92')
wanghao5b981752013-10-22 11:41:41 +0800208 def test_volume_extend_with_None_size(self):
209 # Extend volume with None size.
210 extend_size = None
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('8f05a943-013c-4063-ac71-7baf561e82eb')
wanghao5b981752013-10-22 11:41:41 +0800217 def test_volume_extend_with_nonexistent_volume_id(self):
218 # Extend volume size when volume is nonexistent.
Avi Avrahamd77d3d12017-02-15 16:45:25 +0200219 extend_size = self.volume['size'] + 1
lkuchlanb21fc572016-11-28 12:25:22 +0200220 self.assertRaises(lib_exc.NotFound, self.volumes_client.extend_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -0700221 data_utils.rand_uuid(), new_size=extend_size)
wanghao5b981752013-10-22 11:41:41 +0800222
Jordan Pittier3b46d272017-04-12 16:17:28 +0200223 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800224 @decorators.idempotent_id('aff8ba64-6d6f-4f2e-bc33-41a08ee9f115')
wanghao5b981752013-10-22 11:41:41 +0800225 def test_volume_extend_without_passing_volume_id(self):
226 # Extend volume size when passing volume id is None.
Avi Avrahamd77d3d12017-02-15 16:45:25 +0200227 extend_size = self.volume['size'] + 1
lkuchlanb21fc572016-11-28 12:25:22 +0200228 self.assertRaises(lib_exc.NotFound, self.volumes_client.extend_volume,
Ghanshyam58a9e872015-12-18 10:46:07 +0900229 None, new_size=extend_size)
wanghao5b981752013-10-22 11:41:41 +0800230
Jordan Pittier3b46d272017-04-12 16:17:28 +0200231 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800232 @decorators.idempotent_id('ac6084c0-0546-45f9-b284-38a367e0e0e2')
zhangyanzi6b632432013-10-24 19:08:50 +0800233 def test_reserve_volume_with_nonexistent_volume_id(self):
Masayuki Igawabfa07602015-01-20 18:47:17 +0900234 self.assertRaises(lib_exc.NotFound,
lkuchlanb21fc572016-11-28 12:25:22 +0200235 self.volumes_client.reserve_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -0700236 data_utils.rand_uuid())
zhangyanzi6b632432013-10-24 19:08:50 +0800237
Jordan Pittier3b46d272017-04-12 16:17:28 +0200238 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800239 @decorators.idempotent_id('eb467654-3dc1-4a72-9b46-47c29d22654c')
zhangyanzi6b632432013-10-24 19:08:50 +0800240 def test_unreserve_volume_with_nonexistent_volume_id(self):
Masayuki Igawabfa07602015-01-20 18:47:17 +0900241 self.assertRaises(lib_exc.NotFound,
lkuchlanb21fc572016-11-28 12:25:22 +0200242 self.volumes_client.unreserve_volume,
Ken'ichi Ohmichid079c892016-04-19 11:23:36 -0700243 data_utils.rand_uuid())
zhangyanzi6b632432013-10-24 19:08:50 +0800244
Jordan Pittier3b46d272017-04-12 16:17:28 +0200245 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800246 @decorators.idempotent_id('449c4ed2-ecdd-47bb-98dc-072aeccf158c')
zhangyanzi6b632432013-10-24 19:08:50 +0800247 def test_reserve_volume_with_negative_volume_status(self):
248 # Mark volume as reserved.
lkuchlanb21fc572016-11-28 12:25:22 +0200249 self.volumes_client.reserve_volume(self.volume['id'])
zhangyanzi6b632432013-10-24 19:08:50 +0800250 # Mark volume which is marked as reserved before
Masayuki Igawa4b29e472015-02-16 10:41:54 +0900251 self.assertRaises(lib_exc.BadRequest,
lkuchlanb21fc572016-11-28 12:25:22 +0200252 self.volumes_client.reserve_volume,
zhangyanzi6b632432013-10-24 19:08:50 +0800253 self.volume['id'])
254 # Unmark volume as reserved.
lkuchlanb21fc572016-11-28 12:25:22 +0200255 self.volumes_client.unreserve_volume(self.volume['id'])
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('0f4aa809-8c7b-418f-8fb3-84c7a5dfc52f')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800259 def test_list_volumes_with_nonexistent_name(self):
zhuflc6ce5392016-08-17 14:34:37 +0800260 v_name = data_utils.rand_name(self.__class__.__name__ + '-Volume')
zhufla57530c2017-03-23 11:38:12 +0800261 params = {'name': v_name}
lkuchlanb21fc572016-11-28 12:25:22 +0200262 fetched_volume = self.volumes_client.list_volumes(
263 params=params)['volumes']
Masayuki Igawaf9009b42017-04-10 14:49:29 +0900264 self.assertEmpty(fetched_volume)
Zhi Kun Liu42403182013-10-11 18:05:08 +0800265
Jordan Pittier3b46d272017-04-12 16:17:28 +0200266 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800267 @decorators.idempotent_id('9ca17820-a0e7-4cbd-a7fa-f4468735e359')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800268 def test_list_volumes_detail_with_nonexistent_name(self):
zhuflc6ce5392016-08-17 14:34:37 +0800269 v_name = data_utils.rand_name(self.__class__.__name__ + '-Volume')
zhufla57530c2017-03-23 11:38:12 +0800270 params = {'name': v_name}
Joseph Lanoux6809bab2014-12-18 14:57:18 +0000271 fetched_volume = \
lkuchlanb21fc572016-11-28 12:25:22 +0200272 self.volumes_client.list_volumes(
273 detail=True, params=params)['volumes']
Masayuki Igawaf9009b42017-04-10 14:49:29 +0900274 self.assertEmpty(fetched_volume)
Zhi Kun Liu42403182013-10-11 18:05:08 +0800275
Jordan Pittier3b46d272017-04-12 16:17:28 +0200276 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800277 @decorators.idempotent_id('143b279b-7522-466b-81be-34a87d564a7c')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800278 def test_list_volumes_with_invalid_status(self):
279 params = {'status': 'null'}
lkuchlanb21fc572016-11-28 12:25:22 +0200280 fetched_volume = self.volumes_client.list_volumes(
281 params=params)['volumes']
Masayuki Igawaf9009b42017-04-10 14:49:29 +0900282 self.assertEmpty(fetched_volume)
Zhi Kun Liu42403182013-10-11 18:05:08 +0800283
Jordan Pittier3b46d272017-04-12 16:17:28 +0200284 @decorators.attr(type=['negative'])
Ken'ichi Ohmichi6b279c72017-01-27 18:26:59 -0800285 @decorators.idempotent_id('ba94b27b-be3f-496c-a00e-0283b373fa75')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800286 def test_list_volumes_detail_with_invalid_status(self):
287 params = {'status': 'null'}
Joseph Lanoux6809bab2014-12-18 14:57:18 +0000288 fetched_volume = \
lkuchlanb21fc572016-11-28 12:25:22 +0200289 self.volumes_client.list_volumes(detail=True,
290 params=params)['volumes']
Masayuki Igawaf9009b42017-04-10 14:49:29 +0900291 self.assertEmpty(fetched_volume)
jeremy.zhang0a427162017-04-21 12:47:56 +0800292
293 @decorators.attr(type=['negative'])
294 @decorators.idempotent_id('5b810c91-0ad1-47ce-aee8-615f789be78f')
295 @test.services('image')
296 def test_create_volume_from_image_with_decreasing_size(self):
297 # Create image
lkuchlan13736ae2017-04-24 14:49:45 +0300298 image = self.create_image()
jeremy.zhang0a427162017-04-21 12:47:56 +0800299
300 # Note(jeremyZ): To shorten the test time (uploading a big size image
301 # is time-consuming), here just consider the scenario that volume size
302 # is smaller than the min_disk of image.
303 self.assertRaises(lib_exc.BadRequest,
304 self.volumes_client.create_volume,
305 size=CONF.volume.volume_size,
306 imageRef=image['id'])
lkuchlan13736ae2017-04-24 14:49:45 +0300307
308 @decorators.attr(type=['negative'])
309 @decorators.idempotent_id('d15e7f35-2cfc-48c8-9418-c8223a89bcbb')
310 @test.services('image')
311 def test_create_volume_from_deactivated_image(self):
312 # Create image
313 image = self.create_image()
314
315 # Deactivate the image
316 self.images_client.deactivate_image(image['id'])
317 body = self.images_client.show_image(image['id'])
318 self.assertEqual("deactivated", body['status'])
319 # Try creating a volume from deactivated image
320 self.assertRaises(lib_exc.BadRequest,
321 self.create_volume,
322 imageRef=image['id'])