| ZhiQiang Fan | 39f9722 | 2013-09-20 04:49:44 +0800 | [diff] [blame] | 1 | # Copyright 2012 OpenStack Foundation | 
| Jay Pipes | 051075a | 2012-04-28 17:39:37 -0400 | [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 |  | 
| armando-migliaccio | 9e5eac0 | 2014-03-24 10:55:31 -0700 | [diff] [blame] | 16 | import testtools | 
|  | 17 |  | 
| Matthew Treinish | 6c07229 | 2014-01-29 19:15:52 +0000 | [diff] [blame] | 18 | from tempest import config | 
| Matthew Treinish | f4a9b0f | 2013-07-26 16:58:26 -0400 | [diff] [blame] | 19 | from tempest.openstack.common import log as logging | 
| Sean Dague | 6dbc6da | 2013-05-08 17:49:46 -0400 | [diff] [blame] | 20 | from tempest.scenario import manager | 
| Masayuki Igawa | 4ded9f0 | 2014-02-17 15:05:59 +0900 | [diff] [blame] | 21 | from tempest import test | 
| Jay Pipes | 051075a | 2012-04-28 17:39:37 -0400 | [diff] [blame] | 22 |  | 
| Matthew Treinish | 6c07229 | 2014-01-29 19:15:52 +0000 | [diff] [blame] | 23 | CONF = config.CONF | 
|  | 24 |  | 
| Jay Pipes | 051075a | 2012-04-28 17:39:37 -0400 | [diff] [blame] | 25 | LOG = logging.getLogger(__name__) | 
|  | 26 |  | 
|  | 27 |  | 
| Ghanshyam | aadf036 | 2014-08-27 16:51:26 +0900 | [diff] [blame] | 28 | class TestServerAdvancedOps(manager.ScenarioTest): | 
| Jay Pipes | 051075a | 2012-04-28 17:39:37 -0400 | [diff] [blame] | 29 |  | 
|  | 30 | """ | 
|  | 31 | This test case stresses some advanced server instance operations: | 
|  | 32 |  | 
|  | 33 | * Resizing an instance | 
| Tatyana Leontovich | 58ab531 | 2013-04-22 16:48:33 +0300 | [diff] [blame] | 34 | * Sequence suspend resume | 
| Jay Pipes | 051075a | 2012-04-28 17:39:37 -0400 | [diff] [blame] | 35 | """ | 
|  | 36 |  | 
|  | 37 | @classmethod | 
| Andrea Frittoli | ac20b5e | 2014-09-15 13:31:14 +0100 | [diff] [blame^] | 38 | def resource_setup(cls): | 
| Sylvain Afchain | 9206477 | 2014-01-16 02:45:57 +0100 | [diff] [blame] | 39 | cls.set_network_resources() | 
| Andrea Frittoli | ac20b5e | 2014-09-15 13:31:14 +0100 | [diff] [blame^] | 40 | super(TestServerAdvancedOps, cls).resource_setup() | 
| Jay Pipes | 051075a | 2012-04-28 17:39:37 -0400 | [diff] [blame] | 41 |  | 
| armando-migliaccio | 9e5eac0 | 2014-03-24 10:55:31 -0700 | [diff] [blame] | 42 | if CONF.compute.flavor_ref_alt == CONF.compute.flavor_ref: | 
| Jay Pipes | 051075a | 2012-04-28 17:39:37 -0400 | [diff] [blame] | 43 | msg = "Skipping test - flavor_ref and flavor_ref_alt are identical" | 
| ivan-zhu | 1feeb38 | 2013-01-24 10:14:39 +0800 | [diff] [blame] | 44 | raise cls.skipException(msg) | 
| Jay Pipes | 051075a | 2012-04-28 17:39:37 -0400 | [diff] [blame] | 45 |  | 
| armando-migliaccio | 9e5eac0 | 2014-03-24 10:55:31 -0700 | [diff] [blame] | 46 | @testtools.skipUnless(CONF.compute_feature_enabled.resize, | 
|  | 47 | 'Resize is not available.') | 
| Masayuki Igawa | 4ded9f0 | 2014-02-17 15:05:59 +0900 | [diff] [blame] | 48 | @test.services('compute') | 
| Jay Pipes | 051075a | 2012-04-28 17:39:37 -0400 | [diff] [blame] | 49 | def test_resize_server_confirm(self): | 
|  | 50 | # We create an instance for use in this test | 
| Giulio Fidente | 61cadca | 2013-09-24 18:33:37 +0200 | [diff] [blame] | 51 | instance = self.create_server() | 
| Ghanshyam | aadf036 | 2014-08-27 16:51:26 +0900 | [diff] [blame] | 52 | instance_id = instance['id'] | 
| Matthew Treinish | 6c07229 | 2014-01-29 19:15:52 +0000 | [diff] [blame] | 53 | resize_flavor = CONF.compute.flavor_ref_alt | 
| Jay Pipes | 051075a | 2012-04-28 17:39:37 -0400 | [diff] [blame] | 54 | LOG.debug("Resizing instance %s from flavor %s to flavor %s", | 
| Ghanshyam | aadf036 | 2014-08-27 16:51:26 +0900 | [diff] [blame] | 55 | instance['id'], instance['flavor']['id'], resize_flavor) | 
|  | 56 | self.servers_client.resize(instance_id, resize_flavor) | 
|  | 57 | self.servers_client.wait_for_server_status(instance_id, | 
|  | 58 | 'VERIFY_RESIZE') | 
| Jay Pipes | 051075a | 2012-04-28 17:39:37 -0400 | [diff] [blame] | 59 |  | 
|  | 60 | LOG.debug("Confirming resize of instance %s", instance_id) | 
| Ghanshyam | aadf036 | 2014-08-27 16:51:26 +0900 | [diff] [blame] | 61 | self.servers_client.confirm_resize(instance_id) | 
| Tatyana Leontovich | 58ab531 | 2013-04-22 16:48:33 +0300 | [diff] [blame] | 62 |  | 
| Ghanshyam | aadf036 | 2014-08-27 16:51:26 +0900 | [diff] [blame] | 63 | self.servers_client.wait_for_server_status(instance_id, | 
|  | 64 | 'ACTIVE') | 
| Tatyana Leontovich | 58ab531 | 2013-04-22 16:48:33 +0300 | [diff] [blame] | 65 |  | 
| armando-migliaccio | 9e5eac0 | 2014-03-24 10:55:31 -0700 | [diff] [blame] | 66 | @testtools.skipUnless(CONF.compute_feature_enabled.suspend, | 
|  | 67 | 'Suspend is not available.') | 
| Masayuki Igawa | 4ded9f0 | 2014-02-17 15:05:59 +0900 | [diff] [blame] | 68 | @test.services('compute') | 
| Tatyana Leontovich | 58ab531 | 2013-04-22 16:48:33 +0300 | [diff] [blame] | 69 | def test_server_sequence_suspend_resume(self): | 
|  | 70 | # We create an instance for use in this test | 
| Giulio Fidente | 61cadca | 2013-09-24 18:33:37 +0200 | [diff] [blame] | 71 | instance = self.create_server() | 
| Ghanshyam | aadf036 | 2014-08-27 16:51:26 +0900 | [diff] [blame] | 72 | instance_id = instance['id'] | 
| Tatyana Leontovich | 58ab531 | 2013-04-22 16:48:33 +0300 | [diff] [blame] | 73 | LOG.debug("Suspending instance %s. Current status: %s", | 
| Ghanshyam | aadf036 | 2014-08-27 16:51:26 +0900 | [diff] [blame] | 74 | instance_id, instance['status']) | 
|  | 75 | self.servers_client.suspend_server(instance_id) | 
|  | 76 | self.servers_client.wait_for_server_status(instance_id, | 
|  | 77 | 'SUSPENDED') | 
|  | 78 | _, fetched_instance = self.servers_client.get_server(instance_id) | 
| Tatyana Leontovich | 58ab531 | 2013-04-22 16:48:33 +0300 | [diff] [blame] | 79 | LOG.debug("Resuming instance %s. Current status: %s", | 
| Ghanshyam | aadf036 | 2014-08-27 16:51:26 +0900 | [diff] [blame] | 80 | instance_id, fetched_instance['status']) | 
|  | 81 | self.servers_client.resume_server(instance_id) | 
|  | 82 | self.servers_client.wait_for_server_status(instance_id, | 
|  | 83 | 'ACTIVE') | 
|  | 84 | _, fetched_instance = self.servers_client.get_server(instance_id) | 
| Tatyana Leontovich | 58ab531 | 2013-04-22 16:48:33 +0300 | [diff] [blame] | 85 | LOG.debug("Suspending instance %s. Current status: %s", | 
| Ghanshyam | aadf036 | 2014-08-27 16:51:26 +0900 | [diff] [blame] | 86 | instance_id, fetched_instance['status']) | 
|  | 87 | self.servers_client.suspend_server(instance_id) | 
|  | 88 | self.servers_client.wait_for_server_status(instance_id, | 
|  | 89 | 'SUSPENDED') | 
|  | 90 | _, fetched_instance = self.servers_client.get_server(instance_id) | 
| Tatyana Leontovich | 58ab531 | 2013-04-22 16:48:33 +0300 | [diff] [blame] | 91 | LOG.debug("Resuming instance %s. Current status: %s", | 
| Ghanshyam | aadf036 | 2014-08-27 16:51:26 +0900 | [diff] [blame] | 92 | instance_id, fetched_instance['status']) | 
|  | 93 | self.servers_client.resume_server(instance_id) | 
|  | 94 | self.servers_client.wait_for_server_status(instance_id, | 
|  | 95 | 'ACTIVE') |