blob: f986ddb4a7ff5b22f8c2a6fa810c32c19b997d67 [file] [log] [blame]
ZhiQiang Fan39f97222013-09-20 04:49:44 +08001# Copyright 2012 OpenStack Foundation
Jay Pipes3f981df2012-03-27 18:59:44 -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
Jay Pipes7f757632011-12-02 15:53:32 -050016import os
Matthew Treinishaa29c7e2015-04-23 16:35:09 -040017import tempfile
Jay Pipes3f981df2012-03-27 18:59:44 -040018
Matthew Treinishaa29c7e2015-04-23 16:35:09 -040019from oslo_concurrency import lockutils
Doug Hellmann583ce2c2015-03-11 14:55:46 +000020from oslo_config import cfg
Noam Angel3c6b0162018-07-08 17:05:35 +030021from oslo_config import types
Doug Hellmann583ce2c2015-03-11 14:55:46 +000022from oslo_log import log as logging
Jay Pipes7f757632011-12-02 15:53:32 -050023
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +010024from tempest.lib import exceptions
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +010025from tempest.lib.services import clients
Matthew Treinisha966d0f2015-07-01 17:37:31 -040026from tempest.test_discover import plugins
27
Daryl Walleck1465d612011-11-02 02:22:15 -050028
Maru Newbyf440c292015-03-31 15:58:47 +000029# TODO(marun) Replace use of oslo_config's global ConfigOpts
30# (cfg.CONF) instance with a local instance (cfg.ConfigOpts()) once
31# the cli tests move to the clients. The cli tests rely on oslo
32# incubator modules that use the global cfg.CONF.
33_CONF = cfg.CONF
34
35
DennyZhang88a2dd82013-10-07 12:55:35 -050036def register_opt_group(conf, opt_group, options):
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +010037 if opt_group:
38 conf.register_group(opt_group)
DennyZhang88a2dd82013-10-07 12:55:35 -050039 for opt in options:
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +010040 conf.register_opt(opt, group=getattr(opt_group, 'name', None))
DennyZhang88a2dd82013-10-07 12:55:35 -050041
42
Matthew Treinishc791ac42014-07-16 09:15:23 -040043auth_group = cfg.OptGroup(name='auth',
44 title="Options for authentication and credentials")
45
46
47AuthGroup = [
48 cfg.StrOpt('test_accounts_file',
Matthew Treinishc791ac42014-07-16 09:15:23 -040049 help="Path to the yaml file that contains the list of "
Matthew Treinishfc7cd8f2015-03-30 11:51:55 -040050 "credentials to use for running tests. If used when "
51 "running in parallel you have to make sure sufficient "
52 "credentials are provided in the accounts file. For "
53 "example if no tests with roles are being run it requires "
54 "at least `2 * CONC` distinct accounts configured in "
55 " the `test_accounts_file`, with CONC == the "
56 "number of concurrent test processes."),
Andrea Frittoli (andreaf)17209bb2015-05-22 10:16:57 -070057 cfg.BoolOpt('use_dynamic_credentials',
Attila Fazekas5dda1582015-02-18 17:16:02 +010058 default=True,
Sean Dagueed6e5862016-04-04 10:49:13 -040059 help="Allows test cases to create/destroy projects and "
Andrea Frittoli8283b4e2014-07-17 13:28:58 +010060 "users. This option requires that OpenStack Identity "
61 "API admin credentials are known. If false, isolated "
62 "test cases and parallel execution, can still be "
Ken'ichi Ohmichi553d7cb2018-07-13 22:53:03 +000063 "achieved configuring a list of test accounts"),
Matthew Treinish167b2be2015-01-15 17:20:27 -050064 cfg.ListOpt('tempest_roles',
65 help="Roles to assign to all users created by tempest",
Andrea Frittolic3280152015-02-26 12:42:34 +000066 default=[]),
David Kranz87fc7e92015-07-28 14:05:20 -040067 cfg.StrOpt('default_credentials_domain_name',
68 default='Default',
69 help="Default domain used when getting v3 credentials. "
zhuflf4d35922019-06-06 15:07:05 +080070 "This is the name keystone uses for v2 compatibility."),
Matthew Treinish2219d382015-04-24 10:33:04 -040071 cfg.BoolOpt('create_isolated_networks',
72 default=True,
Andrea Frittoli (andreaf)17209bb2015-05-22 10:16:57 -070073 help="If use_dynamic_credentials is set to True and Neutron "
74 "is enabled Tempest will try to create a usable network, "
Sean Dagueed6e5862016-04-04 10:49:13 -040075 "subnet, and router when needed for each project it "
Matthew Treinish2219d382015-04-24 10:33:04 -040076 "creates. However in some neutron configurations, like "
77 "with VLAN provider networks, this doesn't work. So if "
78 "set to False the isolated networks will not be created"),
Matthew Treinish16cf1e52015-08-11 10:39:23 -040079 cfg.StrOpt('admin_username',
80 help="Username for an administrative user. This is needed for "
Sean Dagueed6e5862016-04-04 10:49:13 -040081 "authenticating requests made by project isolation to "
zhufl5402cc32019-05-28 09:49:15 +080082 "create users and projects"),
Sean Dagueed6e5862016-04-04 10:49:13 -040083 cfg.StrOpt('admin_project_name',
Ken'ichi Ohmichi79a71ac2016-04-22 20:02:51 -070084 help="Project name to use for an administrative user. This is "
Sean Dagueed6e5862016-04-04 10:49:13 -040085 "needed for authenticating requests made by project "
zhufl5402cc32019-05-28 09:49:15 +080086 "isolation to create users and projects"),
Matthew Treinish16cf1e52015-08-11 10:39:23 -040087 cfg.StrOpt('admin_password',
Ken'ichi Ohmichi79a71ac2016-04-22 20:02:51 -070088 help="Password to use for an administrative user. This is "
Sean Dagueed6e5862016-04-04 10:49:13 -040089 "needed for authenticating requests made by project "
Matthew Treinish16cf1e52015-08-11 10:39:23 -040090 "isolation to create users and projects",
zhufl5402cc32019-05-28 09:49:15 +080091 secret=True),
Matthew Treinish16cf1e52015-08-11 10:39:23 -040092 cfg.StrOpt('admin_domain_name',
zhuflc2aa1122018-02-14 09:46:10 +080093 default='Default',
Sergey Vilgelm36fdd202018-11-20 16:10:47 -060094 help="Admin domain name for authentication (Keystone V3). "
Colleen Murphycd0bbbd2019-10-01 16:18:36 -070095 "The same domain applies to user and project if "
96 "admin_user_domain_name and admin_project_domain_name "
97 "are not specified"),
98 cfg.StrOpt('admin_user_domain_name',
99 help="Domain name that contains the admin user (Keystone V3). "
100 "May be different from admin_project_domain_name and "
101 "admin_domain_name"),
102 cfg.StrOpt('admin_project_domain_name',
103 help="Domain name that contains the project given by "
104 "admin_project_name (Keystone V3). May be different from "
105 "admin_user_domain_name and admin_domain_name"),
106 cfg.StrOpt('admin_system',
107 default=None,
108 help="The system scope on which an admin user has an admin "
109 "role assignment, if any. Valid values are 'all' or None. "
110 "This must be set to 'all' if using the "
111 "[oslo_policy]/enforce_scope=true option for the "
112 "identity service."),
Matthew Treinishc791ac42014-07-16 09:15:23 -0400113]
114
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500115identity_group = cfg.OptGroup(name='identity',
116 title="Keystone Configuration Options")
Daryl Walleck1465d612011-11-02 02:22:15 -0500117
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500118IdentityGroup = [
119 cfg.StrOpt('catalog_type',
120 default='identity',
121 help="Catalog type of the Identity service."),
Daniel Melladocad3f3d2016-08-19 14:17:16 +0000122 cfg.BoolOpt('disable_ssl_certificate_validation',
123 default=False,
124 help="Set to True if using self-signed SSL certificates."),
125 cfg.StrOpt('ca_certificates_file',
126 default=None,
127 help='Specify a CA bundle file to use in verifying a '
128 'TLS (https) server certificate.'),
Jay Pipes7c88eb22013-01-16 21:32:43 -0500129 cfg.StrOpt('uri',
Brant Knudsonc7ca3342013-03-28 21:08:50 -0500130 help="Full URI of the OpenStack Identity API (Keystone), v2"),
131 cfg.StrOpt('uri_v3',
132 help='Full URI of the OpenStack Identity API (Keystone), v3'),
Andrea Frittoli8bbdb162014-01-06 11:06:13 +0000133 cfg.StrOpt('auth_version',
Ken'ichi Ohmichia6065a62017-03-03 16:40:22 -0800134 default='v3',
Andrea Frittoli8bbdb162014-01-06 11:06:13 +0000135 help="Identity API version to be used for authentication "
Andrea Frittoli77f9da42014-02-06 11:18:19 +0000136 "for API tests."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500137 cfg.StrOpt('region',
Attila Fazekascadcb1f2013-01-21 23:10:53 +0100138 default='RegionOne',
Arata Notsu8f440392013-09-13 16:14:20 +0900139 help="The identity region name to use. Also used as the other "
140 "services' region name unless they are set explicitly. "
141 "If no such region is found in the service catalog, the "
142 "first found one is used."),
Jane Zadorozhnac7862132015-07-10 14:34:50 +0300143 cfg.StrOpt('v2_admin_endpoint_type',
144 default='adminURL',
145 choices=['public', 'admin', 'internal',
146 'publicURL', 'adminURL', 'internalURL'],
147 help="The admin endpoint type to use for OpenStack Identity "
ghanshyamf58b9fd2015-09-01 16:11:39 +0900148 "(Keystone) API v2"),
Jane Zadorozhnac7862132015-07-10 14:34:50 +0300149 cfg.StrOpt('v2_public_endpoint_type',
JordanP5d29b2c2013-12-18 13:56:03 +0000150 default='publicURL',
151 choices=['public', 'admin', 'internal',
152 'publicURL', 'adminURL', 'internalURL'],
Jane Zadorozhnac7862132015-07-10 14:34:50 +0300153 help="The public endpoint type to use for OpenStack Identity "
zhuflf4d35922019-06-06 15:07:05 +0800154 "(Keystone) API v2"),
Jane Zadorozhnac7862132015-07-10 14:34:50 +0300155 cfg.StrOpt('v3_endpoint_type',
156 default='adminURL',
157 choices=['public', 'admin', 'internal',
158 'publicURL', 'adminURL', 'internalURL'],
159 help="The endpoint type to use for OpenStack Identity "
Hemanth Nakkinab4c0c822017-04-29 10:57:31 +0530160 "(Keystone) API v3. The default value adminURL is "
161 "deprecated and will be modified to publicURL in "
162 "the next release."),
Russell Sim7f894a52013-09-13 10:35:21 +1000163 cfg.StrOpt('admin_role',
164 default='admin',
165 help="Role required to administrate keystone."),
Martin Pavlasek4c3f2ab2014-04-15 17:15:15 +0200166 cfg.StrOpt('default_domain_id',
167 default='default',
168 help="ID of the default domain"),
Andrea Frittoli (andreaf)100d18d2016-05-05 23:34:52 +0100169 cfg.BoolOpt('admin_domain_scope',
170 default=False,
171 help="Whether keystone identity v3 policy required "
Rodrigo Duarte Sousa2d78e8e2016-09-28 10:38:08 -0300172 "a domain scoped token to use admin APIs"),
173 # Security Compliance (PCI-DSS)
174 cfg.IntOpt('user_lockout_failure_attempts',
175 default=2,
176 help="The number of unsuccessful login attempts the user is "
ghanshyama5c28bf2018-10-19 07:51:09 +0000177 "allowed before having the account locked. This only "
178 "takes effect when identity-feature-enabled."
179 "security_compliance is set to 'True'. For more details, "
180 "refer to keystone config options keystone.conf:"
181 "security_compliance.lockout_failure_attempts. "
182 "This feature is disabled by default in keystone."),
Rodrigo Duarte Sousa2d78e8e2016-09-28 10:38:08 -0300183 cfg.IntOpt('user_lockout_duration',
184 default=5,
185 help="The number of seconds a user account will remain "
ghanshyama5c28bf2018-10-19 07:51:09 +0000186 "locked. This only takes "
187 "effect when identity-feature-enabled.security_compliance "
188 "is set to 'True'. For more details, refer to "
189 "keystone config options "
190 "keystone.conf:security_compliance.lockout_duration. "
191 "Setting this option will have no effect unless you also "
192 "set identity.user_lockout_failure_attempts."),
Rodrigo Duarte Sousa2d78e8e2016-09-28 10:38:08 -0300193 cfg.IntOpt('user_unique_last_password_count',
194 default=2,
195 help="The number of passwords for a user that must be unique "
zhuflb11f85a2018-10-15 15:21:34 +0800196 "before an old password can be reused. This only takes "
197 "effect when identity-feature-enabled.security_compliance "
Sergey Vilgelm36fdd202018-11-20 16:10:47 -0600198 "is set to 'True'. "
zhuflb11f85a2018-10-15 15:21:34 +0800199 "This config option corresponds to keystone.conf: "
200 "security_compliance.unique_last_password_count, whose "
201 "default value is 0 meaning disabling this feature. "
202 "NOTE: This config option value must be same as "
203 "keystone.conf: security_compliance.unique_last_password_"
204 "count otherwise test might fail"
205 ),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500206]
Jay Pipes3f981df2012-03-27 18:59:44 -0400207
zhufl071e94c2016-07-12 10:26:34 +0800208service_clients_group = cfg.OptGroup(name='service-clients',
209 title="Service Clients Options")
210
211ServiceClientsGroup = [
212 cfg.IntOpt('http_timeout',
213 default=60,
214 help='Timeout in seconds to wait for the http request to '
215 'return'),
Matthew Treinish74514402016-09-01 11:44:57 -0400216 cfg.StrOpt('proxy_url',
217 help='Specify an http proxy to use.')
zhufl071e94c2016-07-12 10:26:34 +0800218]
219
Matthew Treinishd5021a72014-01-09 18:42:51 +0000220identity_feature_group = cfg.OptGroup(name='identity-feature-enabled',
221 title='Enabled Identity Features')
222
223IdentityFeatureGroup = [
224 cfg.BoolOpt('trust',
225 default=True,
226 help='Does the identity service have delegation and '
Matthew Treinishdb2c5972014-01-31 22:18:59 +0000227 'impersonation enabled'),
228 cfg.BoolOpt('api_v2',
Lance Bragstad1fbad232017-09-22 18:58:53 +0000229 default=False,
230 help='Is the v2 identity API enabled',
231 deprecated_for_removal=True,
232 deprecated_reason='The identity v2.0 API was removed in the '
233 'Queens release. Tests that exercise the '
234 'v2.0 API will be removed from tempest in '
235 'the v22.0.0 release. They are kept only to '
236 'test stable branches.'),
Andrea Frittoli1413ba92017-04-21 14:33:23 +0100237 cfg.BoolOpt('api_v2_admin',
238 default=True,
239 help="Is the v2 identity admin API available? This setting "
240 "only applies if api_v2 is set to True."),
Matthew Treinishdb2c5972014-01-31 22:18:59 +0000241 cfg.BoolOpt('api_v3',
242 default=True,
243 help='Is the v3 identity API enabled'),
Jane Zadorozhna121576d2015-06-23 12:57:13 +0300244 cfg.ListOpt('api_extensions',
245 default=['all'],
246 help="A list of enabled identity extensions with a special "
247 "entry all which indicates every extension is enabled. "
248 "Empty list indicates all extensions are disabled. "
zhufld28a2712017-11-07 13:55:18 +0800249 "To get the list of extensions run: "
250 "'openstack extension list --identity'"),
Leticia Wanderley9cafd3d2017-08-04 00:22:34 -0300251 cfg.BoolOpt('domain_specific_drivers',
252 default=False,
253 help='Are domain specific drivers enabled? '
254 'This configuration value should be same as '
255 '[identity]->domain_specific_drivers_enabled '
256 'in keystone.conf.'),
Rodrigo Duarte Sousa2d78e8e2016-09-28 10:38:08 -0300257 cfg.BoolOpt('security_compliance',
258 default=False,
259 help='Does the environment have the security compliance '
Felipe Monteiro6f960782018-03-16 02:08:38 +0000260 'settings enabled?'),
261 cfg.BoolOpt('project_tags',
Luigi Toscanobe427bf2021-08-11 13:12:34 +0200262 default=True,
263 help='Is the project tags identity v3 API available?',
264 deprecated_for_removal=True,
265 deprecated_reason='Project tags API is a default feature '
266 'since Queens'),
Colleen Murphy0e52d4e2018-02-17 21:29:40 +0100267 cfg.BoolOpt('application_credentials',
Luigi Toscano18a10b12021-08-10 01:04:56 +0200268 default=True,
Colleen Murphy0e52d4e2018-02-17 21:29:40 +0100269 help='Does the environment have application credentials '
Luigi Toscano18a10b12021-08-10 01:04:56 +0200270 'enabled?',
271 deprecated_for_removal=True,
272 deprecated_reason='Application credentials is a default '
273 'feature since Queens'),
Colleen Murphyd2cbd3a2019-12-17 16:31:14 -0800274 # Access rules for application credentials is a default feature in Train.
275 # This config option can removed once Stein is EOL.
276 cfg.BoolOpt('access_rules',
277 default=False,
278 help='Does the environment have access rules enabled?'),
Anna Pankiewicza0710662018-07-24 14:56:42 -0500279 cfg.BoolOpt('immutable_user_source',
280 default=False,
281 help='Set to True if the environment has a read-only '
282 'user source. This will skip all tests that attempt to '
283 'create, delete, or modify users. This should not be set '
284 'to True if using dynamic credentials')
Matthew Treinishd5021a72014-01-09 18:42:51 +0000285]
286
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500287compute_group = cfg.OptGroup(name='compute',
288 title='Compute Service Options')
Rohit Karajgie1b050d2011-12-02 16:13:18 -0800289
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500290ComputeGroup = [
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500291 cfg.StrOpt('image_ref',
Matthew Treinishafcb6b42014-05-27 13:50:02 -0400292 help="Valid primary image reference to be used in tests. "
293 "This is a required option"),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500294 cfg.StrOpt('image_ref_alt',
Matthew Treinishafcb6b42014-05-27 13:50:02 -0400295 help="Valid secondary image reference to be used in tests. "
296 "This is a required option, but if only one image is "
297 "available duplicate the value of image_ref above"),
Lee Yarwood7f7c2322019-06-06 10:57:19 +0100298 cfg.StrOpt('certified_image_ref',
299 help="Valid image reference to be used in image certificate "
300 "validation tests when enabled. This image must also "
301 "have the required img_signature_* properties set. "
302 "Additional details available within the following Nova "
303 "documentation: https://docs.openstack.org/nova/latest/"
304 "user/certificate-validation.html"),
305 cfg.ListOpt('certified_image_trusted_certs',
306 help="A list of trusted certificates to be used when the "
307 "image certificate validation compute feature is "
308 "enabled."),
Ken'ichi Ohmichi35772602013-11-14 15:03:27 +0900309 cfg.StrOpt('flavor_ref',
310 default="1",
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500311 help="Valid primary flavor to use in tests."),
Ken'ichi Ohmichi35772602013-11-14 15:03:27 +0900312 cfg.StrOpt('flavor_ref_alt',
313 default="2",
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500314 help='Valid secondary flavor to be used in tests.'),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500315 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -0400316 default=1,
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500317 help="Time in seconds between build status checks."),
318 cfg.IntOpt('build_timeout',
319 default=300,
Hugh Saunders5b139ad2014-12-15 09:08:41 +0000320 help="Timeout in seconds to wait for an instance to build. "
321 "Other services that do not define build_timeout will "
Lucian Petrut1cfe2982015-01-06 13:57:36 +0200322 "inherit this value."),
Attila Fazekas0abbc952013-07-01 19:19:42 +0200323 cfg.IntOpt('ready_wait',
324 default=0,
DennyZhang8912d012013-09-25 18:08:34 -0500325 help="Additional wait time for clean state, when there is "
326 "no OS-EXT-STS extension available"),
Attila Fazekasb0661652013-05-08 13:01:36 +0200327 cfg.StrOpt('fixed_network_name',
Chris Hoge8f1401b2014-11-19 14:00:37 -0800328 help="Name of the fixed network that is visible to all test "
Sean Dagueed6e5862016-04-04 10:49:13 -0400329 "projects. If multiple networks are available for a "
330 "project, this is the network which will be used for "
331 "creating servers if tempest does not create a network or "
zhufl0bad33e2016-10-14 17:21:46 +0800332 "a network is not specified elsewhere. It may be used for "
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000333 "ssh validation only if floating IPs are disabled."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500334 cfg.StrOpt('catalog_type',
335 default='compute',
336 help="Catalog type of the Compute service."),
Arata Notsu8f440392013-09-13 16:14:20 +0900337 cfg.StrOpt('region',
338 default='',
339 help="The compute region name to use. If empty, the value "
340 "of identity.region is used instead. If no such region "
341 "is found in the service catalog, the first found one is "
342 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000343 cfg.StrOpt('endpoint_type',
344 default='publicURL',
345 choices=['public', 'admin', 'internal',
346 'publicURL', 'adminURL', 'internalURL'],
347 help="The endpoint type to use for the compute service."),
Ryan Hsucb2e1252013-09-03 21:44:49 -0700348 cfg.StrOpt('volume_device_name',
349 default='vdb',
350 help="Expected device name when a volume is attached to "
Kevin_Zheng79ec3342017-03-25 17:33:27 +0800351 "an instance. Not all hypervisors guarantee that they "
352 "will respect the user defined device name, tests may "
353 "fail if inappropriate device name is set."),
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900354 cfg.IntOpt('shelved_offload_time',
355 default=0,
356 help='Time in seconds before a shelved instance is eligible '
357 'for removing from a host. -1 never offload, 0 offload '
zhufl917b5552017-11-27 16:07:24 +0800358 'when shelved. This configuration value should be same as '
zhufldc7eeb42018-09-12 11:10:16 +0800359 'nova.conf: DEFAULT.shelved_offload_time, and '
zhufl917b5552017-11-27 16:07:24 +0800360 'some tests will run for as long as the time.'),
Sean Dague782f6772015-11-11 11:26:45 -0500361 cfg.IntOpt('min_compute_nodes',
362 default=1,
363 help=('The minimum number of compute nodes expected. This will '
364 'be utilized by some multinode specific tests to ensure '
365 'that requests match the expected size of the cluster '
ghanshyam29591532016-03-11 17:12:43 +0900366 'you are testing with.')),
Ken'ichi Ohmichi49db4fe2016-08-12 15:26:51 -0700367 cfg.StrOpt('hypervisor_type',
368 default=None,
369 help="Hypervisor type of the test target on heterogeneous "
370 "compute environment. The value can be 'QEMU', 'xen' or "
371 "something."),
Ken'ichi Ohmichi4d237e72015-11-05 06:32:33 +0000372 cfg.StrOpt('min_microversion',
373 default=None,
374 help="Lower version of the test target microversion range. "
375 "The format is 'X.Y', where 'X' and 'Y' are int values. "
376 "Tempest selects tests based on the range between "
377 "min_microversion and max_microversion. "
Ghanshyam395c5b52015-12-04 17:27:16 +0900378 "If both values are not specified, Tempest avoids tests "
379 "which require a microversion. Valid values are string "
ghanshyam8889d2b2017-02-14 02:29:06 +0000380 "with format 'X.Y' or string 'latest'"),
Ken'ichi Ohmichi4d237e72015-11-05 06:32:33 +0000381 cfg.StrOpt('max_microversion',
382 default=None,
383 help="Upper version of the test target microversion range. "
384 "The format is 'X.Y', where 'X' and 'Y' are int values. "
385 "Tempest selects tests based on the range between "
386 "min_microversion and max_microversion. "
Ghanshyam395c5b52015-12-04 17:27:16 +0900387 "If both values are not specified, Tempest avoids tests "
388 "which require a microversion. Valid values are string "
ghanshyam8889d2b2017-02-14 02:29:06 +0000389 "with format 'X.Y' or string 'latest'"),
Marc Koderer979e4942016-12-08 10:07:59 +0100390 cfg.StrOpt('compute_volume_common_az',
391 default=None,
392 help='AZ to be used for Cinder and Nova. Set this parameter '
393 'when the cloud has nova.conf: cinder.cross_az_attach '
394 'set to false. Which means volumes attached to an '
395 'instance must be in the same availability zone in Cinder '
396 'as the instance availability zone in Nova. Set the '
397 'common availability zone in this config which will be '
398 'used to boot an instance as well as creating a volume. '
399 'NOTE: If that AZ is not in Cinder (or '
400 'allow_availability_zone_fallback=False in cinder.conf), '
401 'the volume create request will fail and the instance '
402 'will fail the build request.'),
ghanshyam29591532016-03-11 17:12:43 +0900403]
404
Lajos Katonaceb88212018-11-30 14:54:12 +0100405placement_group = cfg.OptGroup(name='placement',
406 title='Placement Service Options')
407
408PlacementGroup = [
409 cfg.StrOpt('endpoint_type',
410 default='public',
411 choices=['public', 'admin', 'internal'],
412 help="The endpoint type to use for the placement service."),
413 cfg.StrOpt('catalog_type',
414 default='placement',
415 help="Catalog type of the Placement service."),
416 cfg.StrOpt('region',
Swapnil Chhanikara89eea82020-01-24 17:04:42 +0530417 default='',
Lajos Katonaceb88212018-11-30 14:54:12 +0100418 help="The placement region name to use. If empty, the value "
419 "of [identity]/region is used instead. If no such region "
420 "is found in the service catalog, the first region found "
421 "is used."),
422 cfg.StrOpt('min_microversion',
423 default=None,
424 help="Lower version of the test target microversion range. "
425 "The format is 'X.Y', where 'X' and 'Y' are int values. "
426 "Valid values are string with format 'X.Y' or string "
427 "'latest'"),
428 cfg.StrOpt('max_microversion',
429 default=None,
430 help="Upper version of the test target microversion range. "
431 "The format is 'X.Y', where 'X' and 'Y' are int values. "
432 "Valid values are string with format 'X.Y' or string "
433 "'latest'"),
434]
435
436
ghanshyam29591532016-03-11 17:12:43 +0900437compute_features_group = cfg.OptGroup(name='compute-feature-enabled',
438 title="Enabled Compute Service Features")
439
440ComputeFeaturesGroup = [
Matthew Treinishd5c96022013-10-17 21:51:23 +0000441 cfg.BoolOpt('disk_config',
442 default=True,
443 help="If false, skip disk config tests"),
Pavan Kesava Raodeff57e2021-06-09 15:21:37 -0500444 # TODO(pkesav): Make it True by default once wallaby
445 # is oldest supported stable for Tempest.
446 cfg.BoolOpt('hostname_fqdn_sanitization',
447 default=False,
448 help="If false, skip fqdn instance sanitization tests. "
449 "Nova started sanitizing the instance name by replacing "
450 "the '.' with '-' to comply with fqdn hostname. Nova "
451 "changed that in Wallaby cycle, if your cloud is older "
452 "than wallaby then you can keep/make it False."),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000453 cfg.BoolOpt('change_password',
454 default=False,
455 help="Does the test environment support changing the admin "
456 "password?"),
Adam Gandelmanc6eefb42014-07-15 16:44:08 -0700457 cfg.BoolOpt('console_output',
458 default=True,
459 help="Does the test environment support obtaining instance "
460 "serial console output?"),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000461 cfg.BoolOpt('resize',
462 default=False,
Masayuki Igawad91094d2017-04-12 16:20:09 +0900463 help="Does the test environment support resizing? When you "
464 "enable this feature, 'flavor_ref_alt' should be set and "
465 "it should refer to a larger flavor than 'flavor_ref' "
466 "one."),
Eric Windischb5538072014-03-09 23:47:35 -0400467 cfg.BoolOpt('pause',
468 default=True,
469 help="Does the test environment support pausing?"),
David Shrewsbury25f666f2014-07-22 12:17:59 -0400470 cfg.BoolOpt('shelve',
471 default=True,
472 help="Does the test environment support shelving/unshelving?"),
Alexandre Arents0a9b8232020-07-29 09:52:57 +0000473 cfg.BoolOpt('shelve_migrate',
474 default=False,
475 help="Does the test environment support "
476 "cold migration of unshelved server?"),
Eric Windischaeb7e842014-03-10 01:10:50 -0400477 cfg.BoolOpt('suspend',
478 default=True,
479 help="Does the test environment support suspend/resume?"),
Ludovic Beliveauae314882016-09-15 13:34:14 -0400480 cfg.BoolOpt('cold_migration',
481 default=True,
zhufl0bad33e2016-10-14 17:21:46 +0800482 help="Does the test environment support cold migration?"),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000483 cfg.BoolOpt('live_migration',
Joe Gordon31a139a2014-11-17 16:39:04 -0800484 default=True,
zhufl0bad33e2016-10-14 17:21:46 +0800485 help="Does the test environment support live migration?"),
Sarafraj Singh61e40452016-09-29 13:06:59 -0500486 cfg.BoolOpt('live_migrate_back_and_forth',
487 default=False,
488 help="Does the test environment support live migrating "
489 "VM back and forth between different versions of "
490 "nova-compute?"),
YAMAMOTO Takashi1f62af22015-06-16 03:29:50 +0900491 cfg.BoolOpt('metadata_service',
492 default=True,
493 help="Does the test environment support metadata service? "
494 "Ignored unless validation.run_validation=true."),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000495 cfg.BoolOpt('block_migration_for_live_migration',
496 default=False,
497 help="Does the test environment use block devices for live "
498 "migration"),
499 cfg.BoolOpt('block_migrate_cinder_iscsi',
500 default=False,
Matt Riedemann8cf5f902017-04-24 11:42:48 -0400501 help="Does the test environment support block migration with "
502 "Cinder iSCSI volumes. Note: libvirt >= 1.2.17 is required "
Lee Yarwood48fe99f2020-01-27 19:18:24 +0000503 "to support this if using the libvirt compute driver.",
504 deprecated_for_removal=True,
505 deprecated_reason='This option duplicates the more generic '
506 '[compute-feature-enabled]/block_migration '
507 '_for_live_migration now that '
508 'MIN_LIBVIRT_VERSION is >= 1.2.17 on all '
509 'branches from stable/rocky and will be '
510 'removed in a future release.'),
zhuflbe052d62019-11-04 10:56:02 +0800511 cfg.BoolOpt('can_migrate_between_any_hosts',
512 default=True,
513 help="Does the test environment support migrating between "
514 "any hosts? In environments with non-homogeneous compute "
515 "nodes you can set this to False so that it will select "
516 "destination host for migrating automatically"),
Ghanshyam Mann41c17572014-02-27 18:52:56 +0900517 cfg.BoolOpt('vnc_console',
518 default=False,
519 help='Enable VNC console. This configuration value should '
zhufldc7eeb42018-09-12 11:10:16 +0800520 'be same as nova.conf: vnc.enabled'),
Alex Savatieiev82b6aeb2018-03-28 17:56:49 +0200521 cfg.StrOpt('vnc_server_header',
522 default='WebSockify',
523 help='Expected VNC server name (WebSockify, nginx, etc) '
Leo Henkenfd01d152019-08-02 11:42:52 -0500524 'in response header.',
525 deprecated_for_removal=True,
526 deprecated_reason='This option will be ignored because the '
527 'usage of different response header fields '
528 'to accomplish the same goal (in accordance '
529 'with RFC7231 S6.2.2) makes it obsolete.'),
Ghanshyam70876d02014-03-11 11:40:18 +0900530 cfg.BoolOpt('spice_console',
531 default=False,
532 help='Enable Spice console. This configuration value should '
zhufld5bda712019-11-01 14:01:01 +0800533 'be same as nova.conf: spice.enabled',
534 deprecated_for_removal=True,
535 deprecated_reason="This config option is not being used "
536 "in Tempest, we can add it back when "
537 "adding the test cases."),
Ghanshyam70876d02014-03-11 11:40:18 +0900538 cfg.BoolOpt('rdp_console',
539 default=False,
540 help='Enable RDP console. This configuration value should '
zhufld5bda712019-11-01 14:01:01 +0800541 'be same as nova.conf: rdp.enabled',
542 deprecated_for_removal=True,
543 deprecated_reason="This config option is not being used "
544 "in Tempest, we can add it back when "
545 "adding the test cases."),
Markus Zoeller69d58b82017-02-17 10:09:22 +0100546 cfg.BoolOpt('serial_console',
547 default=False,
548 help='Enable serial console. This configuration value '
zhufldc7eeb42018-09-12 11:10:16 +0800549 'should be the same as '
550 'nova.conf: serial_console.enabled'),
Adam Gandelman2e37b4f2014-06-18 17:34:21 -0700551 cfg.BoolOpt('rescue',
552 default=True,
553 help='Does the test environment support instance rescue '
Ghanshyam9c2e50d2014-07-22 21:32:05 +0900554 'mode?'),
Lee Yarwoodc0ad55c2019-12-06 13:39:19 +0000555 cfg.BoolOpt('stable_rescue',
556 default=False,
557 help='Does the test environment support stable device '
558 'instance rescue mode?'),
Ghanshyam9c2e50d2014-07-22 21:32:05 +0900559 cfg.BoolOpt('enable_instance_password',
560 default=True,
561 help='Enables returning of the instance password by the '
562 'relevant server API calls such as create, rebuild '
zhufle8a703b2016-09-09 15:23:03 +0800563 'or rescue. This configuration value should be same as '
564 'nova.conf: DEFAULT.enable_instance_password'),
Adam Gandelman7186f7a2014-07-23 09:28:56 -0400565 cfg.BoolOpt('interface_attach',
566 default=True,
567 help='Does the test environment support dynamic network '
Adam Gandelmanfbc95ac2014-06-19 17:33:43 -0700568 'interface attachment?'),
569 cfg.BoolOpt('snapshot',
570 default=True,
571 help='Does the test environment support creating snapshot '
Matthew Treinishdfd7ac02015-02-09 17:47:31 -0500572 'images of running instances?'),
Takeaki Matsumotodf4ab7c2015-08-25 17:49:23 +0900573 cfg.BoolOpt('nova_cert',
Sean Dague6943acb2016-08-08 15:28:17 -0400574 default=False,
575 help='Does the test environment have the nova cert running?',
Ken'ichi Ohmichid65cf9c2016-11-23 16:56:04 -0800576 deprecated_for_removal=True,
577 deprecated_reason="On Nova side, the nova-cert service is "
578 "deprecated and the service will be removed "
579 "as early as Ocata."),
Takeaki Matsumotod7e04b22015-09-04 15:13:38 +0900580 cfg.BoolOpt('personality',
Matt Riedemann0baba702016-07-03 19:24:08 -0400581 default=False,
Takeaki Matsumotod7e04b22015-09-04 15:13:38 +0900582 help='Does the test environment support server personality'),
Matt Riedemann79b3b492015-06-20 14:20:44 -0700583 cfg.BoolOpt('attach_encrypted_volume',
584 default=True,
585 help='Does the test environment support attaching an '
586 'encrypted volume to a running server instance? This may '
587 'depend on the combination of compute_driver in nova and '
588 'the volume_driver(s) in cinder.'),
Alexander Gubanov509e2842015-06-09 15:29:51 +0300589 cfg.BoolOpt('config_drive',
590 default=True,
591 help='Enable special configuration drive with metadata.'),
Artom Lifshitz595ae162018-05-23 10:19:18 -0400592 cfg.ListOpt('scheduler_enabled_filters',
Artom Lifshitz1c976a92019-06-17 15:30:18 -0400593 default=["AvailabilityZoneFilter", "ComputeFilter",
594 "ComputeCapabilitiesFilter", "ImagePropertiesFilter",
Artom Lifshitz595ae162018-05-23 10:19:18 -0400595 "ServerGroupAntiAffinityFilter",
596 "ServerGroupAffinityFilter"],
597 help="A list of enabled filters that Nova will accept as "
598 "hints to the scheduler when creating a server. If the "
ghanshyam5817e142016-12-01 11:38:46 +0900599 "default value is overridden in nova.conf by the test "
600 "environment (which means that a different set of "
601 "filters is enabled than what is included in Nova by "
Artom Lifshitz595ae162018-05-23 10:19:18 -0400602 "default), then this option must be configured to "
ghanshyam5817e142016-12-01 11:38:46 +0900603 "contain the same filters that Nova uses in the test "
Artom Lifshitz595ae162018-05-23 10:19:18 -0400604 "environment. A special entry 'all' indicates all "
605 "filters that are included with Nova are enabled. If "
606 "using 'all', be sure to enable all filters in "
607 "nova.conf, as tests can fail in unpredictable ways if "
608 "Nova's and Tempest's enabled filters don't match. "
609 "Empty list indicates all filters are disabled. The "
610 "full list of enabled filters is in nova.conf: "
611 "filter_scheduler.enabled_filters.",
612 deprecated_opts=[cfg.DeprecatedOpt(
613 'scheduler_available_filters',
614 group='compute-feature-enabled')]),
Matt Riedemann342b37c2016-09-21 15:38:12 -0400615 cfg.BoolOpt('swap_volume',
616 default=False,
617 help='Does the test environment support in-place swapping of '
618 'volumes attached to a server instance?'),
melanie witt334f3132017-12-14 21:49:55 +0000619 cfg.BoolOpt('volume_backed_live_migration',
620 default=False,
621 help='Does the test environment support volume-backed live '
622 'migration?'),
Matt Riedemann81fa9b62016-01-14 13:04:38 -0800623 cfg.BoolOpt('volume_multiattach',
624 default=False,
625 help='Does the test environment support attaching a volume to '
626 'more than one instance? This depends on hypervisor and '
627 'volume backend/type and compute API version 2.60.'),
Stephen Finucane39fa9c12020-09-03 17:47:19 +0100628 cfg.BoolOpt('xenapi_apis',
629 default=False,
630 help='Does the test environment support the XenAPI-specific '
631 'APIs: os-agents, writeable server metadata and the '
632 'resetNetwork server action? '
633 'These were removed in Victoria alongside the XenAPI '
634 'virt driver.',
635 deprecated_for_removal=True,
636 deprecated_reason="On Nova side, XenAPI virt driver and the "
637 "APIs that only worked with that driver "
638 "have been removed and there's nothing to "
639 "test after Ussuri."),
Lee Yarwood56a446d2021-02-15 13:34:35 +0000640 cfg.BoolOpt('ide_bus',
641 default=True,
642 help='Does the test environment support attaching devices '
643 'using an IDE bus to the instance?'),
melanie witt74fa5052021-05-06 22:41:30 +0000644 cfg.BoolOpt('unified_limits',
645 default=False,
646 help='Does the test environment support unified limits?'),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000647]
648
649
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500650image_group = cfg.OptGroup(name='image',
651 title="Image Service Options")
Jay Pipesf38eaac2012-06-21 13:37:35 -0400652
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500653ImageGroup = [
Matthew Treinish72ea4422013-02-07 14:42:49 -0500654 cfg.StrOpt('catalog_type',
655 default='image',
Sean Dague83401992013-05-06 17:46:36 -0400656 help='Catalog type of the Image service.'),
Arata Notsu8f440392013-09-13 16:14:20 +0900657 cfg.StrOpt('region',
658 default='',
659 help="The image region name to use. If empty, the value "
660 "of identity.region is used instead. If no such region "
661 "is found in the service catalog, the first found one is "
662 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000663 cfg.StrOpt('endpoint_type',
664 default='publicURL',
665 choices=['public', 'admin', 'internal',
666 'publicURL', 'adminURL', 'internalURL'],
667 help="The endpoint type to use for the image service."),
Dan Smithd4bc9a82021-01-12 17:25:07 -0800668 cfg.StrOpt('alternate_image_endpoint',
669 default=None,
670 help="Alternate endpoint name for cross-worker testing"),
671 cfg.StrOpt('alternate_image_endpoint_type',
672 default='publicURL',
673 choices=['public', 'admin', 'internal',
674 'publicURL', 'adminURL', 'internalURL'],
675 help=("The endpoint type to use for the alternate image "
676 "service.")),
Sean Dague83401992013-05-06 17:46:36 -0400677 cfg.StrOpt('http_image',
678 default='http://download.cirros-cloud.net/0.3.1/'
679 'cirros-0.3.1-x86_64-uec.tar.gz',
Lucian Petrut1cfe2982015-01-06 13:57:36 +0200680 help='http accessible image'),
681 cfg.IntOpt('build_timeout',
682 default=300,
683 help="Timeout in seconds to wait for an image to "
684 "become available."),
685 cfg.IntOpt('build_interval',
686 default=1,
687 help="Time in seconds between image operation status "
Takashi NATSUME12a48512015-08-10 18:33:16 +0900688 "checks."),
689 cfg.ListOpt('container_formats',
690 default=['ami', 'ari', 'aki', 'bare', 'ovf', 'ova'],
691 help="A list of image's container formats "
692 "users can specify."),
693 cfg.ListOpt('disk_formats',
694 default=['ami', 'ari', 'aki', 'vhd', 'vmdk', 'raw', 'qcow2',
Benny Kopilov97c74192017-03-30 09:34:59 +0300695 'vdi', 'iso', 'vhdx'],
Takashi NATSUME12a48512015-08-10 18:33:16 +0900696 help="A list of image's disk formats "
697 "users can specify.")
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500698]
Jay Pipesf38eaac2012-06-21 13:37:35 -0400699
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000700image_feature_group = cfg.OptGroup(name='image-feature-enabled',
701 title='Enabled image service features')
702
703ImageFeaturesGroup = [
704 cfg.BoolOpt('api_v2',
705 default=True,
ghanshyam6b0b8b72017-03-08 04:22:53 +0000706 help="Is the v2 image API enabled",
707 deprecated_for_removal=True,
708 deprecated_reason='Glance v1 APIs are deprecated and v2 APIs '
709 'are current one. In future, Tempest will '
710 'test v2 APIs only so this config option '
711 'will be removed.'),
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000712 cfg.BoolOpt('api_v1',
zhufldc68af72018-09-05 15:47:39 +0800713 default=False,
ghanshyam6b0b8b72017-03-08 04:22:53 +0000714 help="Is the v1 image API enabled",
715 deprecated_for_removal=True,
716 deprecated_reason='Glance v1 APIs are deprecated and v2 APIs '
717 'are current one. In future, Tempest will '
718 'test v2 APIs only so this config option '
719 'will be removed.'),
Abhishek Kekane7cff1302020-07-16 10:30:13 +0000720 # Image import feature is setup in devstack victoria onwards.
721 # Once all stable branches setup the same via glance standalone
722 # mode or with uwsgi, we can remove this config option.
723 cfg.BoolOpt('import_image',
724 default=False,
725 help="Is image import feature enabled"),
Dan Smithe044dad2021-01-15 12:45:16 -0800726 # NOTE(danms): Starting mid-Wallaby glance began enforcing the
727 # previously-informal requirement that os_glance_* properties are
728 # reserved for internal use. Thus, we can only run these checks
729 # if we know we are on a new enough glance.
730 cfg.BoolOpt('os_glance_reserved',
731 default=False,
732 help="Should we check that os_glance namespace is reserved"),
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000733]
Jay Pipesf38eaac2012-06-21 13:37:35 -0400734
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500735network_group = cfg.OptGroup(name='network',
736 title='Network Service Options')
Daryl Walleck587385b2012-03-03 13:00:26 -0600737
Noam Angel3c6b0162018-07-08 17:05:35 +0300738ProfileType = types.Dict(types.List(types.String(), bounds=True))
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500739NetworkGroup = [
740 cfg.StrOpt('catalog_type',
741 default='network',
Mark McClainf2982e82013-07-06 17:48:03 -0400742 help='Catalog type of the Neutron service.'),
Arata Notsu8f440392013-09-13 16:14:20 +0900743 cfg.StrOpt('region',
744 default='',
745 help="The network region name to use. If empty, the value "
746 "of identity.region is used instead. If no such region "
747 "is found in the service catalog, the first found one is "
748 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000749 cfg.StrOpt('endpoint_type',
750 default='publicURL',
751 choices=['public', 'admin', 'internal',
752 'publicURL', 'adminURL', 'internalURL'],
753 help="The endpoint type to use for the network service."),
Sean Dagueed6e5862016-04-04 10:49:13 -0400754 cfg.StrOpt('project_network_cidr',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500755 default="10.100.0.0/16",
Sean Dagueed6e5862016-04-04 10:49:13 -0400756 help="The cidr block to allocate project ipv4 subnets from"),
757 cfg.IntOpt('project_network_mask_bits',
Attila Fazekas8ea181b2013-07-13 16:26:14 +0200758 default=28,
Sean Dagueed6e5862016-04-04 10:49:13 -0400759 help="The mask bits for project ipv4 subnets"),
760 cfg.StrOpt('project_network_v6_cidr',
Brian Haley56893552019-09-19 17:50:37 -0400761 default="2001:db8::/48",
Sean Dagueed6e5862016-04-04 10:49:13 -0400762 help="The cidr block to allocate project ipv6 subnets from"),
763 cfg.IntOpt('project_network_v6_mask_bits',
Sergey Shnaidman1f3659a2014-08-27 18:26:42 +0400764 default=64,
Sean Dagueed6e5862016-04-04 10:49:13 -0400765 help="The mask bits for project ipv6 subnets"),
766 cfg.BoolOpt('project_networks_reachable',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500767 default=False,
Sean Dagueed6e5862016-04-04 10:49:13 -0400768 help="Whether project networks can be reached directly from "
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000769 "the test client. This must be set to True when the "
Matt Riedemann4b0f7e72016-08-08 15:29:26 -0400770 "'fixed' connect_method is selected."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500771 cfg.StrOpt('public_network_id',
772 default="",
773 help="Id of the public network that provides external "
774 "connectivity"),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000775 cfg.StrOpt('floating_network_name',
776 help="Default floating network name. Used to allocate floating "
777 "IPs when neutron is enabled."),
Lukas Piwowarski2385e042020-01-31 12:28:20 +0000778 cfg.StrOpt('subnet_id',
779 default="",
780 help="Subnet id of subnet which is used for allocation of "
781 "floating IPs. Specify when two or more subnets are "
782 "present in network."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500783 cfg.StrOpt('public_router_id',
784 default="",
785 help="Id of the public router that provides external "
Yair Fried1eb27f52014-11-10 15:24:19 +0200786 "connectivity. This should only be used when Neutron's "
787 "'allow_overlapping_ips' is set to 'False' in "
788 "neutron.conf. usually not needed past 'Grizzly' release"),
izikpensod9a01a62014-02-17 20:02:32 +0200789 cfg.IntOpt('build_timeout',
790 default=300,
791 help="Timeout in seconds to wait for network operation to "
792 "complete."),
793 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -0400794 default=1,
izikpensod9a01a62014-02-17 20:02:32 +0200795 help="Time in seconds between network operation status "
796 "checks."),
Attila Fazekas640392b2014-06-12 15:58:10 +0200797 cfg.ListOpt('dns_servers',
798 default=["8.8.8.8", "8.8.4.4"],
Itzik Brown5be44582014-12-24 09:05:13 +0200799 help="List of dns servers which should be used"
zhufle027ea92019-05-07 14:02:23 +0800800 " for subnet creation",
801 deprecated_for_removal=True,
802 deprecated_reason="This config option is no longer "
803 "used anywhere, so it can be removed."),
Itzik Brown2ca01cd2014-12-08 12:58:20 +0200804 cfg.StrOpt('port_vnic_type',
Tom Stappaerts27fd5cb2020-11-26 12:07:47 +0100805 choices=[None, 'normal', 'direct', 'macvtap', 'direct-physical',
806 'baremetal', 'virtio-forwarder'],
Moshe Levie2c2fb12017-08-31 15:18:58 +0300807 help="vnic_type to use when launching instances"
Itzik Brown2ca01cd2014-12-08 12:58:20 +0200808 " with pre-configured ports."
809 " Supported ports are:"
Tom Stappaerts27fd5cb2020-11-26 12:07:47 +0100810 " ['normal', 'direct', 'macvtap', 'direct-physical', "
811 "'baremetal', 'virtio-forwarder']"),
Noam Angel3c6b0162018-07-08 17:05:35 +0300812 cfg.Opt('port_profile',
813 type=ProfileType,
814 default={},
815 help="port profile to use when launching instances"
816 " with pre-configured ports."),
piyush11078648e35d52015-09-24 12:56:43 +0530817 cfg.ListOpt('default_network',
818 default=["1.0.0.0/16", "2.0.0.0/16"],
819 help="List of ip pools"
820 " for subnetpools creation"),
Thiago Paiva66cded22016-08-15 14:55:58 -0300821 cfg.BoolOpt('shared_physical_network',
822 default=False,
823 help="The environment does not support network separation "
824 "between tenants."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500825]
Jay Pipes3f981df2012-03-27 18:59:44 -0400826
Matthew Treinishe3d26142013-11-26 19:14:58 +0000827network_feature_group = cfg.OptGroup(name='network-feature-enabled',
828 title='Enabled network service features')
829
830NetworkFeaturesGroup = [
Matthew Treinishe2e33cf2014-03-03 19:28:41 +0000831 cfg.BoolOpt('ipv6',
832 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500833 help="Allow the execution of IPv6 tests."),
Matthew Treinishe3d26142013-11-26 19:14:58 +0000834 cfg.ListOpt('api_extensions',
835 default=['all'],
Alexander Gubanov36e1f9b2015-06-12 18:02:10 +0300836 help="A list of enabled network extensions with a special "
837 "entry all which indicates every extension is enabled. "
838 "Empty list indicates all extensions are disabled. "
Brian Haley3d701092020-11-23 14:03:25 -0500839 "To get the list of extensions run: "
840 "'openstack extension list --network'"),
elajkatf9bb8b82020-11-02 13:41:06 +0100841 cfg.ListOpt('available_features',
842 default=['all'],
843 help="A list of available network features with a special "
844 "entry all that indicates every feature is available. "
Brian Haley3d701092020-11-23 14:03:25 -0500845 "Empty list indicates all features are disabled. "
elajkatf9bb8b82020-11-02 13:41:06 +0100846 "This list can contain features that are not "
Brian Haley3d701092020-11-23 14:03:25 -0500847 "discoverable through the API."),
Sean M. Collinsdd27a4d2014-05-13 10:33:15 -0400848 cfg.BoolOpt('ipv6_subnet_attributes',
849 default=False,
850 help="Allow the execution of IPv6 subnet tests that use "
851 "the extended IPv6 attributes ipv6_ra_mode "
Brian Haley3d701092020-11-23 14:03:25 -0500852 "and ipv6_address_mode."
Mark McClain6e07c0d2014-10-10 11:25:03 -0400853 ),
Itzik Brownbeb30d32015-03-29 09:42:54 +0300854 cfg.BoolOpt('port_admin_state_change',
855 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500856 help="Does the test environment support changing "
857 "port admin state?"),
Matt Riedemann039b2fe2016-09-15 16:12:24 -0400858 cfg.BoolOpt('port_security',
859 default=False,
860 help="Does the test environment support port security?"),
Matthew Treinish3312de32017-05-19 12:08:17 -0400861 cfg.BoolOpt('floating_ips',
862 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500863 help='Does the test environment support floating_ips?'),
Lajos Katonac87a06b2019-01-04 13:21:48 +0100864 cfg.StrOpt('qos_placement_physnet', default=None,
865 help='Name of the physnet for placement based minimum '
866 'bandwidth allocation.'),
Takashi Kajinami7138e352022-02-03 09:16:34 +0900867 cfg.StrOpt('provider_net_base_segmentation_id', default='3000',
Lajos Katonac87a06b2019-01-04 13:21:48 +0100868 help='Base segmentation ID to create provider networks. '
Balazs Gibizerf294b0d2021-09-29 16:16:44 +0200869 'This value will be increased in case of conflict.'),
870 cfg.BoolOpt('qos_min_bw_and_pps', default=False,
871 help='Does the test environment have minimum bandwidth and '
872 'packet rate inventories configured?'),
Matthew Treinishe3d26142013-11-26 19:14:58 +0000873]
874
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -0600875dashboard_group = cfg.OptGroup(name="dashboard",
876 title="Dashboard options")
877
878DashboardGroup = [
879 cfg.StrOpt('dashboard_url',
880 default='http://localhost/',
881 help="Where the dashboard can be found"),
882 cfg.BoolOpt('disable_ssl_certificate_validation',
883 default=False,
884 help="Set to True if using self-signed SSL certificates."),
885]
886
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000887validation_group = cfg.OptGroup(name='validation',
888 title='SSH Validation options')
889
890ValidationGroup = [
Matthew Treinishe5cca002015-05-11 15:36:50 -0400891 cfg.BoolOpt('run_validation',
Attila Fazekas489e90f2018-09-12 17:30:01 -0600892 default=True,
Matthew Treinishe5cca002015-05-11 15:36:50 -0400893 help='Enable ssh on created servers and creation of additional'
Attila Fazekas489e90f2018-09-12 17:30:01 -0600894 ' validation resources to enable remote access.'
895 ' In case the guest does not support ssh set it'
896 ' to false'),
Brandon Palmc6cc91d2015-08-19 13:20:21 -0500897 cfg.BoolOpt('security_group',
898 default=True,
899 help='Enable/disable security groups.'),
900 cfg.BoolOpt('security_group_rules',
901 default=True,
902 help='Enable/disable security group rules.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000903 cfg.StrOpt('connect_method',
904 default='floating',
905 choices=['fixed', 'floating'],
906 help='Default IP type used for validation: '
907 '-fixed: uses the first IP belonging to the fixed network '
ghanshyamade71d22017-02-15 05:36:14 +0000908 '-floating: creates and uses a floating IP'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000909 cfg.StrOpt('auth_method',
910 default='keypair',
911 choices=['keypair'],
912 help='Default authentication method to the instance. '
913 'Only ssh via keypair is supported for now. '
ghanshyamade71d22017-02-15 05:36:14 +0000914 'Additional methods will be handled in a separate spec.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000915 cfg.IntOpt('ip_version_for_ssh',
916 default=4,
lanoux283273b2015-12-04 03:01:54 -0800917 help='Default IP version for ssh connections.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000918 cfg.IntOpt('ping_timeout',
919 default=120,
ghanshyam244cf7c2017-02-15 06:39:31 +0000920 help='Timeout in seconds to wait for ping to succeed.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000921 cfg.IntOpt('connect_timeout',
922 default=60,
923 help='Timeout in seconds to wait for the TCP connection to be '
lanoux283273b2015-12-04 03:01:54 -0800924 'successful.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000925 cfg.IntOpt('ssh_timeout',
926 default=300,
lanoux283273b2015-12-04 03:01:54 -0800927 help='Timeout in seconds to wait for the ssh banner.'),
928 cfg.StrOpt('image_ssh_user',
929 default="root",
ghanshyam244cf7c2017-02-15 06:39:31 +0000930 help="User name used to authenticate to an instance."),
Weronika Sikorac54a9112019-09-18 13:55:07 +0000931 cfg.StrOpt('image_alt_ssh_user',
932 default="root",
933 help="User name used to authenticate to an alt instance."),
lanoux283273b2015-12-04 03:01:54 -0800934 cfg.StrOpt('image_ssh_password',
935 default="password",
Doug Schveninger6a2be432020-04-29 17:42:31 -0500936 help="Password used to authenticate to an instance.",
937 secret=True),
Weronika Sikorac54a9112019-09-18 13:55:07 +0000938 cfg.StrOpt('image_alt_ssh_password',
939 default="password",
940 help="Password used to authenticate to an alt instance.",
941 secret=True),
lanoux283273b2015-12-04 03:01:54 -0800942 cfg.StrOpt('ssh_shell_prologue',
Lucian Petrut6a7472a2019-08-07 12:43:08 +0300943 default="set -eu -o pipefail; PATH=$$PATH:/sbin:/usr/sbin;",
lanoux283273b2015-12-04 03:01:54 -0800944 help="Shell fragments to use before executing a command "
ghanshyamade71d22017-02-15 05:36:14 +0000945 "when sshing to a guest."),
lanoux283273b2015-12-04 03:01:54 -0800946 cfg.IntOpt('ping_size',
947 default=56,
948 help="The packet size for ping packets originating "
ghanshyamade71d22017-02-15 05:36:14 +0000949 "from remote linux hosts"),
lanoux283273b2015-12-04 03:01:54 -0800950 cfg.IntOpt('ping_count',
951 default=1,
952 help="The number of ping packets originating from remote "
ghanshyamade71d22017-02-15 05:36:14 +0000953 "linux hosts"),
lanoux283273b2015-12-04 03:01:54 -0800954 cfg.StrOpt('floating_ip_range',
955 default='10.0.0.0/29',
956 help='Unallocated floating IP range, which will be used to '
957 'test the floating IP bulk feature for CRUD operation. '
958 'This block must not overlap an existing floating IP '
ghanshyamade71d22017-02-15 05:36:14 +0000959 'pool.'),
lanoux283273b2015-12-04 03:01:54 -0800960 cfg.StrOpt('network_for_ssh',
961 default='public',
962 help="Network used for SSH connections. Ignored if "
ghanshyam244cf7c2017-02-15 06:39:31 +0000963 "connect_method=floating."),
Ade Lee6ded0702021-09-04 15:56:34 -0400964 cfg.StrOpt('ssh_key_type',
Martin Kopec75ca0b82022-04-20 17:57:45 +0200965 default='ecdsa',
Ade Lee6ded0702021-09-04 15:56:34 -0400966 help='Type of key to use for ssh connections. '
967 'Valid types are rsa, ecdsa'),
Roman Safronov72575882022-02-10 12:26:43 +0200968 cfg.IntOpt('allowed_network_downtime',
969 default=5.0,
970 help="Allowed VM network connection downtime during live "
971 "migration, in seconds. "
972 "When the measured downtime exceeds this value, an "
973 "exception is raised."),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000974]
975
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500976volume_group = cfg.OptGroup(name='volume',
977 title='Block Storage Options')
Daryl Walleck587385b2012-03-03 13:00:26 -0600978
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500979VolumeGroup = [
980 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -0400981 default=1,
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500982 help='Time in seconds between volume availability checks.'),
983 cfg.IntOpt('build_timeout',
984 default=300,
Eric Harney9b1f89c2014-10-14 14:40:19 -0400985 help='Timeout in seconds to wait for a volume to become '
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500986 'available.'),
987 cfg.StrOpt('catalog_type',
ghanshyam89c213f2017-12-14 07:22:12 +0000988 default='volumev3',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500989 help="Catalog type of the Volume Service"),
Arata Notsu8f440392013-09-13 16:14:20 +0900990 cfg.StrOpt('region',
991 default='',
992 help="The volume region name to use. If empty, the value "
993 "of identity.region is used instead. If no such region "
994 "is found in the service catalog, the first found one is "
995 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000996 cfg.StrOpt('endpoint_type',
997 default='publicURL',
998 choices=['public', 'admin', 'internal',
999 'publicURL', 'adminURL', 'internalURL'],
1000 help="The endpoint type to use for the volume service."),
Benny Kopilovaf136a92015-11-10 07:37:23 +02001001 cfg.ListOpt('backend_names',
1002 default=['BACKEND_1', 'BACKEND_2'],
april4be58dc2015-12-29 00:07:22 +08001003 help='A list of backend names separated by comma. '
bkopilov27905cc2016-04-12 14:29:13 +03001004 'The backend name must be declared in cinder.conf'),
Ansuman Bebarta46d540d2021-02-16 18:48:33 +05301005 cfg.StrOpt('volume_type',
1006 default='',
1007 help='Volume type to be used while creating volume.'),
Adam Gandelman827ad332013-06-24 17:04:09 -07001008 cfg.StrOpt('storage_protocol',
1009 default='iSCSI',
1010 help='Backend protocol to target when creating volume types'),
1011 cfg.StrOpt('vendor_name',
1012 default='Open Source',
1013 help='Backend vendor to target when creating volume types'),
Ryan Hsua67f4632013-08-29 16:03:06 -07001014 cfg.StrOpt('disk_format',
1015 default='raw',
1016 help='Disk format to use when copying a volume to image'),
Jerry Cai9733d0e2014-03-19 15:50:49 +08001017 cfg.IntOpt('volume_size',
1018 default=1,
1019 help='Default size in GB for volumes created by volumes tests'),
Martin Kopec37c4bd32021-06-24 15:46:00 +00001020 cfg.IntOpt('volume_size_extend',
1021 default=1,
1022 help="Size in GB a volume is extended by - if a test "
1023 "extends a volume, the size of the new volume will be "
1024 "volume_size + volume_size_extend."),
jeremy.zhangf4fbf302017-03-22 11:25:53 +08001025 cfg.ListOpt('manage_volume_ref',
1026 default=['source-name', 'volume-%s'],
1027 help="A reference to existing volume for volume manage. "
1028 "It contains two elements, the first is ref type "
1029 "(like 'source-name', 'source-id', etc), the second is "
1030 "volume name template used in storage backend"),
jeremy.zhangebc752b2017-06-14 13:58:37 +08001031 cfg.ListOpt('manage_snapshot_ref',
1032 default=['source-name', '_snapshot-%s'],
1033 help="A reference to existing snapshot for snapshot manage. "
1034 "It contains two elements, the first is ref type "
1035 "(like 'source-name', 'source-id', etc), the second is "
1036 "snapshot name template used in storage backend"),
Andrew Kerrfcb0b682016-04-01 16:01:34 -04001037 cfg.StrOpt('min_microversion',
1038 default=None,
1039 help="Lower version of the test target microversion range. "
1040 "The format is 'X.Y', where 'X' and 'Y' are int values. "
1041 "Tempest selects tests based on the range between "
1042 "min_microversion and max_microversion. "
1043 "If both values are not specified, Tempest avoids tests "
1044 "which require a microversion. Valid values are string "
1045 "with format 'X.Y' or string 'latest'",),
1046 cfg.StrOpt('max_microversion',
1047 default=None,
1048 help="Upper version of the test target microversion range. "
1049 "The format is 'X.Y', where 'X' and 'Y' are int values. "
1050 "Tempest selects tests based on the range between "
1051 "min_microversion and max_microversion. "
1052 "If both values are not specified, Tempest avoids tests "
1053 "which require a microversion. Valid values are string "
1054 "with format 'X.Y' or string 'latest'",),
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001055]
K Jonathan Harkerd6ba4b42012-12-18 13:50:47 -08001056
Matthew Treinishd5c96022013-10-17 21:51:23 +00001057volume_feature_group = cfg.OptGroup(name='volume-feature-enabled',
1058 title='Enabled Cinder Features')
1059
1060VolumeFeaturesGroup = [
1061 cfg.BoolOpt('multi_backend',
1062 default=False,
Matthew Treinishe3d26142013-11-26 19:14:58 +00001063 help="Runs Cinder multi-backend test (requires 2 backends)"),
Giulio Fidente74b08ad2014-01-18 04:02:51 +01001064 cfg.BoolOpt('backup',
1065 default=True,
1066 help='Runs Cinder volumes backup test'),
JordanPbce55532014-03-19 12:10:32 +01001067 cfg.BoolOpt('snapshot',
1068 default=True,
1069 help='Runs Cinder volume snapshot test'),
Takeaki Matsumoto1702aed2015-08-25 08:44:26 +09001070 cfg.BoolOpt('clone',
1071 default=True,
1072 help='Runs Cinder volume clone test'),
Jordan Pittier31256252017-01-11 14:29:49 +01001073 cfg.BoolOpt('manage_snapshot',
1074 default=False,
1075 help='Runs Cinder manage snapshot tests'),
jeremy.zhangf4fbf302017-03-22 11:25:53 +08001076 cfg.BoolOpt('manage_volume',
1077 default=False,
1078 help='Runs Cinder manage volume tests'),
Matthew Treinishe3d26142013-11-26 19:14:58 +00001079 cfg.ListOpt('api_extensions',
1080 default=['all'],
Zhi Kun Liude25c022014-02-14 13:25:19 +08001081 help='A list of enabled volume extensions with a special '
Simeon Monov5d7effe2014-07-16 07:32:38 +03001082 'entry all which indicates every extension is enabled. '
1083 'Empty list indicates all extensions are disabled'),
Matt Riedemann0cc76bf2017-07-05 17:29:31 -04001084 cfg.BoolOpt('extend_attached_volume',
1085 default=False,
1086 help='Does the cloud support extending the size of a volume '
1087 'which is currently attached to a server instance? This '
1088 'depends on the 3.42 volume API microversion and the '
1089 '2.51 compute API microversion. Also, not all volume or '
Lee Yarwood4bd9edb2020-01-31 17:26:25 +00001090 'compute backends support this operation.'),
1091 cfg.BoolOpt('extend_attached_encrypted_volume',
1092 default=False,
1093 help='Does the cloud support extending the size of an '
1094 'encrypted volume which is currently attached to a '
1095 'server instance? This depends on the 3.42 volume API '
1096 'microversion and the 2.51 compute API microversion. '
1097 'Also, not all volume or compute backends support this '
1098 'operation.')
Matthew Treinishd5c96022013-10-17 21:51:23 +00001099]
1100
Daryl Walleck587385b2012-03-03 13:00:26 -06001101
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001102object_storage_group = cfg.OptGroup(name='object-storage',
1103 title='Object Storage Service Options')
Attila Fazekasa23f5002012-10-23 19:32:45 +02001104
DennyZhang1e71b612013-09-26 12:35:40 -05001105ObjectStoreGroup = [
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001106 cfg.StrOpt('catalog_type',
1107 default='object-store',
1108 help="Catalog type of the Object-Storage service."),
Arata Notsu8f440392013-09-13 16:14:20 +09001109 cfg.StrOpt('region',
1110 default='',
1111 help="The object-storage region name to use. If empty, the "
1112 "value of identity.region is used instead. If no such "
1113 "region is found in the service catalog, the first found "
1114 "one is used."),
JordanP5d29b2c2013-12-18 13:56:03 +00001115 cfg.StrOpt('endpoint_type',
1116 default='publicURL',
1117 choices=['public', 'admin', 'internal',
1118 'publicURL', 'adminURL', 'internalURL'],
1119 help="The endpoint type to use for the object-store service."),
Matthew Treinishf319a732013-10-24 21:39:24 +00001120 cfg.IntOpt('container_sync_timeout',
Daisuke Morita1ac3ee02014-08-25 12:59:18 +09001121 default=600,
Fabien Boucher2178d312013-12-31 15:38:57 +01001122 help="Number of seconds to time on waiting for a container "
nayna-patelb4989b32013-01-09 06:25:13 +00001123 "to container synchronization complete."),
Matthew Treinishf319a732013-10-24 21:39:24 +00001124 cfg.IntOpt('container_sync_interval',
nayna-patelb4989b32013-01-09 06:25:13 +00001125 default=5,
Fabien Boucher2178d312013-12-31 15:38:57 +01001126 help="Number of seconds to wait while looping to check the "
nayna-patelb4989b32013-01-09 06:25:13 +00001127 "status of a container to container synchronization"),
Matthew Treinish3fdb80c2013-08-15 11:13:19 -04001128 cfg.StrOpt('operator_role',
Martin Kopec99d4dae2020-05-27 10:33:17 +00001129 default='member',
Matthew Treinish3fdb80c2013-08-15 11:13:19 -04001130 help="Role to add to users created for swift tests to "
1131 "enable creating containers"),
Matthew Treinish998c91d2014-03-01 12:39:49 -05001132 cfg.StrOpt('reseller_admin_role',
1133 default='ResellerAdmin',
1134 help="User role that has reseller admin"),
Daisuke Morita1ac3ee02014-08-25 12:59:18 +09001135 cfg.StrOpt('realm_name',
1136 default='realm1',
1137 help="Name of sync realm. A sync realm is a set of clusters "
1138 "that have agreed to allow container syncing with each "
1139 "other. Set the same realm name as Swift's "
1140 "container-sync-realms.conf"),
1141 cfg.StrOpt('cluster_name',
1142 default='name1',
1143 help="One name of cluster which is set in the realm whose name "
1144 "is set in 'realm_name' item in this file. Set the "
1145 "same cluster name as Swift's container-sync-realms.conf"),
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001146]
Attila Fazekasa23f5002012-10-23 19:32:45 +02001147
Matthew Treinishd5c96022013-10-17 21:51:23 +00001148object_storage_feature_group = cfg.OptGroup(
1149 name='object-storage-feature-enabled',
1150 title='Enabled object-storage features')
1151
1152ObjectStoreFeaturesGroup = [
Matthew Treinish20345382013-12-13 17:04:23 +00001153 cfg.ListOpt('discoverable_apis',
1154 default=['all'],
1155 help="A list of the enabled optional discoverable apis. "
1156 "A single entry, all, indicates that all of these "
1157 "features are expected to be enabled"),
Daisuke Morita20a183f2014-08-25 14:43:36 +09001158 cfg.BoolOpt('container_sync',
1159 default=True,
1160 help="Execute (old style) container-sync tests"),
1161 cfg.BoolOpt('object_versioning',
1162 default=True,
1163 help="Execute object-versioning tests"),
1164 cfg.BoolOpt('discoverability',
1165 default=True,
1166 help="Execute discoverability tests"),
Giulio Fidente95758b12022-07-14 15:14:24 +02001167 cfg.StrOpt('tempurl_digest_hashlib',
1168 default='sha256',
1169 help="Hashing algorithm to use for the temp_url tests. "
1170 "Needs to be supported both by Swift and the "
1171 "hashlib module, for example sha1 or sha256"),
Matthew Treinishd5c96022013-10-17 21:51:23 +00001172]
1173
Luigi Toscano14d172d2015-01-23 16:37:47 +01001174
Masayuki Igawa73d9f3a2013-05-24 10:30:01 +09001175scenario_group = cfg.OptGroup(name='scenario', title='Scenario Test Options')
1176
1177ScenarioGroup = [
Alessandro Pilottib7c1daa2014-08-16 14:24:13 +03001178 cfg.StrOpt('img_file', deprecated_name='qcow2_img_file',
Martin Kopec02af6a42020-03-03 12:39:12 +00001179 default='/opt/stack/new/devstack/files/images'
1180 '/cirros-0.3.1-x86_64-disk.img',
1181 help='Image full path.'),
Alessandro Pilottib7c1daa2014-08-16 14:24:13 +03001182 cfg.StrOpt('img_disk_format',
1183 default='qcow2',
1184 help='Image disk format'),
1185 cfg.StrOpt('img_container_format',
1186 default='bare',
1187 help='Image container format'),
Evgeny Antyshev7ba0d5f2015-04-28 13:18:07 +00001188 cfg.DictOpt('img_properties', help='Glance image properties. '
1189 'Use for custom images which require them'),
Yair Fried413bf2d2014-11-19 17:07:11 +02001190 # TODO(yfried): add support for dhcpcd
1191 cfg.StrOpt('dhcp_client',
1192 default='udhcpc',
Yaroslav Lobankovceae2042015-09-09 19:25:14 +03001193 choices=["udhcpc", "dhclient", ""],
Yair Fried413bf2d2014-11-19 17:07:11 +02001194 help='DHCP client used by images to renew DCHP lease. '
1195 'If left empty, update operation will be skipped. '
Claudiu Belu33c3e602014-08-28 16:38:01 +03001196 'Supported clients: "udhcpc", "dhclient"'),
1197 cfg.StrOpt('protocol',
1198 default='icmp',
1199 choices=('icmp', 'tcp', 'udp'),
1200 help='The protocol used in security groups tests to check '
1201 'connectivity.'),
Masayuki Igawa73d9f3a2013-05-24 10:30:01 +09001202]
1203
1204
Matthew Treinish4c412922013-07-16 15:27:42 -04001205service_available_group = cfg.OptGroup(name="service_available",
1206 title="Available OpenStack Services")
1207
1208ServiceAvailableGroup = [
1209 cfg.BoolOpt('cinder',
1210 default=True,
1211 help="Whether or not cinder is expected to be available"),
Matthew Treinishfaa340d2013-07-19 16:26:21 -04001212 cfg.BoolOpt('neutron',
1213 default=False,
1214 help="Whether or not neutron is expected to be available"),
Matthew Treinish853ae442013-07-19 16:36:07 -04001215 cfg.BoolOpt('glance',
1216 default=True,
1217 help="Whether or not glance is expected to be available"),
Matthew Treinish61e332b2013-07-19 16:42:31 -04001218 cfg.BoolOpt('swift',
1219 default=True,
1220 help="Whether or not swift is expected to be available"),
Matthew Treinish6b41e242013-07-19 16:49:28 -04001221 cfg.BoolOpt('nova',
1222 default=True,
1223 help="Whether or not nova is expected to be available"),
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001224 cfg.BoolOpt('horizon',
1225 default=True,
1226 help="Whether or not horizon is expected to be available"),
Matthew Treinish4c412922013-07-16 15:27:42 -04001227]
1228
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001229enforce_scope_group = cfg.OptGroup(name="enforce_scope",
1230 title="OpenStack Services with "
1231 "enforce scope")
1232
1233
1234EnforceScopeGroup = [
1235 cfg.BoolOpt('nova',
1236 default=False,
1237 help='Does the compute service API policies enforce scope? '
1238 'This configuration value should be same as '
1239 'nova.conf: [oslo_policy].enforce_scope option.'),
1240 cfg.BoolOpt('neutron',
1241 default=False,
1242 help='Does the network service API policies enforce scope? '
1243 'This configuration value should be same as '
1244 'neutron.conf: [oslo_policy].enforce_scope option.'),
1245 cfg.BoolOpt('glance',
1246 default=False,
1247 help='Does the Image service API policies enforce scope? '
1248 'This configuration value should be same as '
1249 'glance.conf: [oslo_policy].enforce_scope option.'),
1250 cfg.BoolOpt('cinder',
1251 default=False,
1252 help='Does the Volume service API policies enforce scope? '
1253 'This configuration value should be same as '
1254 'cinder.conf: [oslo_policy].enforce_scope option.'),
1255 cfg.BoolOpt('keystone',
1256 default=False,
1257 help='Does the Identity service API policies enforce scope? '
1258 'This configuration value should be same as '
1259 'keystone.conf: [oslo_policy].enforce_scope option.'),
1260]
1261
Attila Fazekasaeeeefd2013-08-06 17:01:56 +02001262debug_group = cfg.OptGroup(name="debug",
1263 title="Debug System")
1264
1265DebugGroup = [
Sean Daguec522c092014-03-24 10:43:22 -04001266 cfg.StrOpt('trace_requests',
1267 default='',
1268 help="""A regex to determine which requests should be traced.
1269
1270This is a regex to match the caller for rest client requests to be able to
1271selectively trace calls out of specific classes and methods. It largely
1272exists for test development, and is not expected to be used in a real deploy
1273of tempest. This will be matched against the discovered ClassName:method
1274in the test environment.
1275
1276Expected values for this field are:
1277
1278 * ClassName:test_method_name - traces one test_method
1279 * ClassName:setUp(Class) - traces specific setup functions
1280 * ClassName:tearDown(Class) - traces specific teardown functions
1281 * ClassName:_run_cleanups - traces the cleanup functions
1282
1283If nothing is specified, this feature is not enabled. To trace everything
1284specify .* as the regex.
1285""")
Attila Fazekasaeeeefd2013-08-06 17:01:56 +02001286]
1287
Ilya Shakhat1291bb42017-11-29 18:08:16 +01001288
1289profiler_group = cfg.OptGroup(name="profiler",
1290 title="OpenStack Profiler")
1291
1292ProfilerGroup = [
1293 cfg.StrOpt('key',
1294 help="The secret key to enable OpenStack Profiler. The value "
1295 "should match the one configured in OpenStack services "
1296 "under `[profiler]/hmac_keys` property. The default empty "
1297 "value keeps profiling disabled"),
1298]
1299
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001300DefaultGroup = [
Martin Kopecae155b72017-06-26 09:41:21 +00001301 cfg.BoolOpt('pause_teardown',
1302 default=False,
1303 help="""Whether to pause a test in global teardown.
1304
1305The best use case is investigating used resources of one test.
1306A test can be run as follows:
Soniya Vyase42bd932019-11-26 16:14:33 +05301307 $ stestr run --pdb TEST_ID
Martin Kopecae155b72017-06-26 09:41:21 +00001308or
1309 $ python -m testtools.run TEST_ID"""),
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001310]
1311
Jon Grimm270bd7f2014-08-05 18:11:29 +00001312_opts = [
1313 (auth_group, AuthGroup),
1314 (compute_group, ComputeGroup),
1315 (compute_features_group, ComputeFeaturesGroup),
1316 (identity_group, IdentityGroup),
zhufl071e94c2016-07-12 10:26:34 +08001317 (service_clients_group, ServiceClientsGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001318 (identity_feature_group, IdentityFeatureGroup),
1319 (image_group, ImageGroup),
1320 (image_feature_group, ImageFeaturesGroup),
1321 (network_group, NetworkGroup),
1322 (network_feature_group, NetworkFeaturesGroup),
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001323 (dashboard_group, DashboardGroup),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001324 (validation_group, ValidationGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001325 (volume_group, VolumeGroup),
1326 (volume_feature_group, VolumeFeaturesGroup),
1327 (object_storage_group, ObjectStoreGroup),
1328 (object_storage_feature_group, ObjectStoreFeaturesGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001329 (scenario_group, ScenarioGroup),
1330 (service_available_group, ServiceAvailableGroup),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001331 (enforce_scope_group, EnforceScopeGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001332 (debug_group, DebugGroup),
Lajos Katonaceb88212018-11-30 14:54:12 +01001333 (placement_group, PlacementGroup),
Ilya Shakhat1291bb42017-11-29 18:08:16 +01001334 (profiler_group, ProfilerGroup),
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001335 (None, DefaultGroup)
Jon Grimm270bd7f2014-08-05 18:11:29 +00001336]
1337
Roman Prykhodchenko62b1ed12013-10-16 21:51:47 +03001338
Matthew Treinish43b296a2014-02-28 15:23:00 -05001339def register_opts():
Matthew Treinisha966d0f2015-07-01 17:37:31 -04001340 ext_plugins = plugins.TempestTestPluginManager()
1341 # Register in-tree tempest config options
Jon Grimm270bd7f2014-08-05 18:11:29 +00001342 for g, o in _opts:
Maru Newbyf440c292015-03-31 15:58:47 +00001343 register_opt_group(_CONF, g, o)
Matthew Treinisha966d0f2015-07-01 17:37:31 -04001344 # Call external plugin config option registration
1345 ext_plugins.register_plugin_opts(_CONF)
Jon Grimm270bd7f2014-08-05 18:11:29 +00001346
1347
1348def list_opts():
1349 """Return a list of oslo.config options available.
1350
1351 The purpose of this is to allow tools like the Oslo sample config file
1352 generator to discover the options exposed to users.
1353 """
Matthew Treinish83a19aa2015-07-23 13:06:13 -04001354 ext_plugins = plugins.TempestTestPluginManager()
Chris Hoged7b4fd12015-11-11 10:24:52 -08001355 # Make a shallow copy of the options list that can be
1356 # extended by plugins. Send back the group object
1357 # to allow group help text to be generated.
1358 opt_list = [(g, o) for g, o in _opts]
Matthew Treinish83a19aa2015-07-23 13:06:13 -04001359 opt_list.extend(ext_plugins.get_plugin_options_list())
1360 return opt_list
Matthew Treinish43b296a2014-02-28 15:23:00 -05001361
1362
Ken'ichi Ohmichi3f5c1392018-04-11 14:38:22 -07001363# This should never be called outside of this module
Sean Dague3b9b1f32013-12-20 17:04:54 -05001364class TempestConfigPrivate(object):
Daryl Walleck1465d612011-11-02 02:22:15 -05001365 """Provides OpenStack configuration information."""
1366
David Patersonbe9f9832015-10-15 09:10:45 -07001367 DEFAULT_CONFIG_DIR = os.path.join(os.getcwd(), "etc")
Daryl Walleck1465d612011-11-02 02:22:15 -05001368
Brian Waldon738cd632011-12-12 18:45:09 -05001369 DEFAULT_CONFIG_FILE = "tempest.conf"
1370
Andrea Frittolia96ee212014-08-15 18:34:20 +01001371 def __getattr__(self, attr):
1372 # Handles config options from the default group
Maru Newbyf440c292015-03-31 15:58:47 +00001373 return getattr(_CONF, attr)
Andrea Frittolia96ee212014-08-15 18:34:20 +01001374
Matthew Treinish43b296a2014-02-28 15:23:00 -05001375 def _set_attrs(self):
Andrea Frittoli382a6f12017-03-09 11:52:17 +00001376 # This methods ensures that config options in Tempest as well as
1377 # in Tempest plugins can be accessed via:
1378 # CONF.<normalised_group_name>.<key_name>
1379 # where:
1380 # normalised_group_name = group_name.replace('-', '_')
1381 # Attributes are set at __init__ time *only* for known option groups
Maru Newbyf440c292015-03-31 15:58:47 +00001382 self.auth = _CONF.auth
1383 self.compute = _CONF.compute
1384 self.compute_feature_enabled = _CONF['compute-feature-enabled']
1385 self.identity = _CONF.identity
zhufl071e94c2016-07-12 10:26:34 +08001386 self.service_clients = _CONF['service-clients']
Maru Newbyf440c292015-03-31 15:58:47 +00001387 self.identity_feature_enabled = _CONF['identity-feature-enabled']
1388 self.image = _CONF.image
1389 self.image_feature_enabled = _CONF['image-feature-enabled']
1390 self.network = _CONF.network
1391 self.network_feature_enabled = _CONF['network-feature-enabled']
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001392 self.dashboard = _CONF.dashboard
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001393 self.validation = _CONF.validation
Maru Newbyf440c292015-03-31 15:58:47 +00001394 self.volume = _CONF.volume
1395 self.volume_feature_enabled = _CONF['volume-feature-enabled']
1396 self.object_storage = _CONF['object-storage']
1397 self.object_storage_feature_enabled = _CONF[
Matthew Treinishd5c96022013-10-17 21:51:23 +00001398 'object-storage-feature-enabled']
Maru Newbyf440c292015-03-31 15:58:47 +00001399 self.scenario = _CONF.scenario
1400 self.service_available = _CONF.service_available
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001401 self.enforce_scope = _CONF.enforce_scope
Maru Newbyf440c292015-03-31 15:58:47 +00001402 self.debug = _CONF.debug
Matthew Treinish46008082015-04-14 18:32:47 -04001403 logging.tempest_set_log_file('tempest.log')
Andrea Frittoli382a6f12017-03-09 11:52:17 +00001404 # Setting attributes for plugins
1405 # NOTE(andreaf) Plugins have no access to the TempestConfigPrivate
1406 # instance at discovery time, so they have no way of setting these
1407 # aliases themselves.
1408 ext_plugins = plugins.TempestTestPluginManager()
1409 for group, _ in ext_plugins.get_plugin_options_list():
1410 if isinstance(group, cfg.OptGroup):
1411 # If we have an OptGroup
1412 group_name = group.name
1413 group_dest = group.dest
1414 else:
1415 # If we have a group name as a string
1416 group_name = group
1417 group_dest = group.replace('-', '_')
1418 # NOTE(andreaf) We can set the attribute safely here since in
1419 # case of name conflict we would not have reached this point.
1420 setattr(self, group_dest, _CONF[group_name])
Sean Dague86bd8422013-12-20 09:56:44 -05001421
Joe Gordon28a84ae2014-07-17 15:38:28 +00001422 def __init__(self, parse_conf=True, config_path=None):
Matthew Treinish43b296a2014-02-28 15:23:00 -05001423 """Initialize a configuration from a conf directory and conf file."""
1424 super(TempestConfigPrivate, self).__init__()
1425 config_files = []
1426 failsafe_path = "/etc/tempest/" + self.DEFAULT_CONFIG_FILE
1427
Joe Gordon28a84ae2014-07-17 15:38:28 +00001428 if config_path:
1429 path = config_path
1430 else:
1431 # Environment variables override defaults...
1432 conf_dir = os.environ.get('TEMPEST_CONFIG_DIR',
1433 self.DEFAULT_CONFIG_DIR)
1434 conf_file = os.environ.get('TEMPEST_CONFIG',
1435 self.DEFAULT_CONFIG_FILE)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001436
Joe Gordon28a84ae2014-07-17 15:38:28 +00001437 path = os.path.join(conf_dir, conf_file)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001438
1439 if not os.path.isfile(path):
1440 path = failsafe_path
1441
1442 # only parse the config file if we expect one to exist. This is needed
1443 # to remove an issue with the config file up to date checker.
1444 if parse_conf:
1445 config_files.append(path)
Maru Newbyf440c292015-03-31 15:58:47 +00001446 logging.register_options(_CONF)
Matthew Treinish5440a402014-10-02 14:36:16 -04001447 if os.path.isfile(path):
Maru Newbyf440c292015-03-31 15:58:47 +00001448 _CONF([], project='tempest', default_config_files=config_files)
Matthew Treinish5440a402014-10-02 14:36:16 -04001449 else:
Maru Newbyf440c292015-03-31 15:58:47 +00001450 _CONF([], project='tempest')
Marc Kodererc81c7672015-12-17 12:10:12 +01001451
1452 logging_cfg_path = "%s/logging.conf" % os.path.dirname(path)
Tom Patzige6f7c7d2016-02-17 16:46:11 +01001453 if ((not hasattr(_CONF, 'log_config_append') or
afazekas40fcb9b2019-03-08 11:25:11 +01001454 _CONF.log_config_append is None) and
Marc Kodererc81c7672015-12-17 12:10:12 +01001455 os.path.isfile(logging_cfg_path)):
1456 # if logging conf is in place we need to set log_config_append
1457 _CONF.log_config_append = logging_cfg_path
1458
Maru Newbyf440c292015-03-31 15:58:47 +00001459 logging.setup(_CONF, 'tempest')
Matthew Treinish43b296a2014-02-28 15:23:00 -05001460 LOG = logging.getLogger('tempest')
Jordan Pittier525ec712016-12-07 17:51:26 +01001461 LOG.info("Using tempest config file %s", path)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001462 register_opts()
1463 self._set_attrs()
Masayuki Igawa9ec4cd82014-02-05 15:04:16 +09001464 if parse_conf:
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301465 _CONF.log_opt_values(LOG, logging.DEBUG)
Masayuki Igawa9ec4cd82014-02-05 15:04:16 +09001466
Sean Dague86bd8422013-12-20 09:56:44 -05001467
1468class TempestConfigProxy(object):
1469 _config = None
Joe Gordon28a84ae2014-07-17 15:38:28 +00001470 _path = None
Sean Dague86bd8422013-12-20 09:56:44 -05001471
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001472 _extra_log_defaults = [
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301473 ('paramiko.transport', logging.INFO),
1474 ('requests.packages.urllib3.connectionpool', logging.WARN),
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001475 ]
1476
1477 def _fix_log_levels(self):
1478 """Tweak the oslo log defaults."""
Doug Hellmann583ce2c2015-03-11 14:55:46 +00001479 for name, level in self._extra_log_defaults:
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301480 logging.getLogger(name).logger.setLevel(level)
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001481
Sean Dague86bd8422013-12-20 09:56:44 -05001482 def __getattr__(self, attr):
1483 if not self._config:
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001484 self._fix_log_levels()
Matthew Treinishaa29c7e2015-04-23 16:35:09 -04001485 lock_dir = os.path.join(tempfile.gettempdir(), 'tempest-lock')
1486 lockutils.set_defaults(lock_dir)
Joe Gordon28a84ae2014-07-17 15:38:28 +00001487 self._config = TempestConfigPrivate(config_path=self._path)
Sean Dague86bd8422013-12-20 09:56:44 -05001488
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001489 # Pushing tempest internal service client configuration to the
1490 # service clients register. Doing this in the config module ensures
1491 # that the configuration is available by the time we register the
1492 # service clients.
1493 # NOTE(andreaf) This has to be done at the time the first
1494 # attribute is accessed, to ensure all plugins have been already
1495 # loaded, options registered, and _config is set.
1496 _register_tempest_service_clients()
1497
Andrea Frittoli8b23c792017-03-09 13:17:01 +00001498 # Registering service clients and pushing their configuration to
1499 # the service clients register. Doing this in the config module
1500 # ensures that the configuration is available by the time we
1501 # discover tests from plugins.
1502 plugins.TempestTestPluginManager()._register_service_clients()
1503
Sean Dague86bd8422013-12-20 09:56:44 -05001504 return getattr(self._config, attr)
1505
Joe Gordon28a84ae2014-07-17 15:38:28 +00001506 def set_config_path(self, path):
1507 self._path = path
Masayuki Igawa79159f82018-07-27 15:00:37 +09001508 # FIXME(masayukig): bug#1783751 To pass the config file path to child
1509 # processes, we need to set the environment variables here as a
1510 # workaround.
1511 os.environ['TEMPEST_CONFIG_DIR'] = os.path.dirname(path)
1512 os.environ['TEMPEST_CONFIG'] = os.path.basename(path)
Joe Gordon28a84ae2014-07-17 15:38:28 +00001513
Sean Dague86bd8422013-12-20 09:56:44 -05001514
1515CONF = TempestConfigProxy()
Matthew Treinishca5a9ff2016-04-16 15:04:34 -04001516
1517
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001518def service_client_config(service_client_name=None):
1519 """Return a dict with the parameters to init service clients
1520
1521 Extracts from CONF the settings specific to the service_client_name and
1522 api_version, and formats them as dict ready to be passed to the service
1523 clients __init__:
1524
1525 * `region` (default to identity)
1526 * `catalog_type`
1527 * `endpoint_type`
1528 * `build_timeout` (object-storage and identity default to compute)
1529 * `build_interval` (object-storage and identity default to compute)
1530
1531 The following common settings are always returned, even if
1532 `service_client_name` is None:
1533
1534 * `disable_ssl_certificate_validation`
1535 * `ca_certs`
1536 * `trace_requests`
zhufl071e94c2016-07-12 10:26:34 +08001537 * `http_timeout`
Matthew Treinish74514402016-09-01 11:44:57 -04001538 * `proxy_url`
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001539
1540 The dict returned by this does not fit a few service clients:
1541
1542 * The endpoint type is not returned for identity client, since it takes
1543 three different values for v2 admin, v2 public and v3
1544 * The `ServersClient` from compute accepts an optional
1545 `enable_instance_password` parameter, which is not returned.
1546 * The `VolumesClient` for both v1 and v2 volume accept an optional
1547 `default_volume_size` parameter, which is not returned.
1548 * The `TokenClient` and `V3TokenClient` have a very different
1549 interface, only auth_url is needed for them.
1550
1551 :param service_client_name: str Name of the service. Supported values are
1552 'compute', 'identity', 'image', 'network', 'object-storage', 'volume'
1553 :return: dictionary of __init__ parameters for the service clients
1554 :rtype: dict
1555 """
1556 _parameters = {
1557 'disable_ssl_certificate_validation':
Daniel Melladocad3f3d2016-08-19 14:17:16 +00001558 CONF.identity.disable_ssl_certificate_validation,
1559 'ca_certs': CONF.identity.ca_certificates_file,
zhufl071e94c2016-07-12 10:26:34 +08001560 'trace_requests': CONF.debug.trace_requests,
Matthew Treinish74514402016-09-01 11:44:57 -04001561 'http_timeout': CONF.service_clients.http_timeout,
1562 'proxy_url': CONF.service_clients.proxy_url,
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001563 }
1564
1565 if service_client_name is None:
1566 return _parameters
1567
1568 # Get the group of options first, by normalising the service_group_name
1569 # Services with a '-' in the name have an '_' in the option group name
1570 config_group = service_client_name.replace('-', '_')
1571 # NOTE(andreaf) Check if the config group exists. This allows for this
1572 # helper to be used for settings from registered plugins as well
1573 try:
1574 options = getattr(CONF, config_group)
1575 except cfg.NoSuchOptError:
1576 # Option group not defined
1577 raise exceptions.UnknownServiceClient(services=service_client_name)
1578 # Set endpoint_type
1579 # Identity uses different settings depending on API version, so do not
1580 # return the endpoint at all.
1581 if service_client_name != 'identity':
1582 _parameters['endpoint_type'] = getattr(options, 'endpoint_type')
1583 # Set build_*
1584 # Object storage and identity groups do not have conf settings for
1585 # build_* parameters, and we default to compute in any case
1586 for setting in ['build_timeout', 'build_interval']:
1587 if not hasattr(options, setting) or not getattr(options, setting):
1588 _parameters[setting] = getattr(CONF.compute, setting)
1589 else:
1590 _parameters[setting] = getattr(options, setting)
1591 # Set region
1592 # If a service client does not define region or region is not set
1593 # default to the identity region
1594 if not hasattr(options, 'region') or not getattr(options, 'region'):
1595 _parameters['region'] = CONF.identity.region
1596 else:
1597 _parameters['region'] = getattr(options, 'region')
1598 # Set service
1599 _parameters['service'] = getattr(options, 'catalog_type')
1600 return _parameters
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001601
1602
1603def _register_tempest_service_clients():
1604 # Register tempest own service clients using the same mechanism used
1605 # for external plugins.
1606 # The configuration data is pushed to the registry so that automatic
1607 # configuration of tempest own service clients is possible both for
1608 # tempest as well as for the plugins.
1609 service_clients = clients.tempest_modules()
1610 registry = clients.ClientsRegistry()
1611 all_clients = []
1612 for service_client in service_clients:
1613 module = service_clients[service_client]
1614 configs = service_client.split('.')[0]
1615 service_client_data = dict(
Andrea Frittoli986407d2017-10-11 10:23:17 +00001616 name=service_client.replace('.', '_').replace('-', '_'),
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001617 service_version=service_client,
1618 module_path=module.__name__,
1619 client_names=module.__all__,
1620 **service_client_config(configs)
1621 )
1622 all_clients.append(service_client_data)
1623 # NOTE(andreaf) Internal service clients do not actually belong
1624 # to a plugin, so using '__tempest__' to indicate a virtual plugin
1625 # which holds internal service clients.
1626 registry.register_service_client('__tempest__', all_clients)