blob: b438f52029eb039b447b7e4c7b09b8887c0c3599 [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
Masayuki Igawa259c1132013-10-31 17:48:44 +090014from 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)
Matthew Treinish57160582014-06-09 17:13:48 -040031 resp, volume = self.manager.volumes_client.create_volume(
32 size=1,
33 display_name=name)
Marc Koderer341bf1c2013-07-11 15:16:08 +020034 assert(resp.status == 200)
35 self.manager.volumes_client.wait_for_volume_status(volume['id'],
36 'available')
37 self.logger.info("created volume: %s" % volume['id'])
38
39 # Step 2: create vm instance
Masayuki Igawa259c1132013-10-31 17:48:44 +090040 vm_name = data_utils.rand_name("instance")
Marc Koderer341bf1c2013-07-11 15:16:08 +020041 self.logger.info("creating vm: %s" % vm_name)
42 resp, server = self.manager.servers_client.create_server(
43 vm_name, self.image, self.flavor)
44 server_id = server['id']
45 assert(resp.status == 202)
46 self.manager.servers_client.wait_for_server_status(server_id, 'ACTIVE')
47 self.logger.info("created vm %s" % server_id)
48
49 # Step 3: attach volume to vm
50 self.logger.info("attach volume (%s) to vm %s" %
51 (volume['id'], server_id))
52 resp, body = self.manager.servers_client.attach_volume(server_id,
53 volume['id'],
54 '/dev/vdc')
55 assert(resp.status == 200)
56 self.manager.volumes_client.wait_for_volume_status(volume['id'],
57 'in-use')
58 self.logger.info("volume (%s) attached to vm %s" %
59 (volume['id'], server_id))
60
61 # Step 4: delete vm
62 self.logger.info("deleting vm: %s" % vm_name)
63 resp, _ = self.manager.servers_client.delete_server(server_id)
64 assert(resp.status == 204)
65 self.manager.servers_client.wait_for_server_termination(server_id)
66 self.logger.info("deleted vm: %s" % server_id)
67
68 # Step 5: delete volume
69 self.logger.info("deleting volume: %s" % volume['id'])
70 resp, _ = self.manager.volumes_client.delete_volume(volume['id'])
71 assert(resp.status == 202)
72 self.manager.volumes_client.wait_for_resource_deletion(volume['id'])
73 self.logger.info("deleted volume: %s" % volume['id'])