Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 1 | # Copyright 2013 NEC Corporation |
| 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 | |
Masayuki Igawa | 259c113 | 2013-10-31 17:48:44 +0900 | [diff] [blame] | 16 | from tempest.common.utils import data_utils |
Matthew Treinish | 6c07229 | 2014-01-29 19:15:52 +0000 | [diff] [blame] | 17 | from tempest import config |
Matthew Treinish | f4a9b0f | 2013-07-26 16:58:26 -0400 | [diff] [blame] | 18 | from tempest.openstack.common import log as logging |
Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 19 | from tempest.scenario import manager |
Masayuki Igawa | 4ded9f0 | 2014-02-17 15:05:59 +0900 | [diff] [blame] | 20 | from tempest import test |
Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 21 | |
Matthew Treinish | 6c07229 | 2014-01-29 19:15:52 +0000 | [diff] [blame] | 22 | CONF = config.CONF |
| 23 | |
Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 24 | |
| 25 | LOG = logging.getLogger(__name__) |
| 26 | |
| 27 | |
Ghanshyam | aa4511e | 2014-09-08 10:37:50 +0900 | [diff] [blame] | 28 | class TestLargeOpsScenario(manager.ScenarioTest): |
Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 29 | |
| 30 | """ |
| 31 | Test large operations. |
| 32 | |
| 33 | This test below: |
Joe Gordon | fa29a62 | 2014-04-17 13:21:44 -0700 | [diff] [blame] | 34 | * Spin up multiple instances in one nova call, and repeat three times |
Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 35 | * as a regular user |
| 36 | * TODO: same thing for cinder |
| 37 | |
| 38 | """ |
| 39 | |
Sylvain Afchain | 9206477 | 2014-01-16 02:45:57 +0100 | [diff] [blame] | 40 | @classmethod |
| 41 | def setUpClass(cls): |
Yair Fried | c1f1e83 | 2014-09-21 12:57:32 +0300 | [diff] [blame^] | 42 | if CONF.scenario.large_ops_number < 1: |
| 43 | raise cls.skipException("large_ops_number not set to multiple " |
| 44 | "instances") |
Sylvain Afchain | 9206477 | 2014-01-16 02:45:57 +0100 | [diff] [blame] | 45 | cls.set_network_resources() |
| 46 | super(TestLargeOpsScenario, cls).setUpClass() |
| 47 | |
Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 48 | def _wait_for_server_status(self, status): |
| 49 | for server in self.servers: |
Ghanshyam | aa4511e | 2014-09-08 10:37:50 +0900 | [diff] [blame] | 50 | self.servers_client.wait_for_server_status(server['id'], status) |
Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 51 | |
Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 52 | def nova_boot(self): |
Masayuki Igawa | 259c113 | 2013-10-31 17:48:44 +0900 | [diff] [blame] | 53 | name = data_utils.rand_name('scenario-server-') |
Matthew Treinish | 6c07229 | 2014-01-29 19:15:52 +0000 | [diff] [blame] | 54 | flavor_id = CONF.compute.flavor_ref |
Ghanshyam | aa4511e | 2014-09-08 10:37:50 +0900 | [diff] [blame] | 55 | secgroup = self._create_security_group() |
| 56 | self.servers_client.create_server( |
| 57 | name, |
| 58 | self.image, |
| 59 | flavor_id, |
Matthew Treinish | 6c07229 | 2014-01-29 19:15:52 +0000 | [diff] [blame] | 60 | min_count=CONF.scenario.large_ops_number, |
Ghanshyam | aa4511e | 2014-09-08 10:37:50 +0900 | [diff] [blame] | 61 | security_groups=[secgroup]) |
Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 62 | # needed because of bug 1199788 |
Ghanshyam | aa4511e | 2014-09-08 10:37:50 +0900 | [diff] [blame] | 63 | params = {'name': name} |
| 64 | _, server_list = self.servers_client.list_servers(params) |
| 65 | self.servers = server_list['servers'] |
Joe Gordon | a321965 | 2013-10-09 15:23:11 -0700 | [diff] [blame] | 66 | for server in self.servers: |
Matthew Treinish | b7144eb | 2013-12-13 22:57:35 +0000 | [diff] [blame] | 67 | # after deleting all servers - wait for all servers to clear |
| 68 | # before cleanup continues |
Ghanshyam | aa4511e | 2014-09-08 10:37:50 +0900 | [diff] [blame] | 69 | self.addCleanup(self.servers_client.wait_for_server_termination, |
| 70 | server['id']) |
Matthew Treinish | b7144eb | 2013-12-13 22:57:35 +0000 | [diff] [blame] | 71 | for server in self.servers: |
Ghanshyam | aa4511e | 2014-09-08 10:37:50 +0900 | [diff] [blame] | 72 | self.addCleanup_with_wait( |
| 73 | waiter_callable=(self.servers_client. |
| 74 | wait_for_server_termination), |
| 75 | thing_id=server['id'], thing_id_param='server_id', |
| 76 | cleanup_callable=self.delete_wrapper, |
| 77 | cleanup_args=[self.servers_client.delete_server, server['id']]) |
Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 78 | self._wait_for_server_status('ACTIVE') |
| 79 | |
Joe Gordon | b7f37cc | 2014-05-09 13:30:40 -0700 | [diff] [blame] | 80 | def _large_ops_scenario(self): |
Joe Gordon | b5e10cd | 2013-07-10 15:51:12 +0000 | [diff] [blame] | 81 | self.glance_image_create() |
| 82 | self.nova_boot() |
Joe Gordon | b7f37cc | 2014-05-09 13:30:40 -0700 | [diff] [blame] | 83 | |
| 84 | @test.services('compute', 'image') |
| 85 | def test_large_ops_scenario_1(self): |
| 86 | self._large_ops_scenario() |
| 87 | |
| 88 | @test.services('compute', 'image') |
| 89 | def test_large_ops_scenario_2(self): |
| 90 | self._large_ops_scenario() |
| 91 | |
| 92 | @test.services('compute', 'image') |
| 93 | def test_large_ops_scenario_3(self): |
| 94 | self._large_ops_scenario() |