blob: c7d4374190c1fbbb86b0b450f7f426c2a44265ea [file] [log] [blame]
Rohit Karajgidd47d7e2012-07-31 04:11:01 -07001# vim: tabstop=4 shiftwidth=4 softtabstop=4
2
3# Copyright 2012 OpenStack, LLC
4# All Rights Reserved.
5#
6# Licensed under the Apache License, Version 2.0 (the "License"); you may
7# not use this file except in compliance with the License. You may obtain
8# a copy of the License at
9#
10# http://www.apache.org/licenses/LICENSE-2.0
11#
12# Unless required by applicable law or agreed to in writing, software
13# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
14# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
15# License for the specific language governing permissions and limitations
16# under the License.
17
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070018from tempest.common.utils.data_utils import rand_name
Matthew Treinisha83a16e2012-12-07 13:44:02 -050019from tempest import exceptions
Matthew Treinish9854d5b2012-09-20 10:22:13 -040020from tempest.tests.volume import base
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070021
22
Attila Fazekas3dcdae12013-02-14 12:50:04 +010023class VolumesNegativeTest(base.BaseVolumeTest):
24 _interface = 'json'
25
26 @classmethod
27 def setUpClass(cls):
28 super(VolumesNegativeTest, cls).setUpClass()
29 cls.client = cls.volumes_client
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070030
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070031 def test_volume_get_nonexistant_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -050032 # Should not be able to get a nonexistant volume
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070033 #Creating a nonexistant volume id
34 volume_id_list = []
35 resp, volumes = self.client.list_volumes()
36 for i in range(len(volumes)):
37 volume_id_list.append(volumes[i]['id'])
38 while True:
39 non_exist_id = rand_name('999')
40 if non_exist_id not in volume_id_list:
41 break
42 #Trying to Get a non existant volume
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103043 self.assertRaises(exceptions.NotFound, self.client.get_volume,
44 non_exist_id)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070045
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070046 def test_volume_delete_nonexistant_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -050047 # Should not be able to delete a nonexistant Volume
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070048 # Creating nonexistant volume id
49 volume_id_list = []
50 resp, volumes = self.client.list_volumes()
51 for i in range(len(volumes)):
52 volume_id_list.append(volumes[i]['id'])
53 while True:
54 non_exist_id = '12345678-abcd-4321-abcd-123456789098'
55 if non_exist_id not in volume_id_list:
56 break
57 # Try to Delete a non existant volume
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103058 self.assertRaises(exceptions.NotFound, self.client.delete_volume,
59 non_exist_id)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070060
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070061 def test_create_volume_with_invalid_size(self):
Sean Dague72a00382013-01-03 17:53:38 -050062 # Should not be able to create volume with invalid size
63 # in request
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070064 v_name = rand_name('Volume-')
65 metadata = {'Type': 'work'}
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103066 self.assertRaises(exceptions.BadRequest, self.client.create_volume,
67 size='#$%', display_name=v_name, metadata=metadata)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070068
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070069 def test_create_volume_with_out_passing_size(self):
Sean Dague72a00382013-01-03 17:53:38 -050070 # Should not be able to create volume without passing size
71 # in request
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070072 v_name = rand_name('Volume-')
73 metadata = {'Type': 'work'}
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103074 self.assertRaises(exceptions.BadRequest, self.client.create_volume,
75 size='', display_name=v_name, metadata=metadata)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070076
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070077 def test_create_volume_with_size_zero(self):
Sean Dague72a00382013-01-03 17:53:38 -050078 # Should not be able to create volume with size zero
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070079 v_name = rand_name('Volume-')
80 metadata = {'Type': 'work'}
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103081 self.assertRaises(exceptions.BadRequest, self.client.create_volume,
82 size='0', display_name=v_name, metadata=metadata)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070083
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070084 def test_get_invalid_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -050085 # Should not be able to get volume with invalid id
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103086 self.assertRaises(exceptions.NotFound, self.client.get_volume,
87 '#$%%&^&^')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070088
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070089 def test_get_volume_without_passing_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -050090 # Should not be able to get volume when empty ID is passed
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103091 self.assertRaises(exceptions.NotFound, self.client.get_volume, '')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070092
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070093 def test_delete_invalid_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -050094 # Should not be able to delete volume when invalid ID is passed
Chris Yeoh8b4eaa52013-02-06 18:03:10 +103095 self.assertRaises(exceptions.NotFound, self.client.delete_volume,
96 '!@#$%^&*()')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070097
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070098 def test_delete_volume_without_passing_volume_id(self):
Sean Dague72a00382013-01-03 17:53:38 -050099 # Should not be able to delete volume when empty ID is passed
Chris Yeoh8b4eaa52013-02-06 18:03:10 +1030100 self.assertRaises(exceptions.NotFound, self.client.delete_volume, '')
Matthew Treinish9854d5b2012-09-20 10:22:13 -0400101
102
Attila Fazekas3dcdae12013-02-14 12:50:04 +0100103class VolumesNegativeTestXML(VolumesNegativeTest):
104 _interface = 'xml'