blob: be5d76bbbee346e5867f998b9546f2645a302cfd [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
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090016from testtools import matchers
Giulio Fidente5ed48ce2014-01-09 18:28:28 +010017
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 Treinish4d352bc2014-01-29 18:29:18 +000020from tempest import config
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090021from tempest import test
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070022
Matthew Treinish4d352bc2014-01-29 18:29:18 +000023CONF = config.CONF
24
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070025
Zhi Kun Liubb363a22013-11-28 18:47:39 +080026class VolumesGetTest(base.BaseVolumeV1Test):
Attila Fazekas3dcdae12013-02-14 12:50:04 +010027 _interface = "json"
28
29 @classmethod
30 def setUpClass(cls):
31 super(VolumesGetTest, cls).setUpClass()
32 cls.client = cls.volumes_client
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070033
Matt Riedemannbc8dbd32013-08-02 14:02:12 -070034 def _delete_volume(self, volume_id):
35 resp, _ = self.client.delete_volume(volume_id)
36 self.assertEqual(202, resp.status)
37 self.client.wait_for_resource_deletion(volume_id)
38
John Griffithd1fefd52013-09-23 20:40:37 +000039 def _is_true(self, val):
40 # NOTE(jdg): Temporary conversion method to get cinder patch
41 # merged. Then we'll make this strict again and
42 #specifically check "true" or "false"
43 if val in ['true', 'True', True]:
44 return True
45 else:
46 return False
47
QingXin Meng611768a2013-09-18 00:51:33 -070048 def _volume_create_get_update_delete(self, **kwargs):
Sean Dague72a00382013-01-03 17:53:38 -050049 # Create a volume, Get it's details and Delete the volume
Matt Riedemannbc8dbd32013-08-02 14:02:12 -070050 volume = {}
Masayuki Igawa259c1132013-10-31 17:48:44 +090051 v_name = data_utils.rand_name('Volume')
Matt Riedemannbc8dbd32013-08-02 14:02:12 -070052 metadata = {'Type': 'Test'}
53 # Create a volume
54 resp, volume = self.client.create_volume(size=1,
55 display_name=v_name,
56 metadata=metadata,
57 **kwargs)
58 self.assertEqual(200, resp.status)
59 self.assertIn('id', volume)
60 self.addCleanup(self._delete_volume, volume['id'])
61 self.assertIn('display_name', volume)
62 self.assertEqual(volume['display_name'], v_name,
63 "The created volume name is not equal "
64 "to the requested name")
65 self.assertTrue(volume['id'] is not None,
66 "Field volume id is empty or not found.")
67 self.client.wait_for_volume_status(volume['id'], 'available')
68 # Get Volume information
69 resp, fetched_volume = self.client.get_volume(volume['id'])
70 self.assertEqual(200, resp.status)
71 self.assertEqual(v_name,
72 fetched_volume['display_name'],
Giulio Fidente5ed48ce2014-01-09 18:28:28 +010073 'The fetched Volume name is different '
Matt Riedemannbc8dbd32013-08-02 14:02:12 -070074 'from the created Volume')
75 self.assertEqual(volume['id'],
76 fetched_volume['id'],
Giulio Fidente5ed48ce2014-01-09 18:28:28 +010077 'The fetched Volume id is different '
Matt Riedemannbc8dbd32013-08-02 14:02:12 -070078 'from the created Volume')
Giulio Fidente5ed48ce2014-01-09 18:28:28 +010079 self.assertThat(fetched_volume['metadata'].items(),
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090080 matchers.ContainsAll(metadata.items()),
Giulio Fidente5ed48ce2014-01-09 18:28:28 +010081 'The fetched Volume metadata misses data '
82 'from the created Volume')
John Griffithd1fefd52013-09-23 20:40:37 +000083
84 # NOTE(jdg): Revert back to strict true/false checking
85 # after fix for bug #1227837 merges
86 boot_flag = self._is_true(fetched_volume['bootable'])
Nayna Patel5e76be12013-08-19 12:10:16 +000087 if 'imageRef' in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +000088 self.assertEqual(boot_flag, True)
Nayna Patel5e76be12013-08-19 12:10:16 +000089 if 'imageRef' not in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +000090 self.assertEqual(boot_flag, False)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070091
QingXin Meng611768a2013-09-18 00:51:33 -070092 # Update Volume
Xiao Chen1ea93672014-01-09 10:10:47 +080093 # Test volume update when display_name is same with original value
94 resp, update_volume = \
95 self.client.update_volume(volume['id'],
96 display_name=v_name)
97 self.assertEqual(200, resp.status)
98 # Test volume update when display_name is new
Masayuki Igawa259c1132013-10-31 17:48:44 +090099 new_v_name = data_utils.rand_name('new-Volume')
QingXin Meng611768a2013-09-18 00:51:33 -0700100 new_desc = 'This is the new description of volume'
101 resp, update_volume = \
102 self.client.update_volume(volume['id'],
103 display_name=new_v_name,
104 display_description=new_desc)
105 # Assert response body for update_volume method
106 self.assertEqual(200, resp.status)
107 self.assertEqual(new_v_name, update_volume['display_name'])
108 self.assertEqual(new_desc, update_volume['display_description'])
109 # Assert response body for get_volume method
110 resp, updated_volume = self.client.get_volume(volume['id'])
111 self.assertEqual(200, resp.status)
112 self.assertEqual(volume['id'], updated_volume['id'])
113 self.assertEqual(new_v_name, updated_volume['display_name'])
114 self.assertEqual(new_desc, updated_volume['display_description'])
Giulio Fidente5ed48ce2014-01-09 18:28:28 +0100115 self.assertThat(updated_volume['metadata'].items(),
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900116 matchers.ContainsAll(metadata.items()),
Giulio Fidente5ed48ce2014-01-09 18:28:28 +0100117 'The fetched Volume metadata misses data '
118 'from the created Volume')
Xiao Chen1ea93672014-01-09 10:10:47 +0800119 # Test volume create when display_name is none and display_description
120 # contains specific characters,
121 # then test volume update if display_name is duplicated
122 new_volume = {}
123 new_v_desc = data_utils.rand_name('@#$%^* description')
124 resp, new_volume = \
125 self.client.create_volume(size=1,
126 display_description=new_v_desc,
Zhi Kun Liu228e73d2014-03-10 15:06:10 +0800127 availability_zone=
128 volume['availability_zone'])
Xiao Chen1ea93672014-01-09 10:10:47 +0800129 self.assertEqual(200, resp.status)
130 self.assertIn('id', new_volume)
131 self.addCleanup(self._delete_volume, new_volume['id'])
132 self.client.wait_for_volume_status(new_volume['id'], 'available')
133 resp, update_volume = \
134 self.client.update_volume(new_volume['id'],
135 display_name=volume['display_name'],
Zhi Kun Liu228e73d2014-03-10 15:06:10 +0800136 display_description=
137 volume['display_description'])
Xiao Chen1ea93672014-01-09 10:10:47 +0800138 self.assertEqual(200, resp.status)
John Griffithd1fefd52013-09-23 20:40:37 +0000139
140 # NOTE(jdg): Revert back to strict true/false checking
141 # after fix for bug #1227837 merges
142 boot_flag = self._is_true(updated_volume['bootable'])
QingXin Meng611768a2013-09-18 00:51:33 -0700143 if 'imageRef' in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +0000144 self.assertEqual(boot_flag, True)
QingXin Meng611768a2013-09-18 00:51:33 -0700145 if 'imageRef' not in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +0000146 self.assertEqual(boot_flag, False)
QingXin Meng611768a2013-09-18 00:51:33 -0700147
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900148 @test.attr(type='smoke')
QingXin Meng611768a2013-09-18 00:51:33 -0700149 def test_volume_create_get_update_delete(self):
150 self._volume_create_get_update_delete()
Giulio Fidente36836c42013-04-05 15:43:51 +0200151
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900152 @test.attr(type='smoke')
153 @test.services('image')
QingXin Meng611768a2013-09-18 00:51:33 -0700154 def test_volume_create_get_update_delete_from_image(self):
Matthew Treinish4d352bc2014-01-29 18:29:18 +0000155 self._volume_create_get_update_delete(imageRef=CONF.compute.image_ref)
Giulio Fidente02f42982013-06-17 16:25:56 +0200156
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900157 @test.attr(type='gate')
QingXin Meng611768a2013-09-18 00:51:33 -0700158 def test_volume_create_get_update_delete_as_clone(self):
Ken'ichi Ohmichi5687d552013-12-26 19:00:12 +0900159 origin = self.create_volume()
QingXin Meng611768a2013-09-18 00:51:33 -0700160 self._volume_create_get_update_delete(source_volid=origin['id'])
Giulio Fidente36836c42013-04-05 15:43:51 +0200161
Matthew Treinish9854d5b2012-09-20 10:22:13 -0400162
Attila Fazekas3dcdae12013-02-14 12:50:04 +0100163class VolumesGetTestXML(VolumesGetTest):
164 _interface = "xml"