blob: 58da440ea6d381ec50a71b7844cd94772042cf1b [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
Jerry Cai9733d0e2014-03-19 15:50:49 +080054 resp, volume = self.client.create_volume(display_name=v_name,
Matt Riedemannbc8dbd32013-08-02 14:02:12 -070055 metadata=metadata,
56 **kwargs)
57 self.assertEqual(200, resp.status)
58 self.assertIn('id', volume)
59 self.addCleanup(self._delete_volume, volume['id'])
60 self.assertIn('display_name', volume)
61 self.assertEqual(volume['display_name'], v_name,
62 "The created volume name is not equal "
63 "to the requested name")
64 self.assertTrue(volume['id'] is not None,
65 "Field volume id is empty or not found.")
66 self.client.wait_for_volume_status(volume['id'], 'available')
67 # Get Volume information
68 resp, fetched_volume = self.client.get_volume(volume['id'])
69 self.assertEqual(200, resp.status)
70 self.assertEqual(v_name,
71 fetched_volume['display_name'],
Giulio Fidente5ed48ce2014-01-09 18:28:28 +010072 'The fetched Volume name is different '
Matt Riedemannbc8dbd32013-08-02 14:02:12 -070073 'from the created Volume')
74 self.assertEqual(volume['id'],
75 fetched_volume['id'],
Giulio Fidente5ed48ce2014-01-09 18:28:28 +010076 'The fetched Volume id is different '
Matt Riedemannbc8dbd32013-08-02 14:02:12 -070077 'from the created Volume')
Giulio Fidente5ed48ce2014-01-09 18:28:28 +010078 self.assertThat(fetched_volume['metadata'].items(),
Masayuki Igawaba7bcf62014-02-17 14:56:41 +090079 matchers.ContainsAll(metadata.items()),
Giulio Fidente5ed48ce2014-01-09 18:28:28 +010080 'The fetched Volume metadata misses data '
81 'from the created Volume')
John Griffithd1fefd52013-09-23 20:40:37 +000082
83 # NOTE(jdg): Revert back to strict true/false checking
84 # after fix for bug #1227837 merges
85 boot_flag = self._is_true(fetched_volume['bootable'])
Nayna Patel5e76be12013-08-19 12:10:16 +000086 if 'imageRef' in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +000087 self.assertEqual(boot_flag, True)
Nayna Patel5e76be12013-08-19 12:10:16 +000088 if 'imageRef' not in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +000089 self.assertEqual(boot_flag, False)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070090
QingXin Meng611768a2013-09-18 00:51:33 -070091 # Update Volume
Xiao Chen1ea93672014-01-09 10:10:47 +080092 # Test volume update when display_name is same with original value
93 resp, update_volume = \
94 self.client.update_volume(volume['id'],
95 display_name=v_name)
96 self.assertEqual(200, resp.status)
97 # Test volume update when display_name is new
Masayuki Igawa259c1132013-10-31 17:48:44 +090098 new_v_name = data_utils.rand_name('new-Volume')
QingXin Meng611768a2013-09-18 00:51:33 -070099 new_desc = 'This is the new description of volume'
100 resp, update_volume = \
101 self.client.update_volume(volume['id'],
102 display_name=new_v_name,
103 display_description=new_desc)
104 # Assert response body for update_volume method
105 self.assertEqual(200, resp.status)
106 self.assertEqual(new_v_name, update_volume['display_name'])
107 self.assertEqual(new_desc, update_volume['display_description'])
108 # Assert response body for get_volume method
109 resp, updated_volume = self.client.get_volume(volume['id'])
110 self.assertEqual(200, resp.status)
111 self.assertEqual(volume['id'], updated_volume['id'])
112 self.assertEqual(new_v_name, updated_volume['display_name'])
113 self.assertEqual(new_desc, updated_volume['display_description'])
Giulio Fidente5ed48ce2014-01-09 18:28:28 +0100114 self.assertThat(updated_volume['metadata'].items(),
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900115 matchers.ContainsAll(metadata.items()),
Giulio Fidente5ed48ce2014-01-09 18:28:28 +0100116 'The fetched Volume metadata misses data '
117 'from the created Volume')
Xiao Chen1ea93672014-01-09 10:10:47 +0800118 # Test volume create when display_name is none and display_description
119 # contains specific characters,
120 # then test volume update if display_name is duplicated
121 new_volume = {}
122 new_v_desc = data_utils.rand_name('@#$%^* description')
123 resp, new_volume = \
124 self.client.create_volume(size=1,
125 display_description=new_v_desc,
Zhi Kun Liu228e73d2014-03-10 15:06:10 +0800126 availability_zone=
127 volume['availability_zone'])
Xiao Chen1ea93672014-01-09 10:10:47 +0800128 self.assertEqual(200, resp.status)
129 self.assertIn('id', new_volume)
130 self.addCleanup(self._delete_volume, new_volume['id'])
131 self.client.wait_for_volume_status(new_volume['id'], 'available')
132 resp, update_volume = \
133 self.client.update_volume(new_volume['id'],
134 display_name=volume['display_name'],
Zhi Kun Liu228e73d2014-03-10 15:06:10 +0800135 display_description=
136 volume['display_description'])
Xiao Chen1ea93672014-01-09 10:10:47 +0800137 self.assertEqual(200, resp.status)
John Griffithd1fefd52013-09-23 20:40:37 +0000138
139 # NOTE(jdg): Revert back to strict true/false checking
140 # after fix for bug #1227837 merges
141 boot_flag = self._is_true(updated_volume['bootable'])
QingXin Meng611768a2013-09-18 00:51:33 -0700142 if 'imageRef' in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +0000143 self.assertEqual(boot_flag, True)
QingXin Meng611768a2013-09-18 00:51:33 -0700144 if 'imageRef' not in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +0000145 self.assertEqual(boot_flag, False)
QingXin Meng611768a2013-09-18 00:51:33 -0700146
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900147 @test.attr(type='smoke')
QingXin Meng611768a2013-09-18 00:51:33 -0700148 def test_volume_create_get_update_delete(self):
149 self._volume_create_get_update_delete()
Giulio Fidente36836c42013-04-05 15:43:51 +0200150
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900151 @test.attr(type='smoke')
152 @test.services('image')
QingXin Meng611768a2013-09-18 00:51:33 -0700153 def test_volume_create_get_update_delete_from_image(self):
Matthew Treinish4d352bc2014-01-29 18:29:18 +0000154 self._volume_create_get_update_delete(imageRef=CONF.compute.image_ref)
Giulio Fidente02f42982013-06-17 16:25:56 +0200155
Masayuki Igawaba7bcf62014-02-17 14:56:41 +0900156 @test.attr(type='gate')
QingXin Meng611768a2013-09-18 00:51:33 -0700157 def test_volume_create_get_update_delete_as_clone(self):
Ken'ichi Ohmichi5687d552013-12-26 19:00:12 +0900158 origin = self.create_volume()
QingXin Meng611768a2013-09-18 00:51:33 -0700159 self._volume_create_get_update_delete(source_volid=origin['id'])
Giulio Fidente36836c42013-04-05 15:43:51 +0200160
Matthew Treinish9854d5b2012-09-20 10:22:13 -0400161
Attila Fazekas3dcdae12013-02-14 12:50:04 +0100162class VolumesGetTestXML(VolumesGetTest):
163 _interface = "xml"