| # Copyright 2013 NEC Corporation |
| # All Rights Reserved. |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| # not use this file except in compliance with the License. You may obtain |
| # a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| # License for the specific language governing permissions and limitations |
| # under the License. |
| |
| from oslo_log import log as logging |
| |
| from tempest.common import custom_matchers |
| from tempest.common import waiters |
| from tempest import config |
| from tempest import exceptions |
| from tempest.scenario import manager |
| from tempest import test |
| |
| CONF = config.CONF |
| |
| LOG = logging.getLogger(__name__) |
| |
| |
| class TestMinimumBasicScenario(manager.ScenarioTest): |
| |
| """This is a basic minimum scenario test. |
| |
| This test below: |
| * across the multiple components |
| * as a regular user |
| * with and without optional parameters |
| * check command outputs |
| |
| Steps: |
| 1. Create image |
| 2. Create keypair |
| 3. Boot instance with keypair and get list of instances |
| 4. Create volume and show list of volumes |
| 5. Attach volume to instance and getlist of volumes |
| 6. Add IP to instance |
| 7. Create and add security group to instance |
| 8. Check SSH connection to instance |
| 9. Reboot instance |
| 10. Check SSH connection to instance after reboot |
| |
| """ |
| |
| def _wait_for_server_status(self, server, status): |
| server_id = server['id'] |
| # Raise on error defaults to True, which is consistent with the |
| # original function from scenario tests here |
| waiters.wait_for_server_status(self.servers_client, |
| server_id, status) |
| |
| def nova_list(self): |
| servers = self.servers_client.list_servers() |
| # The list servers in the compute client is inconsistent... |
| return servers['servers'] |
| |
| def nova_show(self, server): |
| got_server = (self.servers_client.show_server(server['id']) |
| ['server']) |
| excluded_keys = ['OS-EXT-AZ:availability_zone'] |
| # Exclude these keys because of LP:#1486475 |
| excluded_keys.extend(['OS-EXT-STS:power_state', 'updated']) |
| self.assertThat( |
| server, custom_matchers.MatchesDictExceptForKeys( |
| got_server, excluded_keys=excluded_keys)) |
| |
| def cinder_create(self): |
| return self.create_volume() |
| |
| def cinder_list(self): |
| return self.volumes_client.list_volumes()['volumes'] |
| |
| def cinder_show(self, volume): |
| got_volume = self.volumes_client.show_volume(volume['id'])['volume'] |
| self.assertEqual(volume, got_volume) |
| |
| def nova_reboot(self, server): |
| self.servers_client.reboot_server(server['id'], type='SOFT') |
| self._wait_for_server_status(server, 'ACTIVE') |
| |
| def check_partitions(self): |
| # NOTE(andreaf) The device name may be different on different guest OS |
| partitions = self.linux_client.get_partitions() |
| self.assertEqual(1, partitions.count(CONF.compute.volume_device_name)) |
| |
| def create_and_add_security_group_to_server(self, server): |
| secgroup = self._create_security_group() |
| self.servers_client.add_security_group(server['id'], |
| name=secgroup['name']) |
| self.addCleanup(self.servers_client.remove_security_group, |
| server['id'], name=secgroup['name']) |
| |
| def wait_for_secgroup_add(): |
| body = (self.servers_client.show_server(server['id']) |
| ['server']) |
| return {'name': secgroup['name']} in body['security_groups'] |
| |
| if not test.call_until_true(wait_for_secgroup_add, |
| CONF.compute.build_timeout, |
| CONF.compute.build_interval): |
| msg = ('Timed out waiting for adding security group %s to server ' |
| '%s' % (secgroup['id'], server['id'])) |
| raise exceptions.TimeoutException(msg) |
| |
| @test.idempotent_id('bdbb5441-9204-419d-a225-b4fdbfb1a1a8') |
| @test.services('compute', 'volume', 'image', 'network') |
| def test_minimum_basic_scenario(self): |
| image = self.glance_image_create() |
| keypair = self.create_keypair() |
| |
| server = self.create_server(image_id=image, |
| key_name=keypair['name'], |
| wait_until='ACTIVE') |
| servers = self.nova_list() |
| self.assertIn(server['id'], [x['id'] for x in servers]) |
| |
| self.nova_show(server) |
| |
| volume = self.cinder_create() |
| volumes = self.cinder_list() |
| self.assertIn(volume['id'], [x['id'] for x in volumes]) |
| |
| self.cinder_show(volume) |
| |
| volume = self.nova_volume_attach(server, volume) |
| self.addCleanup(self.nova_volume_detach, server, volume) |
| self.cinder_show(volume) |
| |
| floating_ip = self.create_floating_ip(server) |
| self.create_and_add_security_group_to_server(server) |
| |
| # check that we can SSH to the server before reboot |
| self.linux_client = self.get_remote_client( |
| floating_ip['ip'], private_key=keypair['private_key']) |
| |
| self.nova_reboot(server) |
| |
| # check that we can SSH to the server after reboot |
| # (both connections are part of the scenario) |
| self.linux_client = self.get_remote_client( |
| floating_ip['ip'], private_key=keypair['private_key']) |
| |
| self.check_partitions() |