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 |
| 30 | def setUpClass(cls): |
ravikumar-venkatesan | 753262b | 2013-03-21 12:43:57 +0000 | [diff] [blame] | 31 | super(LiveBlockMigrationTestJSON, cls).setUpClass() |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 32 | |
Attila Fazekas | 8e99b99 | 2013-02-24 09:53:23 +0100 | [diff] [blame] | 33 | cls.admin_hosts_client = cls.os_adm.hosts_client |
| 34 | cls.admin_servers_client = cls.os_adm.servers_client |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 35 | |
| 36 | cls.created_server_ids = [] |
| 37 | |
| 38 | def _get_compute_hostnames(self): |
| 39 | _resp, body = self.admin_hosts_client.list_hosts() |
| 40 | return [ |
| 41 | host_record['host_name'] |
| 42 | for host_record in body |
| 43 | if host_record['service'] == 'compute' |
| 44 | ] |
| 45 | |
| 46 | def _get_server_details(self, server_id): |
| 47 | _resp, body = self.admin_servers_client.get_server(server_id) |
| 48 | return body |
| 49 | |
| 50 | def _get_host_for_server(self, server_id): |
Mate Lakat | 0ccf0eb | 2013-03-28 12:00:52 +0000 | [diff] [blame] | 51 | return self._get_server_details(server_id)[self._host_key] |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 52 | |
| 53 | def _migrate_server_to(self, server_id, dest_host): |
| 54 | _resp, body = self.admin_servers_client.live_migrate_server( |
Bob Ball | 0dca897 | 2013-04-09 16:23:31 +0100 | [diff] [blame] | 55 | server_id, dest_host, |
Matthew Treinish | b0a78fc | 2014-01-29 16:49:12 +0000 | [diff] [blame] | 56 | CONF.compute_feature_enabled.block_migration_for_live_migration) |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 57 | return body |
| 58 | |
| 59 | def _get_host_other_than(self, host): |
| 60 | for target_host in self._get_compute_hostnames(): |
| 61 | if host != target_host: |
| 62 | return target_host |
| 63 | |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 64 | def _get_server_status(self, server_id): |
| 65 | return self._get_server_details(server_id)['status'] |
| 66 | |
| 67 | def _get_an_active_server(self): |
| 68 | for server_id in self.created_server_ids: |
| 69 | if 'ACTIVE' == self._get_server_status(server_id): |
| 70 | return server_id |
| 71 | else: |
Ken'ichi Ohmichi | cfc052e | 2013-10-23 11:50:04 +0900 | [diff] [blame] | 72 | _, server = self.create_test_server(wait_until="ACTIVE") |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 73 | server_id = server['id'] |
| 74 | self.password = server['adminPass'] |
| 75 | self.password = 'password' |
| 76 | self.created_server_ids.append(server_id) |
| 77 | return server_id |
| 78 | |
Bob Ball | c078be9 | 2013-04-09 14:25:00 +0100 | [diff] [blame] | 79 | def _volume_clean_up(self, server_id, volume_id): |
| 80 | resp, body = self.volumes_client.get_volume(volume_id) |
| 81 | if body['status'] == 'in-use': |
| 82 | self.servers_client.detach_volume(server_id, volume_id) |
| 83 | self.volumes_client.wait_for_volume_status(volume_id, 'available') |
| 84 | self.volumes_client.delete_volume(volume_id) |
| 85 | |
Matthew Treinish | d5c9602 | 2013-10-17 21:51:23 +0000 | [diff] [blame] | 86 | @testtools.skipIf(not CONF.compute_feature_enabled.live_migration, |
Bob Ball | 0dca897 | 2013-04-09 16:23:31 +0100 | [diff] [blame] | 87 | 'Live migration not available') |
Yuiko Takada | e9999d6 | 2014-03-06 09:22:54 +0000 | [diff] [blame] | 88 | @test.attr(type='gate') |
Attila Fazekas | 8e99b99 | 2013-02-24 09:53:23 +0100 | [diff] [blame] | 89 | def test_live_block_migration(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 90 | # Live block migrate an instance to another host |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 91 | if len(self._get_compute_hostnames()) < 2: |
ivan-zhu | 1feeb38 | 2013-01-24 10:14:39 +0800 | [diff] [blame] | 92 | raise self.skipTest( |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 93 | "Less than 2 compute nodes, skipping migration test.") |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 94 | server_id = self._get_an_active_server() |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 95 | actual_host = self._get_host_for_server(server_id) |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 96 | target_host = self._get_host_other_than(actual_host) |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 97 | self._migrate_server_to(server_id, target_host) |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 98 | self.servers_client.wait_for_server_status(server_id, 'ACTIVE') |
Chang Bo Guo | fc77e93 | 2013-09-16 17:38:26 -0700 | [diff] [blame] | 99 | self.assertEqual(target_host, self._get_host_for_server(server_id)) |
Mate Lakat | 99ee914 | 2012-09-14 12:34:46 +0100 | [diff] [blame] | 100 | |
Matthew Treinish | d5c9602 | 2013-10-17 21:51:23 +0000 | [diff] [blame] | 101 | @testtools.skipIf(not CONF.compute_feature_enabled.live_migration or not |
| 102 | CONF.compute_feature_enabled. |
| 103 | block_migration_for_live_migration, |
Bob Ball | c078be9 | 2013-04-09 14:25:00 +0100 | [diff] [blame] | 104 | 'Block Live migration not available') |
Matthew Treinish | d5c9602 | 2013-10-17 21:51:23 +0000 | [diff] [blame] | 105 | @testtools.skipIf(not CONF.compute_feature_enabled. |
| 106 | block_migrate_cinder_iscsi, |
Bob Ball | c078be9 | 2013-04-09 14:25:00 +0100 | [diff] [blame] | 107 | 'Block Live migration not configured for iSCSI') |
Yuiko Takada | e9999d6 | 2014-03-06 09:22:54 +0000 | [diff] [blame] | 108 | @test.attr(type='gate') |
Bob Ball | c078be9 | 2013-04-09 14:25:00 +0100 | [diff] [blame] | 109 | def test_iscsi_volume(self): |
| 110 | # Live block migrate an instance to another host |
| 111 | if len(self._get_compute_hostnames()) < 2: |
| 112 | raise self.skipTest( |
| 113 | "Less than 2 compute nodes, skipping migration test.") |
| 114 | server_id = self._get_an_active_server() |
| 115 | actual_host = self._get_host_for_server(server_id) |
| 116 | target_host = self._get_host_other_than(actual_host) |
| 117 | |
| 118 | resp, volume = self.volumes_client.create_volume(1, |
| 119 | display_name='test') |
| 120 | |
| 121 | self.volumes_client.wait_for_volume_status(volume['id'], |
| 122 | 'available') |
| 123 | self.addCleanup(self._volume_clean_up, server_id, volume['id']) |
| 124 | |
| 125 | # Attach the volume to the server |
| 126 | self.servers_client.attach_volume(server_id, volume['id'], |
| 127 | device='/dev/xvdb') |
| 128 | self.volumes_client.wait_for_volume_status(volume['id'], 'in-use') |
| 129 | |
| 130 | self._migrate_server_to(server_id, target_host) |
| 131 | self.servers_client.wait_for_server_status(server_id, 'ACTIVE') |
Chang Bo Guo | fc77e93 | 2013-09-16 17:38:26 -0700 | [diff] [blame] | 132 | self.assertEqual(target_host, self._get_host_for_server(server_id)) |
Bob Ball | c078be9 | 2013-04-09 14:25:00 +0100 | [diff] [blame] | 133 | |
ravikumar-venkatesan | 753262b | 2013-03-21 12:43:57 +0000 | [diff] [blame] | 134 | |
| 135 | class LiveBlockMigrationTestXML(LiveBlockMigrationTestJSON): |
Mate Lakat | 0ccf0eb | 2013-03-28 12:00:52 +0000 | [diff] [blame] | 136 | _host_key = ( |
| 137 | '{http://docs.openstack.org/compute/ext/extended_status/api/v1.1}host') |
ravikumar-venkatesan | 753262b | 2013-03-21 12:43:57 +0000 | [diff] [blame] | 138 | _interface = 'xml' |