blob: 37aa5ac12953e5da20404e9b043329b1f4378e5e [file] [log] [blame]
ZhiQiang Fan39f97222013-09-20 04:49:44 +08001# Copyright 2012 OpenStack Foundation
Jay Pipes13b479b2012-06-11 14:52:27 -04002# 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
David Kranzcf0040c2012-06-26 09:46:56 -040016import time
Jay Pipesf38eaac2012-06-21 13:37:35 -040017
Doug Hellmann583ce2c2015-03-11 14:55:46 +000018from oslo_log import log as logging
Matthew Treinish01472ff2015-02-20 17:26:52 -050019
Ghanshyam05049dd2016-02-12 17:44:48 +090020from tempest.api.compute import api_microversion_fixture
Joseph Lanouxb3e1f872015-01-30 11:13:07 +000021from tempest.common import compute
Fei Long Wangd39431f2015-05-14 11:30:48 +120022from tempest.common.utils import data_utils
Ken'ichi Ohmichi8b9c7802015-07-08 05:57:37 +000023from tempest.common import waiters
Matthew Treinishb0a78fc2014-01-29 16:49:12 +000024from tempest import config
Sean Dague20e98612016-01-06 14:33:28 -050025from tempest import exceptions
Ghanshyam1f47cf92016-02-25 04:57:18 +090026from tempest.lib.common import api_version_utils
Jordan Pittier9e227c52016-02-09 14:35:18 +010027from tempest.lib.common.utils import test_utils
Andrea Frittoli (andreaf)db9672e2016-02-23 14:07:24 -050028from tempest.lib import exceptions as lib_exc
Attila Fazekasdc216422013-01-29 15:12:14 +010029import tempest.test
Jay Pipesf38eaac2012-06-21 13:37:35 -040030
Matthew Treinishb0a78fc2014-01-29 16:49:12 +000031CONF = config.CONF
Tiago Melloeda03b52012-08-22 23:47:29 -030032
Jay Pipesf38eaac2012-06-21 13:37:35 -040033LOG = logging.getLogger(__name__)
Daryl Walleckc7251962012-03-12 17:26:54 -050034
35
Ken'ichi Ohmichi4d237e72015-11-05 06:32:33 +000036class BaseV2ComputeTest(api_version_utils.BaseMicroversionTest,
37 tempest.test.BaseTestCase):
Sean Daguef237ccb2013-01-04 15:19:14 -050038 """Base test case class for all Compute API tests."""
Daryl Walleckc7251962012-03-12 17:26:54 -050039
Attila Fazekas430dae32013-10-17 15:19:32 +020040 force_tenant_isolation = False
Chris Yeoh8a79b9d2013-01-18 19:32:47 +103041
Andrea Frittolib21de6c2015-02-06 20:12:38 +000042 # TODO(andreaf) We should care also for the alt_manager here
43 # but only once client lazy load in the manager is done
44 credentials = ['primary']
45
Jay Pipesf38eaac2012-06-21 13:37:35 -040046 @classmethod
Emily Hugenbruche7991d92014-12-12 16:53:36 +000047 def skip_checks(cls):
Ken'ichi Ohmichi02a8ccd2015-11-05 06:05:29 +000048 super(BaseV2ComputeTest, cls).skip_checks()
Matthew Treinishf8ff3582015-08-25 12:41:56 -040049 if not CONF.service_available.nova:
50 raise cls.skipException("Nova is not available")
ghanshyam29591532016-03-11 17:12:43 +090051 cfg_min_version = CONF.compute.min_microversion
52 cfg_max_version = CONF.compute.max_microversion
Ken'ichi Ohmichi4d237e72015-11-05 06:32:33 +000053 api_version_utils.check_skip_with_microversion(cls.min_microversion,
54 cls.max_microversion,
55 cfg_min_version,
56 cfg_max_version)
Jay Pipesf38eaac2012-06-21 13:37:35 -040057
Emily Hugenbruche7991d92014-12-12 16:53:36 +000058 @classmethod
59 def setup_credentials(cls):
60 cls.set_network_resources()
Ken'ichi Ohmichi02a8ccd2015-11-05 06:05:29 +000061 super(BaseV2ComputeTest, cls).setup_credentials()
Daryl Walleckc7251962012-03-12 17:26:54 -050062
Emily Hugenbruche7991d92014-12-12 16:53:36 +000063 @classmethod
64 def setup_clients(cls):
Ken'ichi Ohmichi02a8ccd2015-11-05 06:05:29 +000065 super(BaseV2ComputeTest, cls).setup_clients()
Emily Hugenbruche7991d92014-12-12 16:53:36 +000066 cls.servers_client = cls.os.servers_client
Ken'ichi Ohmichi7ca54b82015-07-07 01:10:26 +000067 cls.server_groups_client = cls.os.server_groups_client
Emily Hugenbruche7991d92014-12-12 16:53:36 +000068 cls.flavors_client = cls.os.flavors_client
Ghanshyamae76c122015-12-22 13:41:35 +090069 cls.compute_images_client = cls.os.compute_images_client
Emily Hugenbruche7991d92014-12-12 16:53:36 +000070 cls.extensions_client = cls.os.extensions_client
Ken'ichi Ohmichi03af1c52015-07-13 00:28:05 +000071 cls.floating_ip_pools_client = cls.os.floating_ip_pools_client
John Warrene74890a2015-11-11 15:18:01 -050072 cls.floating_ips_client = cls.os.compute_floating_ips_client
Emily Hugenbruche7991d92014-12-12 16:53:36 +000073 cls.keypairs_client = cls.os.keypairs_client
John Warren5cdbf422016-01-05 12:42:43 -050074 cls.security_group_rules_client = (
75 cls.os.compute_security_group_rules_client)
John Warrenf2345512015-12-10 13:39:30 -050076 cls.security_groups_client = cls.os.compute_security_groups_client
Emily Hugenbruche7991d92014-12-12 16:53:36 +000077 cls.quotas_client = cls.os.quotas_client
Emily Hugenbruche7991d92014-12-12 16:53:36 +000078 cls.quota_classes_client = cls.os.quota_classes_client
John Warren9487a182015-09-14 18:12:56 -040079 cls.compute_networks_client = cls.os.compute_networks_client
Emily Hugenbruche7991d92014-12-12 16:53:36 +000080 cls.limits_client = cls.os.limits_client
81 cls.volumes_extensions_client = cls.os.volumes_extensions_client
Gaozexub9c9d6e2015-09-10 17:08:04 +080082 cls.snapshots_extensions_client = cls.os.snapshots_extensions_client
Emily Hugenbruche7991d92014-12-12 16:53:36 +000083 cls.interfaces_client = cls.os.interfaces_client
84 cls.fixed_ips_client = cls.os.fixed_ips_client
85 cls.availability_zone_client = cls.os.availability_zone_client
86 cls.agents_client = cls.os.agents_client
87 cls.aggregates_client = cls.os.aggregates_client
88 cls.services_client = cls.os.services_client
89 cls.instance_usages_audit_log_client = (
90 cls.os.instance_usages_audit_log_client)
91 cls.hypervisor_client = cls.os.hypervisor_client
92 cls.certificates_client = cls.os.certificates_client
93 cls.migrations_client = cls.os.migrations_client
94 cls.security_group_default_rules_client = (
95 cls.os.security_group_default_rules_client)
Ken'ichi Ohmichi2b6012b2015-09-03 01:56:19 +000096 cls.versions_client = cls.os.compute_versions_client
Emily Hugenbruche7991d92014-12-12 16:53:36 +000097
Ivan Kolodyazhnybcfc32e2015-08-06 13:31:36 +030098 if CONF.volume_feature_enabled.api_v1:
99 cls.volumes_client = cls.os.volumes_client
100 else:
101 cls.volumes_client = cls.os.volumes_v2_client
102
Emily Hugenbruche7991d92014-12-12 16:53:36 +0000103 @classmethod
104 def resource_setup(cls):
Ken'ichi Ohmichi02a8ccd2015-11-05 06:05:29 +0000105 super(BaseV2ComputeTest, cls).resource_setup()
Ghanshyam05049dd2016-02-12 17:44:48 +0900106 cls.request_microversion = (
107 api_version_utils.select_request_microversion(
108 cls.min_microversion,
ghanshyam29591532016-03-11 17:12:43 +0900109 CONF.compute.min_microversion))
Matthew Treinishb0a78fc2014-01-29 16:49:12 +0000110 cls.build_interval = CONF.compute.build_interval
111 cls.build_timeout = CONF.compute.build_timeout
Matthew Treinishb0a78fc2014-01-29 16:49:12 +0000112 cls.image_ref = CONF.compute.image_ref
113 cls.image_ref_alt = CONF.compute.image_ref_alt
114 cls.flavor_ref = CONF.compute.flavor_ref
115 cls.flavor_ref_alt = CONF.compute.flavor_ref_alt
lanoux283273b2015-12-04 03:01:54 -0800116 cls.ssh_user = CONF.validation.image_ssh_user
117 cls.image_ssh_user = CONF.validation.image_ssh_user
118 cls.image_ssh_password = CONF.validation.image_ssh_password
Jay Pipesf38eaac2012-06-21 13:37:35 -0400119 cls.servers = []
Sean Dagued62bf1c2013-06-05 14:36:25 -0400120 cls.images = []
Zhi Kun Liu02e7a7b2014-01-08 16:08:32 +0800121 cls.security_groups = []
Abhijeet.Jain87dd4452014-04-23 15:51:23 +0530122 cls.server_groups = []
Matthew Treinishf7fca6a2013-12-09 16:27:23 +0000123
Emily Hugenbruche7991d92014-12-12 16:53:36 +0000124 @classmethod
125 def resource_cleanup(cls):
126 cls.clear_images()
127 cls.clear_servers()
128 cls.clear_security_groups()
129 cls.clear_server_groups()
Ken'ichi Ohmichi02a8ccd2015-11-05 06:05:29 +0000130 super(BaseV2ComputeTest, cls).resource_cleanup()
Ken'ichi Ohmichi543a5d42014-05-02 08:44:15 +0900131
Matthew Treinishf7fca6a2013-12-09 16:27:23 +0000132 @classmethod
Jay Pipes444c3e62012-10-04 19:26:35 -0400133 def clear_servers(cls):
Salvatore1422a9a2014-10-08 15:53:25 +0200134 LOG.debug('Clearing servers: %s', ','.join(
135 server['id'] for server in cls.servers))
Jay Pipes444c3e62012-10-04 19:26:35 -0400136 for server in cls.servers:
Dan Smith74e7bcb2012-08-21 09:18:26 -0700137 try:
Jordan Pittier9e227c52016-02-09 14:35:18 +0100138 test_utils.call_and_ignore_notfound_exc(
139 cls.servers_client.delete_server, server['id'])
Joe Gordon0c335792014-09-23 12:36:11 -0700140 except Exception:
141 LOG.exception('Deleting server %s failed' % server['id'])
Dan Smith74e7bcb2012-08-21 09:18:26 -0700142
Jay Pipes444c3e62012-10-04 19:26:35 -0400143 for server in cls.servers:
Dan Smith74e7bcb2012-08-21 09:18:26 -0700144 try:
Ken'ichi Ohmichie91a0c62015-08-13 02:09:16 +0000145 waiters.wait_for_server_termination(cls.servers_client,
146 server['id'])
Dan Smith74e7bcb2012-08-21 09:18:26 -0700147 except Exception:
Joe Gordon0c335792014-09-23 12:36:11 -0700148 LOG.exception('Waiting for deletion of server %s failed'
149 % server['id'])
Dan Smith74e7bcb2012-08-21 09:18:26 -0700150
151 @classmethod
Attila Fazekas305e65b2013-10-29 13:23:07 +0100152 def server_check_teardown(cls):
153 """Checks is the shared server clean enough for subsequent test.
Ken'ichi Ohmichi88363cb2015-11-19 08:00:54 +0000154
Attila Fazekas305e65b2013-10-29 13:23:07 +0100155 Method will delete the server when it's dirty.
156 The setUp method is responsible for creating a new server.
157 Exceptions raised in tearDown class are fails the test case,
Marian Horban6afb0232015-11-10 22:47:12 -0500158 This method supposed to use only by tearDown methods, when
Attila Fazekas305e65b2013-10-29 13:23:07 +0100159 the shared server_id is stored in the server_id of the class.
160 """
161 if getattr(cls, 'server_id', None) is not None:
162 try:
Ken'ichi Ohmichi0eb153c2015-07-13 02:18:25 +0000163 waiters.wait_for_server_status(cls.servers_client,
164 cls.server_id, 'ACTIVE')
Attila Fazekas305e65b2013-10-29 13:23:07 +0100165 except Exception as exc:
166 LOG.exception(exc)
167 cls.servers_client.delete_server(cls.server_id)
Ken'ichi Ohmichie91a0c62015-08-13 02:09:16 +0000168 waiters.wait_for_server_termination(cls.servers_client,
169 cls.server_id)
Attila Fazekas305e65b2013-10-29 13:23:07 +0100170 cls.server_id = None
171 raise
172
173 @classmethod
Sean Dagued62bf1c2013-06-05 14:36:25 -0400174 def clear_images(cls):
Salvatore1422a9a2014-10-08 15:53:25 +0200175 LOG.debug('Clearing images: %s', ','.join(cls.images))
Sean Dagued62bf1c2013-06-05 14:36:25 -0400176 for image_id in cls.images:
177 try:
Jordan Pittier9e227c52016-02-09 14:35:18 +0100178 test_utils.call_and_ignore_notfound_exc(
179 cls.compute_images_client.delete_image, image_id)
Yair Frieda039f872014-01-02 12:11:10 +0200180 except Exception:
181 LOG.exception('Exception raised deleting image %s' % image_id)
Sean Dagued62bf1c2013-06-05 14:36:25 -0400182
183 @classmethod
Zhi Kun Liu02e7a7b2014-01-08 16:08:32 +0800184 def clear_security_groups(cls):
Salvatore1422a9a2014-10-08 15:53:25 +0200185 LOG.debug('Clearing security groups: %s', ','.join(
186 str(sg['id']) for sg in cls.security_groups))
Zhi Kun Liu02e7a7b2014-01-08 16:08:32 +0800187 for sg in cls.security_groups:
188 try:
Jordan Pittier9e227c52016-02-09 14:35:18 +0100189 test_utils.call_and_ignore_notfound_exc(
190 cls.security_groups_client.delete_security_group, sg['id'])
Zhi Kun Liu02e7a7b2014-01-08 16:08:32 +0800191 except Exception as exc:
192 LOG.info('Exception raised deleting security group %s',
193 sg['id'])
194 LOG.exception(exc)
Zhi Kun Liu02e7a7b2014-01-08 16:08:32 +0800195
196 @classmethod
Abhijeet.Jain87dd4452014-04-23 15:51:23 +0530197 def clear_server_groups(cls):
Salvatore1422a9a2014-10-08 15:53:25 +0200198 LOG.debug('Clearing server groups: %s', ','.join(cls.server_groups))
Abhijeet.Jain87dd4452014-04-23 15:51:23 +0530199 for server_group_id in cls.server_groups:
200 try:
Jordan Pittier9e227c52016-02-09 14:35:18 +0100201 test_utils.call_and_ignore_notfound_exc(
202 cls.server_groups_client.delete_server_group,
203 server_group_id
204 )
Abhijeet.Jain87dd4452014-04-23 15:51:23 +0530205 except Exception:
206 LOG.exception('Exception raised deleting server-group %s',
207 server_group_id)
208
209 @classmethod
Joe Gordon8843f0f2015-03-17 15:07:34 -0700210 def create_test_server(cls, validatable=False, volume_backed=False,
211 **kwargs):
Joseph Lanouxb3e1f872015-01-30 11:13:07 +0000212 """Wrapper utility that returns a test server.
Rohit Karajgidc300b22012-05-04 08:11:00 -0700213
Joseph Lanouxb3e1f872015-01-30 11:13:07 +0000214 This wrapper utility calls the common create test server and
215 returns a test server. The purpose of this wrapper is to minimize
216 the impact on the code of the tests already using this
217 function.
Joe Gordon8843f0f2015-03-17 15:07:34 -0700218
219 :param validatable: Whether the server will be pingable or sshable.
220 :param volume_backed: Whether the instance is volume backed or not.
Joseph Lanouxb3e1f872015-01-30 11:13:07 +0000221 """
222 tenant_network = cls.get_tenant_network()
223 body, servers = compute.create_test_server(
224 cls.os,
225 validatable,
226 validation_resources=cls.validation_resources,
227 tenant_network=tenant_network,
Joe Gordon8843f0f2015-03-17 15:07:34 -0700228 volume_backed=volume_backed,
Joseph Lanouxb3e1f872015-01-30 11:13:07 +0000229 **kwargs)
Ken'ichi Ohmichi51c8c262013-12-21 03:30:37 +0900230
231 cls.servers.extend(servers)
Sean Dague9b669e32012-12-13 18:40:08 -0500232
David Kranz0fb14292015-02-11 15:55:20 -0500233 return body
Sean Dague9b669e32012-12-13 18:40:08 -0500234
Zhi Kun Liu02e7a7b2014-01-08 16:08:32 +0800235 @classmethod
236 def create_security_group(cls, name=None, description=None):
237 if name is None:
238 name = data_utils.rand_name(cls.__name__ + "-securitygroup")
239 if description is None:
Ken'ichi Ohmichi4937f562015-03-23 00:15:01 +0000240 description = data_utils.rand_name('description')
ghanshyamb610b772015-08-24 17:29:38 +0900241 body = cls.security_groups_client.create_security_group(
242 name=name, description=description)['security_group']
Zhi Kun Liu02e7a7b2014-01-08 16:08:32 +0800243 cls.security_groups.append(body)
244
David Kranz9964b4e2015-02-06 15:45:29 -0500245 return body
Zhi Kun Liu02e7a7b2014-01-08 16:08:32 +0800246
Abhijeet.Jain87dd4452014-04-23 15:51:23 +0530247 @classmethod
Ghanshyam2a180b82014-06-16 13:54:22 +0900248 def create_test_server_group(cls, name="", policy=None):
Abhijeet.Jain87dd4452014-04-23 15:51:23 +0530249 if not name:
250 name = data_utils.rand_name(cls.__name__ + "-Server-Group")
Ghanshyam2a180b82014-06-16 13:54:22 +0900251 if policy is None:
Abhijeet.Jain87dd4452014-04-23 15:51:23 +0530252 policy = ['affinity']
Ken'ichi Ohmichi1f36daa2015-09-30 01:41:34 +0000253 body = cls.server_groups_client.create_server_group(
254 name=name, policies=policy)['server_group']
David Kranzda5d4ec2014-06-24 16:04:57 -0400255 cls.server_groups.append(body['id'])
David Kranzae99b9a2015-02-16 13:37:01 -0500256 return body
Abhijeet.Jain87dd4452014-04-23 15:51:23 +0530257
David Kranzcf0040c2012-06-26 09:46:56 -0400258 def wait_for(self, condition):
Sean Daguef237ccb2013-01-04 15:19:14 -0500259 """Repeatedly calls condition() until a timeout."""
David Kranzcf0040c2012-06-26 09:46:56 -0400260 start_time = int(time.time())
261 while True:
262 try:
263 condition()
Matthew Treinish05d9fb92012-12-07 16:14:05 -0500264 except Exception:
David Kranzcf0040c2012-06-26 09:46:56 -0400265 pass
266 else:
267 return
268 if int(time.time()) - start_time >= self.build_timeout:
269 condition()
270 return
271 time.sleep(self.build_interval)
Jay Pipesf38eaac2012-06-21 13:37:35 -0400272
Matt Riedemann807d0562014-01-27 12:03:10 -0800273 @staticmethod
274 def _delete_volume(volumes_client, volume_id):
275 """Deletes the given volume and waits for it to be gone."""
276 try:
Joseph Lanoux6809bab2014-12-18 14:57:18 +0000277 volumes_client.delete_volume(volume_id)
Matt Riedemann807d0562014-01-27 12:03:10 -0800278 # TODO(mriedem): We should move the wait_for_resource_deletion
279 # into the delete_volume method as a convenience to the caller.
280 volumes_client.wait_for_resource_deletion(volume_id)
Masayuki Igawabfa07602015-01-20 18:47:17 +0900281 except lib_exc.NotFound:
zhangguoqing6c096642016-01-04 06:17:21 +0000282 LOG.warning("Unable to delete volume '%s' since it was not found. "
283 "Maybe it was already deleted?" % volume_id)
Matt Riedemann807d0562014-01-27 12:03:10 -0800284
Attila Fazekas423834d2014-03-14 17:33:13 +0100285 @classmethod
286 def prepare_instance_network(cls):
Joseph Lanouxffe09dd2015-03-18 16:45:33 +0000287 if (CONF.validation.auth_method != 'disabled' and
288 CONF.validation.connect_method == 'floating'):
Attila Fazekas423834d2014-03-14 17:33:13 +0100289 cls.set_network_resources(network=True, subnet=True, router=True,
290 dhcp=True)
291
ivan-zhu8f992be2013-07-31 14:56:58 +0800292 @classmethod
293 def create_image_from_server(cls, server_id, **kwargs):
294 """Wrapper utility that returns an image created from the server."""
Masayuki Igawa259c1132013-10-31 17:48:44 +0900295 name = data_utils.rand_name(cls.__name__ + "-image")
ivan-zhu8f992be2013-07-31 14:56:58 +0800296 if 'name' in kwargs:
297 name = kwargs.pop('name')
298
Ghanshyamae76c122015-12-22 13:41:35 +0900299 image = cls.compute_images_client.create_image(server_id, name=name)
David Kranza5299eb2015-01-15 17:24:05 -0500300 image_id = data_utils.parse_image_id(image.response['location'])
ivan-zhu8f992be2013-07-31 14:56:58 +0800301 cls.images.append(image_id)
302
303 if 'wait_until' in kwargs:
Ghanshyamae76c122015-12-22 13:41:35 +0900304 waiters.wait_for_image_status(cls.compute_images_client,
Ken'ichi Ohmichi8b9c7802015-07-08 05:57:37 +0000305 image_id, kwargs['wait_until'])
Ghanshyamae76c122015-12-22 13:41:35 +0900306 image = cls.compute_images_client.show_image(image_id)['image']
ivan-zhu8f992be2013-07-31 14:56:58 +0800307
Bob Ball621e4602013-12-06 19:53:43 +0000308 if kwargs['wait_until'] == 'ACTIVE':
309 if kwargs.get('wait_for_server', True):
Ken'ichi Ohmichi0eb153c2015-07-13 02:18:25 +0000310 waiters.wait_for_server_status(cls.servers_client,
311 server_id, 'ACTIVE')
David Kranza5299eb2015-01-15 17:24:05 -0500312 return image
ivan-zhu8f992be2013-07-31 14:56:58 +0800313
314 @classmethod
Joseph Lanouxffe09dd2015-03-18 16:45:33 +0000315 def rebuild_server(cls, server_id, validatable=False, **kwargs):
ivan-zhu8f992be2013-07-31 14:56:58 +0800316 # Destroy an existing server and creates a new one
Matthew Treinish2cd19a42013-12-02 21:54:42 +0000317 if server_id:
318 try:
319 cls.servers_client.delete_server(server_id)
Ken'ichi Ohmichie91a0c62015-08-13 02:09:16 +0000320 waiters.wait_for_server_termination(cls.servers_client,
321 server_id)
Yair Frieda039f872014-01-02 12:11:10 +0200322 except Exception:
323 LOG.exception('Failed to delete server %s' % server_id)
Joseph Lanouxffe09dd2015-03-18 16:45:33 +0000324
Ghanshyam3390d9f2015-12-25 12:48:02 +0900325 cls.password = data_utils.rand_password()
Joseph Lanouxffe09dd2015-03-18 16:45:33 +0000326 server = cls.create_test_server(
327 validatable,
328 wait_until='ACTIVE',
Ghanshyam3390d9f2015-12-25 12:48:02 +0900329 adminPass=cls.password,
Joseph Lanouxffe09dd2015-03-18 16:45:33 +0000330 **kwargs)
Matthew Treinish2cd19a42013-12-02 21:54:42 +0000331 return server['id']
ivan-zhu8f992be2013-07-31 14:56:58 +0800332
Matt Riedemann5dc594c2014-01-27 11:40:28 -0800333 @classmethod
Jesse Keating613b4982015-05-04 15:05:19 -0700334 def delete_server(cls, server_id):
335 """Deletes an existing server and waits for it to be gone."""
336 try:
337 cls.servers_client.delete_server(server_id)
Ken'ichi Ohmichie91a0c62015-08-13 02:09:16 +0000338 waiters.wait_for_server_termination(cls.servers_client,
339 server_id)
Jesse Keating613b4982015-05-04 15:05:19 -0700340 except Exception:
341 LOG.exception('Failed to delete server %s' % server_id)
342
343 @classmethod
Matt Riedemann5dc594c2014-01-27 11:40:28 -0800344 def delete_volume(cls, volume_id):
345 """Deletes the given volume and waits for it to be gone."""
Ken'ichi Ohmichi9f5adf82014-12-12 04:01:32 +0000346 cls._delete_volume(cls.volumes_extensions_client, volume_id)
Ken'ichi Ohmichi543a5d42014-05-02 08:44:15 +0900347
Joseph Lanouxffe09dd2015-03-18 16:45:33 +0000348 @classmethod
349 def get_server_ip(cls, server):
350 """Get the server fixed or floating IP.
351
Sean Dague20e98612016-01-06 14:33:28 -0500352 Based on the configuration we're in, return a correct ip
353 address for validating that a guest is up.
Joseph Lanouxffe09dd2015-03-18 16:45:33 +0000354 """
355 if CONF.validation.connect_method == 'floating':
Sean Dague20e98612016-01-06 14:33:28 -0500356 return cls.validation_resources['floating_ip']['ip']
Joseph Lanouxffe09dd2015-03-18 16:45:33 +0000357 elif CONF.validation.connect_method == 'fixed':
Sean Dague20e98612016-01-06 14:33:28 -0500358 addresses = server['addresses'][CONF.validation.network_for_ssh]
359 for address in addresses:
360 if address['version'] == CONF.validation.ip_version_for_ssh:
361 return address['addr']
362 raise exceptions.ServerUnreachable()
363 else:
364 raise exceptions.InvalidConfiguration()
Joseph Lanouxffe09dd2015-03-18 16:45:33 +0000365
Ghanshyam05049dd2016-02-12 17:44:48 +0900366 def setUp(self):
367 super(BaseV2ComputeTest, self).setUp()
368 self.useFixture(api_microversion_fixture.APIMicroversionFixture(
369 self.request_microversion))
370
Ken'ichi Ohmichi543a5d42014-05-02 08:44:15 +0900371
Ken'ichi Ohmichi02a8ccd2015-11-05 06:05:29 +0000372class BaseV2ComputeAdminTest(BaseV2ComputeTest):
Ken'ichi Ohmichibcefa3d2014-05-09 08:14:05 +0900373 """Base test case class for Compute Admin API tests."""
ivan-zhuf2b00502013-10-18 10:06:52 +0800374
Andrea Frittolib21de6c2015-02-06 20:12:38 +0000375 credentials = ['primary', 'admin']
Emily Hugenbruche7991d92014-12-12 16:53:36 +0000376
377 @classmethod
378 def setup_clients(cls):
Ken'ichi Ohmichi02a8ccd2015-11-05 06:05:29 +0000379 super(BaseV2ComputeAdminTest, cls).setup_clients()
Ken'ichi Ohmichi9f5adf82014-12-12 04:01:32 +0000380 cls.availability_zone_admin_client = (
381 cls.os_adm.availability_zone_client)