blob: bc5b1dc91c870fc5ec7cd8d76149ea5e50e07b67 [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
Zhi Kun Liu43f9af12014-03-19 21:01:35 +080028 @test.safe_setup
Attila Fazekas3dcdae12013-02-14 12:50:04 +010029 def setUpClass(cls):
30 super(VolumesNegativeTest, cls).setUpClass()
31 cls.client = cls.volumes_client
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070032
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080033 # Create a test shared instance and volume for attach/detach tests
Ken'ichi Ohmichi5687d552013-12-26 19:00:12 +090034 cls.volume = cls.create_volume()
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080035 cls.mountpoint = "/dev/vdc"
36
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090037 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +000038 def test_volume_get_nonexistent_volume_id(self):
39 # Should not be able to get a non-existent volume
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103040 self.assertRaises(exceptions.NotFound, self.client.get_volume,
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080041 str(uuid.uuid4()))
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070042
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090043 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +000044 def test_volume_delete_nonexistent_volume_id(self):
45 # Should not be able to delete a non-existent Volume
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103046 self.assertRaises(exceptions.NotFound, self.client.delete_volume,
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +080047 str(uuid.uuid4()))
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070048
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090049 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070050 def test_create_volume_with_invalid_size(self):
Sean Dague72a00382013-01-03 17:53:38 -050051 # Should not be able to create volume with invalid size
52 # in request
Masayuki Igawa259c1132013-10-31 17:48:44 +090053 v_name = data_utils.rand_name('Volume-')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070054 metadata = {'Type': 'work'}
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103055 self.assertRaises(exceptions.BadRequest, self.client.create_volume,
56 size='#$%', display_name=v_name, metadata=metadata)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070057
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090058 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070059 def test_create_volume_with_out_passing_size(self):
Sean Dague72a00382013-01-03 17:53:38 -050060 # Should not be able to create volume without passing size
61 # in request
Masayuki Igawa259c1132013-10-31 17:48:44 +090062 v_name = data_utils.rand_name('Volume-')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070063 metadata = {'Type': 'work'}
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103064 self.assertRaises(exceptions.BadRequest, self.client.create_volume,
65 size='', display_name=v_name, metadata=metadata)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070066
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090067 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070068 def test_create_volume_with_size_zero(self):
Sean Dague72a00382013-01-03 17:53:38 -050069 # Should not be able to create volume with size zero
Masayuki Igawa259c1132013-10-31 17:48:44 +090070 v_name = data_utils.rand_name('Volume-')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070071 metadata = {'Type': 'work'}
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103072 self.assertRaises(exceptions.BadRequest, self.client.create_volume,
73 size='0', display_name=v_name, metadata=metadata)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070074
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090075 @test.attr(type=['negative', 'gate'])
wanghaoc2abb6c2013-09-29 19:14:09 +080076 def test_create_volume_with_size_negative(self):
77 # Should not be able to create volume with size negative
Masayuki Igawa259c1132013-10-31 17:48:44 +090078 v_name = data_utils.rand_name('Volume-')
wanghaoc2abb6c2013-09-29 19:14:09 +080079 metadata = {'Type': 'work'}
80 self.assertRaises(exceptions.BadRequest, self.client.create_volume,
81 size='-1', display_name=v_name, metadata=metadata)
82
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090083 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +000084 def test_create_volume_with_nonexistent_volume_type(self):
85 # Should not be able to create volume with non-existent volume type
Masayuki Igawa259c1132013-10-31 17:48:44 +090086 v_name = data_utils.rand_name('Volume-')
zhangyanzib866f052013-10-12 11:41:32 +080087 metadata = {'Type': 'work'}
88 self.assertRaises(exceptions.NotFound, self.client.create_volume,
89 size='1', volume_type=str(uuid.uuid4()),
90 display_name=v_name, metadata=metadata)
91
Masayuki Igawa1edf94f2014-03-04 18:34:16 +090092 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +000093 def test_create_volume_with_nonexistent_snapshot_id(self):
94 # Should not be able to create volume with non-existent snapshot
Masayuki Igawa259c1132013-10-31 17:48:44 +090095 v_name = data_utils.rand_name('Volume-')
zhangyanzib866f052013-10-12 11:41:32 +080096 metadata = {'Type': 'work'}
97 self.assertRaises(exceptions.NotFound, self.client.create_volume,
98 size='1', snapshot_id=str(uuid.uuid4()),
99 display_name=v_name, metadata=metadata)
100
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900101 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +0000102 def test_create_volume_with_nonexistent_source_volid(self):
103 # Should not be able to create volume with non-existent source volume
Masayuki Igawa259c1132013-10-31 17:48:44 +0900104 v_name = data_utils.rand_name('Volume-')
zhangyanzib866f052013-10-12 11:41:32 +0800105 metadata = {'Type': 'work'}
106 self.assertRaises(exceptions.NotFound, self.client.create_volume,
107 size='1', source_volid=str(uuid.uuid4()),
108 display_name=v_name, metadata=metadata)
109
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900110 @test.attr(type=['negative', 'gate'])
nayna-patel179077c2014-01-15 12:27:16 +0000111 def test_update_volume_with_nonexistent_volume_id(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900112 v_name = data_utils.rand_name('Volume-')
wanghaoc2abb6c2013-09-29 19:14:09 +0800113 metadata = {'Type': 'work'}
114 self.assertRaises(exceptions.NotFound, self.client.update_volume,
115 volume_id=str(uuid.uuid4()), display_name=v_name,
116 metadata=metadata)
117
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900118 @test.attr(type=['negative', 'gate'])
wanghaoc2abb6c2013-09-29 19:14:09 +0800119 def test_update_volume_with_invalid_volume_id(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900120 v_name = data_utils.rand_name('Volume-')
wanghaoc2abb6c2013-09-29 19:14:09 +0800121 metadata = {'Type': 'work'}
122 self.assertRaises(exceptions.NotFound, self.client.update_volume,
123 volume_id='#$%%&^&^', display_name=v_name,
124 metadata=metadata)
125
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900126 @test.attr(type=['negative', 'gate'])
wanghaoc2abb6c2013-09-29 19:14:09 +0800127 def test_update_volume_with_empty_volume_id(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900128 v_name = data_utils.rand_name('Volume-')
wanghaoc2abb6c2013-09-29 19:14:09 +0800129 metadata = {'Type': 'work'}
130 self.assertRaises(exceptions.NotFound, self.client.update_volume,
131 volume_id='', display_name=v_name,
132 metadata=metadata)
133
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900134 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700135 def test_get_invalid_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500136 # Should not be able to get volume with invalid id
Chris Yeoh8b4eaa52013-02-06 18:03:10 +1030137 self.assertRaises(exceptions.NotFound, self.client.get_volume,
138 '#$%%&^&^')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700139
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900140 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700141 def test_get_volume_without_passing_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500142 # Should not be able to get volume when empty ID is passed
Chris Yeoh8b4eaa52013-02-06 18:03:10 +1030143 self.assertRaises(exceptions.NotFound, self.client.get_volume, '')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700144
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900145 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700146 def test_delete_invalid_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500147 # Should not be able to delete volume when invalid ID is passed
Chris Yeoh8b4eaa52013-02-06 18:03:10 +1030148 self.assertRaises(exceptions.NotFound, self.client.delete_volume,
149 '!@#$%^&*()')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700150
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900151 @test.attr(type=['negative', 'gate'])
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700152 def test_delete_volume_without_passing_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -0500153 # Should not be able to delete volume when empty ID is passed
Chris Yeoh8b4eaa52013-02-06 18:03:10 +1030154 self.assertRaises(exceptions.NotFound, self.client.delete_volume, '')
Matthew Treinish9854d5b2012-09-20 10:22:13 -0400155
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900156 @test.attr(type=['negative', 'gate'])
Matthew Treinish7ea69e62014-06-03 17:23:50 -0400157 @test.services('compute')
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800158 def test_attach_volumes_with_nonexistent_volume_id(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900159 srv_name = data_utils.rand_name('Instance-')
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800160 resp, server = self.servers_client.create_server(srv_name,
161 self.image_ref,
162 self.flavor_ref)
163 self.addCleanup(self.servers_client.delete_server, server['id'])
164 self.servers_client.wait_for_server_status(server['id'], 'ACTIVE')
165 self.assertRaises(exceptions.NotFound,
166 self.client.attach_volume,
167 str(uuid.uuid4()),
168 server['id'],
169 self.mountpoint)
170
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900171 @test.attr(type=['negative', 'gate'])
Zhi Kun Liu3bdfe092013-09-02 01:31:58 +0800172 def test_detach_volumes_with_invalid_volume_id(self):
173 self.assertRaises(exceptions.NotFound,
174 self.client.detach_volume,
175 'xxx')
176
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900177 @test.attr(type=['negative', 'gate'])
wanghao5b981752013-10-22 11:41:41 +0800178 def test_volume_extend_with_size_smaller_than_original_size(self):
179 # Extend volume with smaller size than original size.
180 extend_size = 0
181 self.assertRaises(exceptions.BadRequest, self.client.extend_volume,
182 self.volume['id'], extend_size)
183
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900184 @test.attr(type=['negative', 'gate'])
wanghao5b981752013-10-22 11:41:41 +0800185 def test_volume_extend_with_non_number_size(self):
186 # Extend volume when size is non number.
187 extend_size = 'abc'
188 self.assertRaises(exceptions.BadRequest, self.client.extend_volume,
189 self.volume['id'], extend_size)
190
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900191 @test.attr(type=['negative', 'gate'])
wanghao5b981752013-10-22 11:41:41 +0800192 def test_volume_extend_with_None_size(self):
193 # Extend volume with None size.
194 extend_size = None
195 self.assertRaises(exceptions.BadRequest, self.client.extend_volume,
196 self.volume['id'], extend_size)
197
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900198 @test.attr(type=['negative', 'gate'])
wanghao5b981752013-10-22 11:41:41 +0800199 def test_volume_extend_with_nonexistent_volume_id(self):
200 # Extend volume size when volume is nonexistent.
201 extend_size = int(self.volume['size']) + 1
202 self.assertRaises(exceptions.NotFound, self.client.extend_volume,
203 str(uuid.uuid4()), extend_size)
204
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900205 @test.attr(type=['negative', 'gate'])
wanghao5b981752013-10-22 11:41:41 +0800206 def test_volume_extend_without_passing_volume_id(self):
207 # Extend volume size when passing volume id is None.
208 extend_size = int(self.volume['size']) + 1
209 self.assertRaises(exceptions.NotFound, self.client.extend_volume,
210 None, extend_size)
211
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900212 @test.attr(type=['negative', 'gate'])
zhangyanzi6b632432013-10-24 19:08:50 +0800213 def test_reserve_volume_with_nonexistent_volume_id(self):
214 self.assertRaises(exceptions.NotFound,
215 self.client.reserve_volume,
216 str(uuid.uuid4()))
217
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900218 @test.attr(type=['negative', 'gate'])
zhangyanzi6b632432013-10-24 19:08:50 +0800219 def test_unreserve_volume_with_nonexistent_volume_id(self):
220 self.assertRaises(exceptions.NotFound,
221 self.client.unreserve_volume,
222 str(uuid.uuid4()))
223
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900224 @test.attr(type=['negative', 'gate'])
zhangyanzi6b632432013-10-24 19:08:50 +0800225 def test_reserve_volume_with_negative_volume_status(self):
226 # Mark volume as reserved.
227 resp, body = self.client.reserve_volume(self.volume['id'])
228 self.assertEqual(202, resp.status)
229 # Mark volume which is marked as reserved before
230 self.assertRaises(exceptions.BadRequest,
231 self.client.reserve_volume,
232 self.volume['id'])
233 # Unmark volume as reserved.
234 resp, body = self.client.unreserve_volume(self.volume['id'])
235 self.assertEqual(202, resp.status)
236
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900237 @test.attr(type=['negative', 'gate'])
Zhi Kun Liu42403182013-10-11 18:05:08 +0800238 def test_list_volumes_with_nonexistent_name(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900239 v_name = data_utils.rand_name('Volume-')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800240 params = {'display_name': v_name}
241 resp, fetched_volume = self.client.list_volumes(params)
242 self.assertEqual(200, resp.status)
243 self.assertEqual(0, len(fetched_volume))
244
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900245 @test.attr(type=['negative', 'gate'])
Zhi Kun Liu42403182013-10-11 18:05:08 +0800246 def test_list_volumes_detail_with_nonexistent_name(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +0900247 v_name = data_utils.rand_name('Volume-')
Zhi Kun Liu42403182013-10-11 18:05:08 +0800248 params = {'display_name': v_name}
249 resp, fetched_volume = self.client.list_volumes_with_detail(params)
250 self.assertEqual(200, resp.status)
251 self.assertEqual(0, len(fetched_volume))
252
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900253 @test.attr(type=['negative', 'gate'])
Zhi Kun Liu42403182013-10-11 18:05:08 +0800254 def test_list_volumes_with_invalid_status(self):
255 params = {'status': 'null'}
256 resp, fetched_volume = self.client.list_volumes(params)
257 self.assertEqual(200, resp.status)
258 self.assertEqual(0, len(fetched_volume))
259
Masayuki Igawa1edf94f2014-03-04 18:34:16 +0900260 @test.attr(type=['negative', 'gate'])
Zhi Kun Liu42403182013-10-11 18:05:08 +0800261 def test_list_volumes_detail_with_invalid_status(self):
262 params = {'status': 'null'}
263 resp, fetched_volume = self.client.list_volumes_with_detail(params)
264 self.assertEqual(200, resp.status)
265 self.assertEqual(0, len(fetched_volume))
266
Matthew Treinish9854d5b2012-09-20 10:22:13 -0400267
Attila Fazekas3dcdae12013-02-14 12:50:04 +0100268class VolumesNegativeTestXML(VolumesNegativeTest):
269 _interface = 'xml'