blob: f2915f7ff2432ba8d254d24641106ae53c57fc56 [file] [log] [blame]
Rohit Karajgidd47d7e2012-07-31 04:11:01 -07001# vim: tabstop=4 shiftwidth=4 softtabstop=4
2
ZhiQiang Fan39f97222013-09-20 04:49:44 +08003# Copyright 2012 OpenStack Foundation
Rohit Karajgidd47d7e2012-07-31 04:11:01 -07004# 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
Sean Dague1937d092013-05-17 16:36:38 -040018from tempest.api.volume import base
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070019from tempest.common.utils.data_utils import rand_name
Chris Yeoh01cb2792013-02-09 22:25:37 +103020from tempest.test import attr
Matthew Treinish660a4c12013-09-09 20:06:12 +000021from tempest.test import services
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070022
23
Attila Fazekas3dcdae12013-02-14 12:50:04 +010024class VolumesGetTest(base.BaseVolumeTest):
Attila Fazekas3dcdae12013-02-14 12:50:04 +010025 _interface = "json"
26
27 @classmethod
28 def setUpClass(cls):
29 super(VolumesGetTest, cls).setUpClass()
30 cls.client = cls.volumes_client
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070031
Matt Riedemannbc8dbd32013-08-02 14:02:12 -070032 def _delete_volume(self, volume_id):
33 resp, _ = self.client.delete_volume(volume_id)
34 self.assertEqual(202, resp.status)
35 self.client.wait_for_resource_deletion(volume_id)
36
John Griffithd1fefd52013-09-23 20:40:37 +000037 def _is_true(self, val):
38 # NOTE(jdg): Temporary conversion method to get cinder patch
39 # merged. Then we'll make this strict again and
40 #specifically check "true" or "false"
41 if val in ['true', 'True', True]:
42 return True
43 else:
44 return False
45
QingXin Meng611768a2013-09-18 00:51:33 -070046 def _volume_create_get_update_delete(self, **kwargs):
Sean Dague72a00382013-01-03 17:53:38 -050047 # Create a volume, Get it's details and Delete the volume
Matt Riedemannbc8dbd32013-08-02 14:02:12 -070048 volume = {}
49 v_name = rand_name('Volume')
50 metadata = {'Type': 'Test'}
51 # Create a volume
52 resp, volume = self.client.create_volume(size=1,
53 display_name=v_name,
54 metadata=metadata,
55 **kwargs)
56 self.assertEqual(200, resp.status)
57 self.assertIn('id', volume)
58 self.addCleanup(self._delete_volume, volume['id'])
59 self.assertIn('display_name', volume)
60 self.assertEqual(volume['display_name'], v_name,
61 "The created volume name is not equal "
62 "to the requested name")
63 self.assertTrue(volume['id'] is not None,
64 "Field volume id is empty or not found.")
65 self.client.wait_for_volume_status(volume['id'], 'available')
66 # Get Volume information
67 resp, fetched_volume = self.client.get_volume(volume['id'])
68 self.assertEqual(200, resp.status)
69 self.assertEqual(v_name,
70 fetched_volume['display_name'],
71 'The fetched Volume is different '
72 'from the created Volume')
73 self.assertEqual(volume['id'],
74 fetched_volume['id'],
75 'The fetched Volume is different '
76 'from the created Volume')
77 self.assertEqual(metadata,
78 fetched_volume['metadata'],
79 'The fetched Volume is different '
80 'from the created Volume')
John Griffithd1fefd52013-09-23 20:40:37 +000081
82 # NOTE(jdg): Revert back to strict true/false checking
83 # after fix for bug #1227837 merges
84 boot_flag = self._is_true(fetched_volume['bootable'])
Nayna Patel5e76be12013-08-19 12:10:16 +000085 if 'imageRef' in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +000086 self.assertEqual(boot_flag, True)
Nayna Patel5e76be12013-08-19 12:10:16 +000087 if 'imageRef' not in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +000088 self.assertEqual(boot_flag, False)
Rohit Karajgidd47d7e2012-07-31 04:11:01 -070089
QingXin Meng611768a2013-09-18 00:51:33 -070090 # Update Volume
91 new_v_name = rand_name('new-Volume')
92 new_desc = 'This is the new description of volume'
93 resp, update_volume = \
94 self.client.update_volume(volume['id'],
95 display_name=new_v_name,
96 display_description=new_desc)
97 # Assert response body for update_volume method
98 self.assertEqual(200, resp.status)
99 self.assertEqual(new_v_name, update_volume['display_name'])
100 self.assertEqual(new_desc, update_volume['display_description'])
101 # Assert response body for get_volume method
102 resp, updated_volume = self.client.get_volume(volume['id'])
103 self.assertEqual(200, resp.status)
104 self.assertEqual(volume['id'], updated_volume['id'])
105 self.assertEqual(new_v_name, updated_volume['display_name'])
106 self.assertEqual(new_desc, updated_volume['display_description'])
107 self.assertEqual(metadata, updated_volume['metadata'])
John Griffithd1fefd52013-09-23 20:40:37 +0000108
109 # NOTE(jdg): Revert back to strict true/false checking
110 # after fix for bug #1227837 merges
111 boot_flag = self._is_true(updated_volume['bootable'])
QingXin Meng611768a2013-09-18 00:51:33 -0700112 if 'imageRef' in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +0000113 self.assertEqual(boot_flag, True)
QingXin Meng611768a2013-09-18 00:51:33 -0700114 if 'imageRef' not in kwargs:
John Griffithd1fefd52013-09-23 20:40:37 +0000115 self.assertEqual(boot_flag, False)
QingXin Meng611768a2013-09-18 00:51:33 -0700116
Giulio Fidente8b311902013-05-12 15:40:31 +0200117 @attr(type='gate')
Rohit Karajgidd47d7e2012-07-31 04:11:01 -0700118 def test_volume_get_metadata_none(self):
Sean Dague72a00382013-01-03 17:53:38 -0500119 # Create a volume without passing metadata, get details, and delete
Matt Riedemannbc8dbd32013-08-02 14:02:12 -0700120 volume = {}
121 v_name = rand_name('Volume-')
122 # Create a volume without metadata
123 resp, volume = self.client.create_volume(size=1,
124 display_name=v_name,
125 metadata={})
126 self.assertEqual(200, resp.status)
127 self.assertIn('id', volume)
128 self.addCleanup(self._delete_volume, volume['id'])
129 self.assertIn('display_name', volume)
130 self.client.wait_for_volume_status(volume['id'], 'available')
131 # GET Volume
132 resp, fetched_volume = self.client.get_volume(volume['id'])
133 self.assertEqual(200, resp.status)
134 self.assertEqual(fetched_volume['metadata'], {})
Matthew Treinish9854d5b2012-09-20 10:22:13 -0400135
Giulio Fidenteba3985a2013-05-29 01:46:36 +0200136 @attr(type='smoke')
QingXin Meng611768a2013-09-18 00:51:33 -0700137 def test_volume_create_get_update_delete(self):
138 self._volume_create_get_update_delete()
Giulio Fidente36836c42013-04-05 15:43:51 +0200139
Giulio Fidenteba3985a2013-05-29 01:46:36 +0200140 @attr(type='smoke')
Matthew Treinish660a4c12013-09-09 20:06:12 +0000141 @services('image')
QingXin Meng611768a2013-09-18 00:51:33 -0700142 def test_volume_create_get_update_delete_from_image(self):
143 self._volume_create_get_update_delete(imageRef=self.
144 config.compute.image_ref)
Giulio Fidente02f42982013-06-17 16:25:56 +0200145
146 @attr(type='gate')
QingXin Meng611768a2013-09-18 00:51:33 -0700147 def test_volume_create_get_update_delete_as_clone(self):
Giulio Fidente02f42982013-06-17 16:25:56 +0200148 origin = self.create_volume(size=1,
149 display_name="Volume Origin")
QingXin Meng611768a2013-09-18 00:51:33 -0700150 self._volume_create_get_update_delete(source_volid=origin['id'])
Giulio Fidente36836c42013-04-05 15:43:51 +0200151
Matthew Treinish9854d5b2012-09-20 10:22:13 -0400152
Attila Fazekas3dcdae12013-02-14 12:50:04 +0100153class VolumesGetTestXML(VolumesGetTest):
154 _interface = "xml"