ZhiQiang Fan | 39f9722 | 2013-09-20 04:49:44 +0800 | [diff] [blame] | 1 | # Copyright 2012 OpenStack Foundation |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 2 | # 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 | |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 16 | |
ivan-zhu | 1feeb38 | 2013-01-24 10:14:39 +0800 | [diff] [blame] | 17 | import testtools |
Matthew Treinish | a83a16e | 2012-12-07 13:44:02 -0500 | [diff] [blame] | 18 | |
Sean Dague | 1937d09 | 2013-05-17 16:36:38 -0400 | [diff] [blame] | 19 | from tempest.api.compute import base |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 20 | from tempest import config |
Yuiko Takada | e9999d6 | 2014-03-06 09:22:54 +0000 | [diff] [blame] | 21 | from tempest import test |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 22 | |
Matthew Treinish | b0a78fc | 2014-01-29 16:49:12 +0000 | [diff] [blame] | 23 | CONF = config.CONF |
| 24 | |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 25 | |
ivan-zhu | f2b0050 | 2013-10-18 10:06:52 +0800 | [diff] [blame] | 26 | class LiveBlockMigrationTestJSON(base.BaseV2ComputeAdminTest): |
Mate Lakat | 0ccf0eb | 2013-03-28 12:00:52 +0000 | [diff] [blame] | 27 | _host_key = 'OS-EXT-SRV-ATTR:host' |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 28 | |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 29 | @classmethod |
Rohan Kanade | 60b7309 | 2015-02-04 17:58:19 +0530 | [diff] [blame^] | 30 | def setup_clients(cls): |
| 31 | super(LiveBlockMigrationTestJSON, cls).setup_clients() |
Attila Fazekas | 8e99b99 | 2013-02-24 09:53:23 +0100 | [diff] [blame] | 32 | cls.admin_hosts_client = cls.os_adm.hosts_client |
| 33 | cls.admin_servers_client = cls.os_adm.servers_client |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 34 | |
Rohan Kanade | 60b7309 | 2015-02-04 17:58:19 +0530 | [diff] [blame^] | 35 | @classmethod |
| 36 | def resource_setup(cls): |
| 37 | super(LiveBlockMigrationTestJSON, cls).resource_setup() |
| 38 | |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 39 | cls.created_server_ids = [] |
| 40 | |
| 41 | def _get_compute_hostnames(self): |
David Kranz | 0a73517 | 2015-01-16 10:51:18 -0500 | [diff] [blame] | 42 | body = self.admin_hosts_client.list_hosts() |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 43 | return [ |
| 44 | host_record['host_name'] |
| 45 | for host_record in body |
| 46 | if host_record['service'] == 'compute' |
| 47 | ] |
| 48 | |
| 49 | def _get_server_details(self, server_id): |
David Kranz | 0fb1429 | 2015-02-11 15:55:20 -0500 | [diff] [blame] | 50 | body = self.admin_servers_client.get_server(server_id) |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 51 | return body |
| 52 | |
| 53 | def _get_host_for_server(self, server_id): |
Mate Lakat | 0ccf0eb | 2013-03-28 12:00:52 +0000 | [diff] [blame] | 54 | return self._get_server_details(server_id)[self._host_key] |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 55 | |
| 56 | def _migrate_server_to(self, server_id, dest_host): |
David Kranz | ae99b9a | 2015-02-16 13:37:01 -0500 | [diff] [blame] | 57 | body = self.admin_servers_client.live_migrate_server( |
Bob Ball | 0dca897 | 2013-04-09 16:23:31 +0100 | [diff] [blame] | 58 | server_id, dest_host, |
Matthew Treinish | b0a78fc | 2014-01-29 16:49:12 +0000 | [diff] [blame] | 59 | CONF.compute_feature_enabled.block_migration_for_live_migration) |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 60 | return body |
| 61 | |
| 62 | def _get_host_other_than(self, host): |
| 63 | for target_host in self._get_compute_hostnames(): |
| 64 | if host != target_host: |
| 65 | return target_host |
| 66 | |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 67 | def _get_server_status(self, server_id): |
| 68 | return self._get_server_details(server_id)['status'] |
| 69 | |
| 70 | def _get_an_active_server(self): |
| 71 | for server_id in self.created_server_ids: |
| 72 | if 'ACTIVE' == self._get_server_status(server_id): |
| 73 | return server_id |
| 74 | else: |
David Kranz | 0fb1429 | 2015-02-11 15:55:20 -0500 | [diff] [blame] | 75 | server = self.create_test_server(wait_until="ACTIVE") |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 76 | server_id = server['id'] |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 77 | self.created_server_ids.append(server_id) |
| 78 | return server_id |
| 79 | |
Bob Ball | c078be9 | 2013-04-09 14:25:00 +0100 | [diff] [blame] | 80 | def _volume_clean_up(self, server_id, volume_id): |
Joseph Lanoux | 5d7b6c1 | 2015-02-09 13:57:24 +0000 | [diff] [blame] | 81 | body = self.volumes_client.get_volume(volume_id) |
Bob Ball | c078be9 | 2013-04-09 14:25:00 +0100 | [diff] [blame] | 82 | if body['status'] == 'in-use': |
| 83 | self.servers_client.detach_volume(server_id, volume_id) |
| 84 | self.volumes_client.wait_for_volume_status(volume_id, 'available') |
| 85 | self.volumes_client.delete_volume(volume_id) |
| 86 | |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 87 | @test.idempotent_id('1dce86b8-eb04-4c03-a9d8-9c1dc3ee0c7b') |
Matthew Treinish | d5c9602 | 2013-10-17 21:51:23 +0000 | [diff] [blame] | 88 | @testtools.skipIf(not CONF.compute_feature_enabled.live_migration, |
Bob Ball | 0dca897 | 2013-04-09 16:23:31 +0100 | [diff] [blame] | 89 | 'Live migration not available') |
Yuiko Takada | e9999d6 | 2014-03-06 09:22:54 +0000 | [diff] [blame] | 90 | @test.attr(type='gate') |
Attila Fazekas | 8e99b99 | 2013-02-24 09:53:23 +0100 | [diff] [blame] | 91 | def test_live_block_migration(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 92 | # Live block migrate an instance to another host |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 93 | if len(self._get_compute_hostnames()) < 2: |
ivan-zhu | 1feeb38 | 2013-01-24 10:14:39 +0800 | [diff] [blame] | 94 | raise self.skipTest( |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 95 | "Less than 2 compute nodes, skipping migration test.") |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 96 | server_id = self._get_an_active_server() |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 97 | actual_host = self._get_host_for_server(server_id) |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 98 | target_host = self._get_host_other_than(actual_host) |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 99 | self._migrate_server_to(server_id, target_host) |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 100 | self.servers_client.wait_for_server_status(server_id, 'ACTIVE') |
Chang Bo Guo | fc77e93 | 2013-09-16 17:38:26 -0700 | [diff] [blame] | 101 | self.assertEqual(target_host, self._get_host_for_server(server_id)) |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 102 | |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 103 | @test.idempotent_id('e19c0cc6-6720-4ed8-be83-b6603ed5c812') |
Matthew Treinish | d5c9602 | 2013-10-17 21:51:23 +0000 | [diff] [blame] | 104 | @testtools.skipIf(not CONF.compute_feature_enabled.live_migration or not |
| 105 | CONF.compute_feature_enabled. |
| 106 | block_migration_for_live_migration, |
Bob Ball | c078be9 | 2013-04-09 14:25:00 +0100 | [diff] [blame] | 107 | 'Block Live migration not available') |
Matthew Treinish | d5c9602 | 2013-10-17 21:51:23 +0000 | [diff] [blame] | 108 | @testtools.skipIf(not CONF.compute_feature_enabled. |
| 109 | block_migrate_cinder_iscsi, |
Bob Ball | c078be9 | 2013-04-09 14:25:00 +0100 | [diff] [blame] | 110 | 'Block Live migration not configured for iSCSI') |
Yuiko Takada | e9999d6 | 2014-03-06 09:22:54 +0000 | [diff] [blame] | 111 | @test.attr(type='gate') |
Bob Ball | c078be9 | 2013-04-09 14:25:00 +0100 | [diff] [blame] | 112 | def test_iscsi_volume(self): |
| 113 | # Live block migrate an instance to another host |
| 114 | if len(self._get_compute_hostnames()) < 2: |
| 115 | raise self.skipTest( |
| 116 | "Less than 2 compute nodes, skipping migration test.") |
| 117 | server_id = self._get_an_active_server() |
| 118 | actual_host = self._get_host_for_server(server_id) |
| 119 | target_host = self._get_host_other_than(actual_host) |
| 120 | |
Markus Zoeller | 3d2a21c | 2015-02-27 12:04:22 +0100 | [diff] [blame] | 121 | volume = self.volumes_client.create_volume(display_name='test') |
Bob Ball | c078be9 | 2013-04-09 14:25:00 +0100 | [diff] [blame] | 122 | |
| 123 | self.volumes_client.wait_for_volume_status(volume['id'], |
| 124 | 'available') |
| 125 | self.addCleanup(self._volume_clean_up, server_id, volume['id']) |
| 126 | |
| 127 | # Attach the volume to the server |
| 128 | self.servers_client.attach_volume(server_id, volume['id'], |
| 129 | device='/dev/xvdb') |
| 130 | self.volumes_client.wait_for_volume_status(volume['id'], 'in-use') |
| 131 | |
| 132 | self._migrate_server_to(server_id, target_host) |
| 133 | self.servers_client.wait_for_server_status(server_id, 'ACTIVE') |
Chang Bo Guo | fc77e93 | 2013-09-16 17:38:26 -0700 | [diff] [blame] | 134 | self.assertEqual(target_host, self._get_host_for_server(server_id)) |