blob: a5e393fad71a6e1f4212d1b216e77e42e264d803 [file] [log] [blame]
Marc Koderer341bf1c2013-07-11 15:16:08 +02001# (c) 2013 Deutsche Telekom AG
2# Licensed under the Apache License, Version 2.0 (the "License");
3# you may not use this file except in compliance with the License.
4# You may obtain a copy of the License at
5#
6# http://www.apache.org/licenses/LICENSE-2.0
7#
8# Unless required by applicable law or agreed to in writing, software
9# distributed under the License is distributed on an "AS IS" BASIS,
10# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11# See the License for the specific language governing permissions and
12# limitations under the License.
13
Fei Long Wangd39431f2015-05-14 11:30:48 +120014from tempest.common.utils import data_utils
Matthew Treinish88f49ef2014-01-29 18:36:27 +000015from tempest import config
Marc Koderer341bf1c2013-07-11 15:16:08 +020016import tempest.stress.stressaction as stressaction
17
Matthew Treinish88f49ef2014-01-29 18:36:27 +000018CONF = config.CONF
19
Marc Koderer341bf1c2013-07-11 15:16:08 +020020
21class VolumeAttachDeleteTest(stressaction.StressAction):
22
23 def setUp(self, **kwargs):
Matthew Treinish88f49ef2014-01-29 18:36:27 +000024 self.image = CONF.compute.image_ref
25 self.flavor = CONF.compute.flavor_ref
Marc Koderer341bf1c2013-07-11 15:16:08 +020026
27 def run(self):
28 # Step 1: create volume
Masayuki Igawa259c1132013-10-31 17:48:44 +090029 name = data_utils.rand_name("volume")
Marc Koderer341bf1c2013-07-11 15:16:08 +020030 self.logger.info("creating volume: %s" % name)
David Kranz668d3892015-02-16 09:20:08 -050031 volume = self.manager.volumes_client.create_volume(
Matthew Treinish57160582014-06-09 17:13:48 -040032 display_name=name)
Marc Koderer341bf1c2013-07-11 15:16:08 +020033 self.manager.volumes_client.wait_for_volume_status(volume['id'],
34 'available')
35 self.logger.info("created volume: %s" % volume['id'])
36
37 # Step 2: create vm instance
Masayuki Igawa259c1132013-10-31 17:48:44 +090038 vm_name = data_utils.rand_name("instance")
Marc Koderer341bf1c2013-07-11 15:16:08 +020039 self.logger.info("creating vm: %s" % vm_name)
David Kranz668d3892015-02-16 09:20:08 -050040 server = self.manager.servers_client.create_server(
Marc Koderer341bf1c2013-07-11 15:16:08 +020041 vm_name, self.image, self.flavor)
42 server_id = server['id']
Marc Koderer341bf1c2013-07-11 15:16:08 +020043 self.manager.servers_client.wait_for_server_status(server_id, 'ACTIVE')
44 self.logger.info("created vm %s" % server_id)
45
46 # Step 3: attach volume to vm
47 self.logger.info("attach volume (%s) to vm %s" %
Matthew Treinish1d14c542014-06-17 20:25:40 -040048 (volume['id'], server_id))
ghanshyam51e84f42014-10-02 17:28:18 +090049 self.manager.servers_client.attach_volume(server_id,
50 volume['id'],
51 '/dev/vdc')
Marc Koderer341bf1c2013-07-11 15:16:08 +020052 self.manager.volumes_client.wait_for_volume_status(volume['id'],
53 'in-use')
54 self.logger.info("volume (%s) attached to vm %s" %
55 (volume['id'], server_id))
56
57 # Step 4: delete vm
58 self.logger.info("deleting vm: %s" % vm_name)
ghanshyam51e84f42014-10-02 17:28:18 +090059 self.manager.servers_client.delete_server(server_id)
Marc Koderer341bf1c2013-07-11 15:16:08 +020060 self.manager.servers_client.wait_for_server_termination(server_id)
61 self.logger.info("deleted vm: %s" % server_id)
62
63 # Step 5: delete volume
64 self.logger.info("deleting volume: %s" % volume['id'])
ghanshyam51e84f42014-10-02 17:28:18 +090065 self.manager.volumes_client.delete_volume(volume['id'])
Marc Koderer341bf1c2013-07-11 15:16:08 +020066 self.manager.volumes_client.wait_for_resource_deletion(volume['id'])
67 self.logger.info("deleted volume: %s" % volume['id'])