blob: 82924a5630e8fad5144891fd9bf60c890357bb48 [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
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080016import uuid
17
Sean Dague1937d092013-05-17 16:36:38 -040018from tempest.api.volume import base
Masayuki Igawa259c1132013-10-31 17:48:44 +090019from tempest.common.utils import data_utils
Matthew Treinisha83a16e2012-12-07 13:44:02 -050020from tempest import exceptions
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090021from tempest import test
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070022
23
Zhi Kun Liubb363a22013-11-28 18:47:39 +080024class VolumesNegativeTest(base.BaseVolumeV1Test):
Attila Fazekas3dcdae12013-02-14 12:50:04 +010025 _interface = 'json'
26
27 @classmethod
28 def setUpClass(cls):
29 super(VolumesNegativeTest, cls).setUpClass()
30 cls.client = cls.volumes_client
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070031
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080032 # Create a test shared instance and volume for attach/detach tests
Ken'ichi Ohmichi5687d552013-12-26 19:00:12 +090033 cls.volume = cls.create_volume()
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080034 cls.mountpoint = "/dev/vdc"
35
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090036 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +000037 def test_volume_get_nonexistent_volume_id(self):
38 # Should not be able to get a non-existent volume
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103039 self.assertRaises(exceptions.NotFound, self.client.get_volume,
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080040 str(uuid.uuid4()))
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070041
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090042 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +000043 def test_volume_delete_nonexistent_volume_id(self):
44 # Should not be able to delete a non-existent Volume
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103045 self.assertRaises(exceptions.NotFound, self.client.delete_volume,
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080046 str(uuid.uuid4()))
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070047
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090048 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070049 def test_create_volume_with_invalid_size(self):
Sean Dague72a00382013-01-03 17:53:38 -050050 # Should not be able to create volume with invalid size
51 # in request
Masayuki Igawa259c1132013-10-31 17:48:44 +090052 v_name = data_utils.rand_name('Volume-')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070053 metadata = {'Type': 'work'}
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103054 self.assertRaises(exceptions.BadRequest, self.client.create_volume,
55 size='#$%', display_name=v_name, metadata=metadata)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070056
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090057 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070058 def test_create_volume_with_out_passing_size(self):
Sean Dague72a00382013-01-03 17:53:38 -050059 # Should not be able to create volume without passing size
60 # in request
Masayuki Igawa259c1132013-10-31 17:48:44 +090061 v_name = data_utils.rand_name('Volume-')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070062 metadata = {'Type': 'work'}
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103063 self.assertRaises(exceptions.BadRequest, self.client.create_volume,
64 size='', display_name=v_name, metadata=metadata)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070065
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090066 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070067 def test_create_volume_with_size_zero(self):
Sean Dague72a00382013-01-03 17:53:38 -050068 # Should not be able to create volume with size zero
Masayuki Igawa259c1132013-10-31 17:48:44 +090069 v_name = data_utils.rand_name('Volume-')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070070 metadata = {'Type': 'work'}
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103071 self.assertRaises(exceptions.BadRequest, self.client.create_volume,
72 size='0', display_name=v_name, metadata=metadata)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070073
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090074 @test.attr(type=['negative', 'gate'])
wanghaoc2abb6c2013-09-29 19:14:09 +080075 def test_create_volume_with_size_negative(self):
76 # Should not be able to create volume with size negative
Masayuki Igawa259c1132013-10-31 17:48:44 +090077 v_name = data_utils.rand_name('Volume-')
wanghaoc2abb6c2013-09-29 19:14:09 +080078 metadata = {'Type': 'work'}
79 self.assertRaises(exceptions.BadRequest, self.client.create_volume,
80 size='-1', display_name=v_name, metadata=metadata)
81
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090082 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +000083 def test_create_volume_with_nonexistent_volume_type(self):
84 # Should not be able to create volume with non-existent volume type
Masayuki Igawa259c1132013-10-31 17:48:44 +090085 v_name = data_utils.rand_name('Volume-')
zhangyanzib866f052013-10-12 11:41:32 +080086 metadata = {'Type': 'work'}
87 self.assertRaises(exceptions.NotFound, self.client.create_volume,
88 size='1', volume_type=str(uuid.uuid4()),
89 display_name=v_name, metadata=metadata)
90
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090091 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +000092 def test_create_volume_with_nonexistent_snapshot_id(self):
93 # Should not be able to create volume with non-existent snapshot
Masayuki Igawa259c1132013-10-31 17:48:44 +090094 v_name = data_utils.rand_name('Volume-')
zhangyanzib866f052013-10-12 11:41:32 +080095 metadata = {'Type': 'work'}
96 self.assertRaises(exceptions.NotFound, self.client.create_volume,
97 size='1', snapshot_id=str(uuid.uuid4()),
98 display_name=v_name, metadata=metadata)
99
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900100 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +0000101 def test_create_volume_with_nonexistent_source_volid(self):
102 # Should not be able to create volume with non-existent source volume
Masayuki Igawa259c1132013-10-31 17:48:44 +0900103 v_name = data_utils.rand_name('Volume-')
zhangyanzib866f052013-10-12 11:41:32 +0800104 metadata = {'Type': 'work'}
105 self.assertRaises(exceptions.NotFound, self.client.create_volume,
106 size='1', source_volid=str(uuid.uuid4()),
107 display_name=v_name, metadata=metadata)
108
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900109 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +0000110 def test_update_volume_with_nonexistent_volume_id(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900111 v_name = data_utils.rand_name('Volume-')
wanghaoc2abb6c2013-09-29 19:14:09 +0800112 metadata = {'Type': 'work'}
113 self.assertRaises(exceptions.NotFound, self.client.update_volume,
114 volume_id=str(uuid.uuid4()), display_name=v_name,
115 metadata=metadata)
116
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900117 @test.attr(type=['negative', 'gate'])
wanghaoc2abb6c2013-09-29 19:14:09 +0800118 def test_update_volume_with_invalid_volume_id(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900119 v_name = data_utils.rand_name('Volume-')
wanghaoc2abb6c2013-09-29 19:14:09 +0800120 metadata = {'Type': 'work'}
121 self.assertRaises(exceptions.NotFound, self.client.update_volume,
122 volume_id='#$%%&^&^', display_name=v_name,
123 metadata=metadata)
124
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900125 @test.attr(type=['negative', 'gate'])
wanghaoc2abb6c2013-09-29 19:14:09 +0800126 def test_update_volume_with_empty_volume_id(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900127 v_name = data_utils.rand_name('Volume-')
wanghaoc2abb6c2013-09-29 19:14:09 +0800128 metadata = {'Type': 'work'}
129 self.assertRaises(exceptions.NotFound, self.client.update_volume,
130 volume_id='', display_name=v_name,
131 metadata=metadata)
132
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900133 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700134 def test_get_invalid_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500135 # Should not be able to get volume with invalid id
Chris Yeoh8b4eaa52013-02-06 18:03:10 +1030136 self.assertRaises(exceptions.NotFound, self.client.get_volume,
137 '#$%%&^&^')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700138
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900139 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700140 def test_get_volume_without_passing_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500141 # Should not be able to get volume when empty ID is passed
Chris Yeoh8b4eaa52013-02-06 18:03:10 +1030142 self.assertRaises(exceptions.NotFound, self.client.get_volume, '')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700143
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900144 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700145 def test_delete_invalid_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500146 # Should not be able to delete volume when invalid ID is passed
Chris Yeoh8b4eaa52013-02-06 18:03:10 +1030147 self.assertRaises(exceptions.NotFound, self.client.delete_volume,
148 '!@#$%^&*()')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700149
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900150 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700151 def test_delete_volume_without_passing_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500152 # Should not be able to delete volume when empty ID is passed
Chris Yeoh8b4eaa52013-02-06 18:03:10 +1030153 self.assertRaises(exceptions.NotFound, self.client.delete_volume, '')
Matthew Treinish9854d5b2012-09-20 10:22:13 -0400154
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900155 @test.attr(type=['negative', 'gate'])
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800156 def test_attach_volumes_with_nonexistent_volume_id(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900157 srv_name = data_utils.rand_name('Instance-')
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800158 resp, server = self.servers_client.create_server(srv_name,
159 self.image_ref,
160 self.flavor_ref)
161 self.addCleanup(self.servers_client.delete_server, server['id'])
162 self.servers_client.wait_for_server_status(server['id'], 'ACTIVE')
163 self.assertRaises(exceptions.NotFound,
164 self.client.attach_volume,
165 str(uuid.uuid4()),
166 server['id'],
167 self.mountpoint)
168
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900169 @test.attr(type=['negative', 'gate'])
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800170 def test_detach_volumes_with_invalid_volume_id(self):
171 self.assertRaises(exceptions.NotFound,
172 self.client.detach_volume,
173 'xxx')
174
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900175 @test.attr(type=['negative', 'gate'])
wanghao5b981752013-10-22 11:41:41 +0800176 def test_volume_extend_with_size_smaller_than_original_size(self):
177 # Extend volume with smaller size than original size.
178 extend_size = 0
179 self.assertRaises(exceptions.BadRequest, self.client.extend_volume,
180 self.volume['id'], extend_size)
181
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900182 @test.attr(type=['negative', 'gate'])
wanghao5b981752013-10-22 11:41:41 +0800183 def test_volume_extend_with_non_number_size(self):
184 # Extend volume when size is non number.
185 extend_size = 'abc'
186 self.assertRaises(exceptions.BadRequest, self.client.extend_volume,
187 self.volume['id'], extend_size)
188
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900189 @test.attr(type=['negative', 'gate'])
wanghao5b981752013-10-22 11:41:41 +0800190 def test_volume_extend_with_None_size(self):
191 # Extend volume with None size.
192 extend_size = None
193 self.assertRaises(exceptions.BadRequest, self.client.extend_volume,
194 self.volume['id'], extend_size)
195
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900196 @test.attr(type=['negative', 'gate'])
wanghao5b981752013-10-22 11:41:41 +0800197 def test_volume_extend_with_nonexistent_volume_id(self):
198 # Extend volume size when volume is nonexistent.
199 extend_size = int(self.volume['size']) + 1
200 self.assertRaises(exceptions.NotFound, self.client.extend_volume,
201 str(uuid.uuid4()), extend_size)
202
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900203 @test.attr(type=['negative', 'gate'])
wanghao5b981752013-10-22 11:41:41 +0800204 def test_volume_extend_without_passing_volume_id(self):
205 # Extend volume size when passing volume id is None.
206 extend_size = int(self.volume['size']) + 1
207 self.assertRaises(exceptions.NotFound, self.client.extend_volume,
208 None, extend_size)
209
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900210 @test.attr(type=['negative', 'gate'])
zhangyanzi6b632432013-10-24 19:08:50 +0800211 def test_reserve_volume_with_nonexistent_volume_id(self):
212 self.assertRaises(exceptions.NotFound,
213 self.client.reserve_volume,
214 str(uuid.uuid4()))
215
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900216 @test.attr(type=['negative', 'gate'])
zhangyanzi6b632432013-10-24 19:08:50 +0800217 def test_unreserve_volume_with_nonexistent_volume_id(self):
218 self.assertRaises(exceptions.NotFound,
219 self.client.unreserve_volume,
220 str(uuid.uuid4()))
221
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900222 @test.attr(type=['negative', 'gate'])
zhangyanzi6b632432013-10-24 19:08:50 +0800223 def test_reserve_volume_with_negative_volume_status(self):
224 # Mark volume as reserved.
225 resp, body = self.client.reserve_volume(self.volume['id'])
226 self.assertEqual(202, resp.status)
227 # Mark volume which is marked as reserved before
228 self.assertRaises(exceptions.BadRequest,
229 self.client.reserve_volume,
230 self.volume['id'])
231 # Unmark volume as reserved.
232 resp, body = self.client.unreserve_volume(self.volume['id'])
233 self.assertEqual(202, resp.status)
234
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900235 @test.attr(type=['negative', 'gate'])
Zhi Kun Liu42403182013-10-11 18:05:08 +0800236 def test_list_volumes_with_nonexistent_name(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900237 v_name = data_utils.rand_name('Volume-')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800238 params = {'display_name': v_name}
239 resp, fetched_volume = self.client.list_volumes(params)
240 self.assertEqual(200, resp.status)
241 self.assertEqual(0, len(fetched_volume))
242
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900243 @test.attr(type=['negative', 'gate'])
Zhi Kun Liu42403182013-10-11 18:05:08 +0800244 def test_list_volumes_detail_with_nonexistent_name(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900245 v_name = data_utils.rand_name('Volume-')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800246 params = {'display_name': v_name}
247 resp, fetched_volume = self.client.list_volumes_with_detail(params)
248 self.assertEqual(200, resp.status)
249 self.assertEqual(0, len(fetched_volume))
250
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900251 @test.attr(type=['negative', 'gate'])
Zhi Kun Liu42403182013-10-11 18:05:08 +0800252 def test_list_volumes_with_invalid_status(self):
253 params = {'status': 'null'}
254 resp, fetched_volume = self.client.list_volumes(params)
255 self.assertEqual(200, resp.status)
256 self.assertEqual(0, len(fetched_volume))
257
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900258 @test.attr(type=['negative', 'gate'])
Zhi Kun Liu42403182013-10-11 18:05:08 +0800259 def test_list_volumes_detail_with_invalid_status(self):
260 params = {'status': 'null'}
261 resp, fetched_volume = self.client.list_volumes_with_detail(params)
262 self.assertEqual(200, resp.status)
263 self.assertEqual(0, len(fetched_volume))
264
Matthew Treinish9854d5b2012-09-20 10:22:13 -0400265
Attila Fazekas3dcdae12013-02-14 12:50:04 +0100266class VolumesNegativeTestXML(VolumesNegativeTest):
267 _interface = 'xml'