blob: 32a355b1881c0dd2186cd6204cebfb838ff23676 [file] [log] [blame]
Jérôme Gallard86551ce2013-03-08 11:41:26 +01001# Licensed under the Apache License, Version 2.0 (the "License"); you may
2# not use this file except in compliance with the License. You may obtain
3# a copy of the License at
4#
5# http://www.apache.org/licenses/LICENSE-2.0
6#
7# Unless required by applicable law or agreed to in writing, software
8# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
9# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
10# License for the specific language governing permissions and limitations
11# under the License.
12
Sean Dague1937d092013-05-17 16:36:38 -040013from tempest.api.volume import base
Masayuki Igawa259c1132013-10-31 17:48:44 +090014from tempest.common.utils import data_utils
Matthew Treinishf4a9b0f2013-07-26 16:58:26 -040015from tempest.openstack.common import log as logging
Jérôme Gallard86551ce2013-03-08 11:41:26 +010016from tempest.services.volume.json.admin import volume_types_client
17from tempest.services.volume.json import volumes_client
Giulio Fidente8b311902013-05-12 15:40:31 +020018from tempest.test import attr
Jérôme Gallard86551ce2013-03-08 11:41:26 +010019
20LOG = logging.getLogger(__name__)
21
22
Zhi Kun Liubb363a22013-11-28 18:47:39 +080023class VolumeMultiBackendTest(base.BaseVolumeV1AdminTest):
Jérôme Gallard86551ce2013-03-08 11:41:26 +010024 _interface = "json"
25
Jérôme Gallard86551ce2013-03-08 11:41:26 +010026 @classmethod
Jérôme Gallard86551ce2013-03-08 11:41:26 +010027 def setUpClass(cls):
28 super(VolumeMultiBackendTest, cls).setUpClass()
Matthew Treinishd5c96022013-10-17 21:51:23 +000029 if not cls.config.volume_feature_enabled.multi_backend:
armando-migliaccio3e2a0282013-11-22 14:47:16 -080030 cls.tearDownClass()
Giulio Fidentef4fa8942013-05-28 18:48:03 +020031 raise cls.skipException("Cinder multi-backend feature disabled")
32
33 cls.backend1_name = cls.config.volume.backend1_name
34 cls.backend2_name = cls.config.volume.backend2_name
Jérôme Gallard86551ce2013-03-08 11:41:26 +010035
36 adm_user = cls.config.identity.admin_username
37 adm_pass = cls.config.identity.admin_password
38 adm_tenant = cls.config.identity.admin_tenant_name
39 auth_url = cls.config.identity.uri
40
Giulio Fidentef4fa8942013-05-28 18:48:03 +020041 cls.volume_client = volumes_client.VolumesClientJSON(cls.config,
42 adm_user,
43 adm_pass,
44 auth_url,
45 adm_tenant)
46 cls.type_client = volume_types_client.VolumeTypesClientJSON(cls.config,
47 adm_user,
48 adm_pass,
49 auth_url,
50 adm_tenant)
Jérôme Gallard86551ce2013-03-08 11:41:26 +010051
Giulio Fidentef4fa8942013-05-28 18:48:03 +020052 cls.volume_type_id_list = []
Jérôme Gallard86551ce2013-03-08 11:41:26 +010053 cls.volume_id_list = []
Jérôme Gallard86551ce2013-03-08 11:41:26 +010054 try:
Giulio Fidentef4fa8942013-05-28 18:48:03 +020055 # Volume/Type creation (uses backend1_name)
Masayuki Igawa259c1132013-10-31 17:48:44 +090056 type1_name = data_utils.rand_name('Type-')
57 vol1_name = data_utils.rand_name('Volume-')
Jérôme Gallard86551ce2013-03-08 11:41:26 +010058 extra_specs1 = {"volume_backend_name": cls.backend1_name}
Giulio Fidentef4fa8942013-05-28 18:48:03 +020059 resp, cls.type1 = cls.type_client.create_volume_type(
60 type1_name, extra_specs=extra_specs1)
61 cls.volume_type_id_list.append(cls.type1['id'])
Jérôme Gallard86551ce2013-03-08 11:41:26 +010062
Giulio Fidentef4fa8942013-05-28 18:48:03 +020063 resp, cls.volume1 = cls.volume_client.create_volume(
64 size=1, display_name=vol1_name, volume_type=type1_name)
Jérôme Gallard86551ce2013-03-08 11:41:26 +010065 cls.volume_id_list.append(cls.volume1['id'])
Giulio Fidentef4fa8942013-05-28 18:48:03 +020066 cls.volume_client.wait_for_volume_status(cls.volume1['id'],
67 'available')
Jérôme Gallard86551ce2013-03-08 11:41:26 +010068
Giulio Fidentef4fa8942013-05-28 18:48:03 +020069 if cls.backend1_name != cls.backend2_name:
70 # Volume/Type creation (uses backend2_name)
Masayuki Igawa259c1132013-10-31 17:48:44 +090071 type2_name = data_utils.rand_name('Type-')
72 vol2_name = data_utils.rand_name('Volume-')
Giulio Fidentef4fa8942013-05-28 18:48:03 +020073 extra_specs2 = {"volume_backend_name": cls.backend2_name}
74 resp, cls.type2 = cls.type_client.create_volume_type(
75 type2_name, extra_specs=extra_specs2)
76 cls.volume_type_id_list.append(cls.type2['id'])
77
78 resp, cls.volume2 = cls.volume_client.create_volume(
79 size=1, display_name=vol2_name, volume_type=type2_name)
80 cls.volume_id_list.append(cls.volume2['id'])
81 cls.volume_client.wait_for_volume_status(cls.volume2['id'],
82 'available')
Matt Riedemannbc8dbd32013-08-02 14:02:12 -070083 except Exception as e:
84 LOG.exception("setup failed: %s" % e)
Jérôme Gallard86551ce2013-03-08 11:41:26 +010085 cls.tearDownClass()
86 raise
87
88 @classmethod
89 def tearDownClass(cls):
Attila Fazekasf7f34f92013-08-01 17:01:44 +020090 # volumes deletion
armando-migliaccio3e2a0282013-11-22 14:47:16 -080091 volume_id_list = getattr(cls, 'volume_id_list', [])
92 for volume_id in volume_id_list:
Giulio Fidentef4fa8942013-05-28 18:48:03 +020093 cls.volume_client.delete_volume(volume_id)
94 cls.volume_client.wait_for_resource_deletion(volume_id)
Jérôme Gallard86551ce2013-03-08 11:41:26 +010095
Attila Fazekasf7f34f92013-08-01 17:01:44 +020096 # volume types deletion
armando-migliaccio3e2a0282013-11-22 14:47:16 -080097 volume_type_id_list = getattr(cls, 'volume_type_id_list', [])
98 for volume_type_id in volume_type_id_list:
Giulio Fidentef4fa8942013-05-28 18:48:03 +020099 cls.type_client.delete_volume_type(volume_type_id)
Jérôme Gallard86551ce2013-03-08 11:41:26 +0100100
Dolph Mathews6dbb27c2013-05-09 10:56:24 -0500101 super(VolumeMultiBackendTest, cls).tearDownClass()
102
Giulio Fidenteba3985a2013-05-29 01:46:36 +0200103 @attr(type='smoke')
Giulio Fidentef4fa8942013-05-28 18:48:03 +0200104 def test_backend_name_reporting(self):
105 # this test checks if os-vol-attr:host is populated correctly after
106 # the multi backend feature has been enabled
Jérôme Gallard86551ce2013-03-08 11:41:26 +0100107 # if multi-backend is enabled: os-vol-attr:host should be like:
108 # host@backend_name
Giulio Fidentef4fa8942013-05-28 18:48:03 +0200109 resp, volume = self.volume_client.get_volume(self.volume1['id'])
Jérôme Gallard86551ce2013-03-08 11:41:26 +0100110 self.assertEqual(200, resp.status)
111
Giulio Fidentef4fa8942013-05-28 18:48:03 +0200112 volume1_host = volume['os-vol-host-attr:host']
113 msg = ("multi-backend reporting incorrect values for volume %s" %
114 self.volume1['id'])
115 self.assertTrue(len(volume1_host.split("@")) > 1, msg)
Jérôme Gallard86551ce2013-03-08 11:41:26 +0100116
Giulio Fidente8b311902013-05-12 15:40:31 +0200117 @attr(type='gate')
Jérôme Gallard86551ce2013-03-08 11:41:26 +0100118 def test_backend_name_distinction(self):
Giulio Fidentef4fa8942013-05-28 18:48:03 +0200119 # this test checks that the two volumes created at setUp don't
120 # belong to the same backend (if they are, than the
121 # volume backend distinction is not working properly)
122 if self.backend1_name == self.backend2_name:
123 raise self.skipException("backends configured with same name")
Jérôme Gallard86551ce2013-03-08 11:41:26 +0100124
Giulio Fidentef4fa8942013-05-28 18:48:03 +0200125 resp, volume = self.volume_client.get_volume(self.volume1['id'])
126 volume1_host = volume['os-vol-host-attr:host']
Jérôme Gallard86551ce2013-03-08 11:41:26 +0100127
Giulio Fidentef4fa8942013-05-28 18:48:03 +0200128 resp, volume = self.volume_client.get_volume(self.volume2['id'])
129 volume2_host = volume['os-vol-host-attr:host']
Jérôme Gallard86551ce2013-03-08 11:41:26 +0100130
Giulio Fidentef4fa8942013-05-28 18:48:03 +0200131 msg = ("volumes %s and %s were created in the same backend" %
132 (self.volume1['id'], self.volume2['id']))
133 self.assertNotEqual(volume1_host, volume2_host, msg)