blob: 0f509fb695e064ff78154095e2a6d73699acc7ea [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 Treinishe3d26142013-11-26 19:14:58 +0000453 cfg.ListOpt('api_extensions',
454 default=['all'],
Zhi Kun Liude25c022014-02-14 13:25:19 +0800455 help='A list of enabled compute extensions with a special '
Ken'ichi Ohmichia7e68712014-05-06 10:47:26 +0900456 'entry all which indicates every extension is enabled. '
Simeon Monov5d7effe2014-07-16 07:32:38 +0300457 'Each extension should be specified with alias name. '
Matthew Treinish5078e8b2016-09-16 11:13:11 -0400458 'Empty list indicates all extensions are disabled',
459 deprecated_for_removal=True,
460 deprecated_reason='The Nova extensions API and mechanism '
461 'is deprecated. This option will be '
462 'removed when all releases supported '
463 'by tempest no longer contain the Nova '
464 'extensions API and mechanism.'),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000465 cfg.BoolOpt('change_password',
466 default=False,
467 help="Does the test environment support changing the admin "
468 "password?"),
Adam Gandelmanc6eefb42014-07-15 16:44:08 -0700469 cfg.BoolOpt('console_output',
470 default=True,
471 help="Does the test environment support obtaining instance "
472 "serial console output?"),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000473 cfg.BoolOpt('resize',
474 default=False,
Masayuki Igawad91094d2017-04-12 16:20:09 +0900475 help="Does the test environment support resizing? When you "
476 "enable this feature, 'flavor_ref_alt' should be set and "
477 "it should refer to a larger flavor than 'flavor_ref' "
478 "one."),
Eric Windischb5538072014-03-09 23:47:35 -0400479 cfg.BoolOpt('pause',
480 default=True,
481 help="Does the test environment support pausing?"),
David Shrewsbury25f666f2014-07-22 12:17:59 -0400482 cfg.BoolOpt('shelve',
483 default=True,
484 help="Does the test environment support shelving/unshelving?"),
Alexandre Arents0a9b8232020-07-29 09:52:57 +0000485 cfg.BoolOpt('shelve_migrate',
486 default=False,
487 help="Does the test environment support "
488 "cold migration of unshelved server?"),
Eric Windischaeb7e842014-03-10 01:10:50 -0400489 cfg.BoolOpt('suspend',
490 default=True,
491 help="Does the test environment support suspend/resume?"),
Ludovic Beliveauae314882016-09-15 13:34:14 -0400492 cfg.BoolOpt('cold_migration',
493 default=True,
zhufl0bad33e2016-10-14 17:21:46 +0800494 help="Does the test environment support cold migration?"),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000495 cfg.BoolOpt('live_migration',
Joe Gordon31a139a2014-11-17 16:39:04 -0800496 default=True,
zhufl0bad33e2016-10-14 17:21:46 +0800497 help="Does the test environment support live migration?"),
Sarafraj Singh61e40452016-09-29 13:06:59 -0500498 cfg.BoolOpt('live_migrate_back_and_forth',
499 default=False,
500 help="Does the test environment support live migrating "
501 "VM back and forth between different versions of "
502 "nova-compute?"),
YAMAMOTO Takashi1f62af22015-06-16 03:29:50 +0900503 cfg.BoolOpt('metadata_service',
504 default=True,
505 help="Does the test environment support metadata service? "
506 "Ignored unless validation.run_validation=true."),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000507 cfg.BoolOpt('block_migration_for_live_migration',
508 default=False,
509 help="Does the test environment use block devices for live "
510 "migration"),
511 cfg.BoolOpt('block_migrate_cinder_iscsi',
512 default=False,
Matt Riedemann8cf5f902017-04-24 11:42:48 -0400513 help="Does the test environment support block migration with "
514 "Cinder iSCSI volumes. Note: libvirt >= 1.2.17 is required "
Lee Yarwood48fe99f2020-01-27 19:18:24 +0000515 "to support this if using the libvirt compute driver.",
516 deprecated_for_removal=True,
517 deprecated_reason='This option duplicates the more generic '
518 '[compute-feature-enabled]/block_migration '
519 '_for_live_migration now that '
520 'MIN_LIBVIRT_VERSION is >= 1.2.17 on all '
521 'branches from stable/rocky and will be '
522 'removed in a future release.'),
zhuflbe052d62019-11-04 10:56:02 +0800523 cfg.BoolOpt('can_migrate_between_any_hosts',
524 default=True,
525 help="Does the test environment support migrating between "
526 "any hosts? In environments with non-homogeneous compute "
527 "nodes you can set this to False so that it will select "
528 "destination host for migrating automatically"),
Ghanshyam Mann41c17572014-02-27 18:52:56 +0900529 cfg.BoolOpt('vnc_console',
530 default=False,
531 help='Enable VNC console. This configuration value should '
zhufldc7eeb42018-09-12 11:10:16 +0800532 'be same as nova.conf: vnc.enabled'),
Alex Savatieiev82b6aeb2018-03-28 17:56:49 +0200533 cfg.StrOpt('vnc_server_header',
534 default='WebSockify',
535 help='Expected VNC server name (WebSockify, nginx, etc) '
Leo Henkenfd01d152019-08-02 11:42:52 -0500536 'in response header.',
537 deprecated_for_removal=True,
538 deprecated_reason='This option will be ignored because the '
539 'usage of different response header fields '
540 'to accomplish the same goal (in accordance '
541 'with RFC7231 S6.2.2) makes it obsolete.'),
Ghanshyam70876d02014-03-11 11:40:18 +0900542 cfg.BoolOpt('spice_console',
543 default=False,
544 help='Enable Spice console. This configuration value should '
zhufld5bda712019-11-01 14:01:01 +0800545 'be same as nova.conf: spice.enabled',
546 deprecated_for_removal=True,
547 deprecated_reason="This config option is not being used "
548 "in Tempest, we can add it back when "
549 "adding the test cases."),
Ghanshyam70876d02014-03-11 11:40:18 +0900550 cfg.BoolOpt('rdp_console',
551 default=False,
552 help='Enable RDP console. This configuration value should '
zhufld5bda712019-11-01 14:01:01 +0800553 'be same as nova.conf: rdp.enabled',
554 deprecated_for_removal=True,
555 deprecated_reason="This config option is not being used "
556 "in Tempest, we can add it back when "
557 "adding the test cases."),
Markus Zoeller69d58b82017-02-17 10:09:22 +0100558 cfg.BoolOpt('serial_console',
559 default=False,
560 help='Enable serial console. This configuration value '
zhufldc7eeb42018-09-12 11:10:16 +0800561 'should be the same as '
562 'nova.conf: serial_console.enabled'),
Adam Gandelman2e37b4f2014-06-18 17:34:21 -0700563 cfg.BoolOpt('rescue',
564 default=True,
565 help='Does the test environment support instance rescue '
Ghanshyam9c2e50d2014-07-22 21:32:05 +0900566 'mode?'),
Lee Yarwoodc0ad55c2019-12-06 13:39:19 +0000567 cfg.BoolOpt('stable_rescue',
568 default=False,
569 help='Does the test environment support stable device '
570 'instance rescue mode?'),
Ghanshyam9c2e50d2014-07-22 21:32:05 +0900571 cfg.BoolOpt('enable_instance_password',
572 default=True,
573 help='Enables returning of the instance password by the '
574 'relevant server API calls such as create, rebuild '
zhufle8a703b2016-09-09 15:23:03 +0800575 'or rescue. This configuration value should be same as '
576 'nova.conf: DEFAULT.enable_instance_password'),
Adam Gandelman7186f7a2014-07-23 09:28:56 -0400577 cfg.BoolOpt('interface_attach',
578 default=True,
579 help='Does the test environment support dynamic network '
Adam Gandelmanfbc95ac2014-06-19 17:33:43 -0700580 'interface attachment?'),
581 cfg.BoolOpt('snapshot',
582 default=True,
583 help='Does the test environment support creating snapshot '
Matthew Treinishdfd7ac02015-02-09 17:47:31 -0500584 'images of running instances?'),
Takeaki Matsumotodf4ab7c2015-08-25 17:49:23 +0900585 cfg.BoolOpt('nova_cert',
Sean Dague6943acb2016-08-08 15:28:17 -0400586 default=False,
587 help='Does the test environment have the nova cert running?',
Ken'ichi Ohmichid65cf9c2016-11-23 16:56:04 -0800588 deprecated_for_removal=True,
589 deprecated_reason="On Nova side, the nova-cert service is "
590 "deprecated and the service will be removed "
591 "as early as Ocata."),
Takeaki Matsumotod7e04b22015-09-04 15:13:38 +0900592 cfg.BoolOpt('personality',
Matt Riedemann0baba702016-07-03 19:24:08 -0400593 default=False,
Takeaki Matsumotod7e04b22015-09-04 15:13:38 +0900594 help='Does the test environment support server personality'),
Matt Riedemann79b3b492015-06-20 14:20:44 -0700595 cfg.BoolOpt('attach_encrypted_volume',
596 default=True,
597 help='Does the test environment support attaching an '
598 'encrypted volume to a running server instance? This may '
599 'depend on the combination of compute_driver in nova and '
600 'the volume_driver(s) in cinder.'),
Alexander Gubanov509e2842015-06-09 15:29:51 +0300601 cfg.BoolOpt('config_drive',
602 default=True,
603 help='Enable special configuration drive with metadata.'),
Artom Lifshitz595ae162018-05-23 10:19:18 -0400604 cfg.ListOpt('scheduler_enabled_filters',
Artom Lifshitz1c976a92019-06-17 15:30:18 -0400605 default=["AvailabilityZoneFilter", "ComputeFilter",
606 "ComputeCapabilitiesFilter", "ImagePropertiesFilter",
Artom Lifshitz595ae162018-05-23 10:19:18 -0400607 "ServerGroupAntiAffinityFilter",
608 "ServerGroupAffinityFilter"],
609 help="A list of enabled filters that Nova will accept as "
610 "hints to the scheduler when creating a server. If the "
ghanshyam5817e142016-12-01 11:38:46 +0900611 "default value is overridden in nova.conf by the test "
612 "environment (which means that a different set of "
613 "filters is enabled than what is included in Nova by "
Artom Lifshitz595ae162018-05-23 10:19:18 -0400614 "default), then this option must be configured to "
ghanshyam5817e142016-12-01 11:38:46 +0900615 "contain the same filters that Nova uses in the test "
Artom Lifshitz595ae162018-05-23 10:19:18 -0400616 "environment. A special entry 'all' indicates all "
617 "filters that are included with Nova are enabled. If "
618 "using 'all', be sure to enable all filters in "
619 "nova.conf, as tests can fail in unpredictable ways if "
620 "Nova's and Tempest's enabled filters don't match. "
621 "Empty list indicates all filters are disabled. The "
622 "full list of enabled filters is in nova.conf: "
623 "filter_scheduler.enabled_filters.",
624 deprecated_opts=[cfg.DeprecatedOpt(
625 'scheduler_available_filters',
626 group='compute-feature-enabled')]),
Matt Riedemann342b37c2016-09-21 15:38:12 -0400627 cfg.BoolOpt('swap_volume',
628 default=False,
629 help='Does the test environment support in-place swapping of '
630 'volumes attached to a server instance?'),
melanie witt334f3132017-12-14 21:49:55 +0000631 cfg.BoolOpt('volume_backed_live_migration',
632 default=False,
633 help='Does the test environment support volume-backed live '
634 'migration?'),
Matt Riedemann81fa9b62016-01-14 13:04:38 -0800635 cfg.BoolOpt('volume_multiattach',
636 default=False,
637 help='Does the test environment support attaching a volume to '
638 'more than one instance? This depends on hypervisor and '
639 'volume backend/type and compute API version 2.60.'),
Stephen Finucane39fa9c12020-09-03 17:47:19 +0100640 cfg.BoolOpt('xenapi_apis',
641 default=False,
642 help='Does the test environment support the XenAPI-specific '
643 'APIs: os-agents, writeable server metadata and the '
644 'resetNetwork server action? '
645 'These were removed in Victoria alongside the XenAPI '
646 'virt driver.',
647 deprecated_for_removal=True,
648 deprecated_reason="On Nova side, XenAPI virt driver and the "
649 "APIs that only worked with that driver "
650 "have been removed and there's nothing to "
651 "test after Ussuri."),
Lee Yarwood56a446d2021-02-15 13:34:35 +0000652 cfg.BoolOpt('ide_bus',
653 default=True,
654 help='Does the test environment support attaching devices '
655 'using an IDE bus to the instance?'),
melanie witt74fa5052021-05-06 22:41:30 +0000656 cfg.BoolOpt('unified_limits',
657 default=False,
658 help='Does the test environment support unified limits?'),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000659]
660
661
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500662image_group = cfg.OptGroup(name='image',
663 title="Image Service Options")
Jay Pipesf38eaac2012-06-21 13:37:35 -0400664
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500665ImageGroup = [
Matthew Treinish72ea4422013-02-07 14:42:49 -0500666 cfg.StrOpt('catalog_type',
667 default='image',
Sean Dague83401992013-05-06 17:46:36 -0400668 help='Catalog type of the Image service.'),
Arata Notsu8f440392013-09-13 16:14:20 +0900669 cfg.StrOpt('region',
670 default='',
671 help="The image region name to use. If empty, the value "
672 "of identity.region is used instead. If no such region "
673 "is found in the service catalog, the first found one is "
674 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000675 cfg.StrOpt('endpoint_type',
676 default='publicURL',
677 choices=['public', 'admin', 'internal',
678 'publicURL', 'adminURL', 'internalURL'],
679 help="The endpoint type to use for the image service."),
Dan Smithd4bc9a82021-01-12 17:25:07 -0800680 cfg.StrOpt('alternate_image_endpoint',
681 default=None,
682 help="Alternate endpoint name for cross-worker testing"),
683 cfg.StrOpt('alternate_image_endpoint_type',
684 default='publicURL',
685 choices=['public', 'admin', 'internal',
686 'publicURL', 'adminURL', 'internalURL'],
687 help=("The endpoint type to use for the alternate image "
688 "service.")),
Sean Dague83401992013-05-06 17:46:36 -0400689 cfg.StrOpt('http_image',
690 default='http://download.cirros-cloud.net/0.3.1/'
691 'cirros-0.3.1-x86_64-uec.tar.gz',
Lucian Petrut1cfe2982015-01-06 13:57:36 +0200692 help='http accessible image'),
693 cfg.IntOpt('build_timeout',
694 default=300,
695 help="Timeout in seconds to wait for an image to "
696 "become available."),
697 cfg.IntOpt('build_interval',
698 default=1,
699 help="Time in seconds between image operation status "
Takashi NATSUME12a48512015-08-10 18:33:16 +0900700 "checks."),
701 cfg.ListOpt('container_formats',
702 default=['ami', 'ari', 'aki', 'bare', 'ovf', 'ova'],
703 help="A list of image's container formats "
704 "users can specify."),
705 cfg.ListOpt('disk_formats',
706 default=['ami', 'ari', 'aki', 'vhd', 'vmdk', 'raw', 'qcow2',
Benny Kopilov97c74192017-03-30 09:34:59 +0300707 'vdi', 'iso', 'vhdx'],
Takashi NATSUME12a48512015-08-10 18:33:16 +0900708 help="A list of image's disk formats "
709 "users can specify.")
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500710]
Jay Pipesf38eaac2012-06-21 13:37:35 -0400711
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000712image_feature_group = cfg.OptGroup(name='image-feature-enabled',
713 title='Enabled image service features')
714
715ImageFeaturesGroup = [
716 cfg.BoolOpt('api_v2',
717 default=True,
ghanshyam6b0b8b72017-03-08 04:22:53 +0000718 help="Is the v2 image API enabled",
719 deprecated_for_removal=True,
720 deprecated_reason='Glance v1 APIs are deprecated and v2 APIs '
721 'are current one. In future, Tempest will '
722 'test v2 APIs only so this config option '
723 'will be removed.'),
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000724 cfg.BoolOpt('api_v1',
zhufldc68af72018-09-05 15:47:39 +0800725 default=False,
ghanshyam6b0b8b72017-03-08 04:22:53 +0000726 help="Is the v1 image API enabled",
727 deprecated_for_removal=True,
728 deprecated_reason='Glance v1 APIs are deprecated and v2 APIs '
729 'are current one. In future, Tempest will '
730 'test v2 APIs only so this config option '
731 'will be removed.'),
Abhishek Kekane7cff1302020-07-16 10:30:13 +0000732 # Image import feature is setup in devstack victoria onwards.
733 # Once all stable branches setup the same via glance standalone
734 # mode or with uwsgi, we can remove this config option.
735 cfg.BoolOpt('import_image',
736 default=False,
737 help="Is image import feature enabled"),
Dan Smithe044dad2021-01-15 12:45:16 -0800738 # NOTE(danms): Starting mid-Wallaby glance began enforcing the
739 # previously-informal requirement that os_glance_* properties are
740 # reserved for internal use. Thus, we can only run these checks
741 # if we know we are on a new enough glance.
742 cfg.BoolOpt('os_glance_reserved',
743 default=False,
744 help="Should we check that os_glance namespace is reserved"),
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000745]
Jay Pipesf38eaac2012-06-21 13:37:35 -0400746
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500747network_group = cfg.OptGroup(name='network',
748 title='Network Service Options')
Daryl Walleck587385b2012-03-03 13:00:26 -0600749
Noam Angel3c6b0162018-07-08 17:05:35 +0300750ProfileType = types.Dict(types.List(types.String(), bounds=True))
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500751NetworkGroup = [
752 cfg.StrOpt('catalog_type',
753 default='network',
Mark McClainf2982e82013-07-06 17:48:03 -0400754 help='Catalog type of the Neutron service.'),
Arata Notsu8f440392013-09-13 16:14:20 +0900755 cfg.StrOpt('region',
756 default='',
757 help="The network region name to use. If empty, the value "
758 "of identity.region is used instead. If no such region "
759 "is found in the service catalog, the first found one is "
760 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000761 cfg.StrOpt('endpoint_type',
762 default='publicURL',
763 choices=['public', 'admin', 'internal',
764 'publicURL', 'adminURL', 'internalURL'],
765 help="The endpoint type to use for the network service."),
Sean Dagueed6e5862016-04-04 10:49:13 -0400766 cfg.StrOpt('project_network_cidr',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500767 default="10.100.0.0/16",
Sean Dagueed6e5862016-04-04 10:49:13 -0400768 help="The cidr block to allocate project ipv4 subnets from"),
769 cfg.IntOpt('project_network_mask_bits',
Attila Fazekas8ea181b2013-07-13 16:26:14 +0200770 default=28,
Sean Dagueed6e5862016-04-04 10:49:13 -0400771 help="The mask bits for project ipv4 subnets"),
772 cfg.StrOpt('project_network_v6_cidr',
Brian Haley56893552019-09-19 17:50:37 -0400773 default="2001:db8::/48",
Sean Dagueed6e5862016-04-04 10:49:13 -0400774 help="The cidr block to allocate project ipv6 subnets from"),
775 cfg.IntOpt('project_network_v6_mask_bits',
Sergey Shnaidman1f3659a2014-08-27 18:26:42 +0400776 default=64,
Sean Dagueed6e5862016-04-04 10:49:13 -0400777 help="The mask bits for project ipv6 subnets"),
778 cfg.BoolOpt('project_networks_reachable',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500779 default=False,
Sean Dagueed6e5862016-04-04 10:49:13 -0400780 help="Whether project networks can be reached directly from "
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000781 "the test client. This must be set to True when the "
Matt Riedemann4b0f7e72016-08-08 15:29:26 -0400782 "'fixed' connect_method is selected."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500783 cfg.StrOpt('public_network_id',
784 default="",
785 help="Id of the public network that provides external "
786 "connectivity"),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000787 cfg.StrOpt('floating_network_name',
788 help="Default floating network name. Used to allocate floating "
789 "IPs when neutron is enabled."),
Lukas Piwowarski2385e042020-01-31 12:28:20 +0000790 cfg.StrOpt('subnet_id',
791 default="",
792 help="Subnet id of subnet which is used for allocation of "
793 "floating IPs. Specify when two or more subnets are "
794 "present in network."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500795 cfg.StrOpt('public_router_id',
796 default="",
797 help="Id of the public router that provides external "
Yair Fried1eb27f52014-11-10 15:24:19 +0200798 "connectivity. This should only be used when Neutron's "
799 "'allow_overlapping_ips' is set to 'False' in "
800 "neutron.conf. usually not needed past 'Grizzly' release"),
izikpensod9a01a62014-02-17 20:02:32 +0200801 cfg.IntOpt('build_timeout',
802 default=300,
803 help="Timeout in seconds to wait for network operation to "
804 "complete."),
805 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -0400806 default=1,
izikpensod9a01a62014-02-17 20:02:32 +0200807 help="Time in seconds between network operation status "
808 "checks."),
Attila Fazekas640392b2014-06-12 15:58:10 +0200809 cfg.ListOpt('dns_servers',
810 default=["8.8.8.8", "8.8.4.4"],
Itzik Brown5be44582014-12-24 09:05:13 +0200811 help="List of dns servers which should be used"
zhufle027ea92019-05-07 14:02:23 +0800812 " for subnet creation",
813 deprecated_for_removal=True,
814 deprecated_reason="This config option is no longer "
815 "used anywhere, so it can be removed."),
Itzik Brown2ca01cd2014-12-08 12:58:20 +0200816 cfg.StrOpt('port_vnic_type',
Tom Stappaerts27fd5cb2020-11-26 12:07:47 +0100817 choices=[None, 'normal', 'direct', 'macvtap', 'direct-physical',
818 'baremetal', 'virtio-forwarder'],
Moshe Levie2c2fb12017-08-31 15:18:58 +0300819 help="vnic_type to use when launching instances"
Itzik Brown2ca01cd2014-12-08 12:58:20 +0200820 " with pre-configured ports."
821 " Supported ports are:"
Tom Stappaerts27fd5cb2020-11-26 12:07:47 +0100822 " ['normal', 'direct', 'macvtap', 'direct-physical', "
823 "'baremetal', 'virtio-forwarder']"),
Noam Angel3c6b0162018-07-08 17:05:35 +0300824 cfg.Opt('port_profile',
825 type=ProfileType,
826 default={},
827 help="port profile to use when launching instances"
828 " with pre-configured ports."),
piyush11078648e35d52015-09-24 12:56:43 +0530829 cfg.ListOpt('default_network',
830 default=["1.0.0.0/16", "2.0.0.0/16"],
831 help="List of ip pools"
832 " for subnetpools creation"),
Thiago Paiva66cded22016-08-15 14:55:58 -0300833 cfg.BoolOpt('shared_physical_network',
834 default=False,
835 help="The environment does not support network separation "
836 "between tenants."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500837]
Jay Pipes3f981df2012-03-27 18:59:44 -0400838
Matthew Treinishe3d26142013-11-26 19:14:58 +0000839network_feature_group = cfg.OptGroup(name='network-feature-enabled',
840 title='Enabled network service features')
841
842NetworkFeaturesGroup = [
Matthew Treinishe2e33cf2014-03-03 19:28:41 +0000843 cfg.BoolOpt('ipv6',
844 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500845 help="Allow the execution of IPv6 tests."),
Matthew Treinishe3d26142013-11-26 19:14:58 +0000846 cfg.ListOpt('api_extensions',
847 default=['all'],
Alexander Gubanov36e1f9b2015-06-12 18:02:10 +0300848 help="A list of enabled network extensions with a special "
849 "entry all which indicates every extension is enabled. "
850 "Empty list indicates all extensions are disabled. "
Brian Haley3d701092020-11-23 14:03:25 -0500851 "To get the list of extensions run: "
852 "'openstack extension list --network'"),
elajkatf9bb8b82020-11-02 13:41:06 +0100853 cfg.ListOpt('available_features',
854 default=['all'],
855 help="A list of available network features with a special "
856 "entry all that indicates every feature is available. "
Brian Haley3d701092020-11-23 14:03:25 -0500857 "Empty list indicates all features are disabled. "
elajkatf9bb8b82020-11-02 13:41:06 +0100858 "This list can contain features that are not "
Brian Haley3d701092020-11-23 14:03:25 -0500859 "discoverable through the API."),
Sean M. Collinsdd27a4d2014-05-13 10:33:15 -0400860 cfg.BoolOpt('ipv6_subnet_attributes',
861 default=False,
862 help="Allow the execution of IPv6 subnet tests that use "
863 "the extended IPv6 attributes ipv6_ra_mode "
Brian Haley3d701092020-11-23 14:03:25 -0500864 "and ipv6_address_mode."
Mark McClain6e07c0d2014-10-10 11:25:03 -0400865 ),
Itzik Brownbeb30d32015-03-29 09:42:54 +0300866 cfg.BoolOpt('port_admin_state_change',
867 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500868 help="Does the test environment support changing "
869 "port admin state?"),
Matt Riedemann039b2fe2016-09-15 16:12:24 -0400870 cfg.BoolOpt('port_security',
871 default=False,
872 help="Does the test environment support port security?"),
Matthew Treinish3312de32017-05-19 12:08:17 -0400873 cfg.BoolOpt('floating_ips',
874 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500875 help='Does the test environment support floating_ips?'),
Lajos Katonac87a06b2019-01-04 13:21:48 +0100876 cfg.StrOpt('qos_placement_physnet', default=None,
877 help='Name of the physnet for placement based minimum '
878 'bandwidth allocation.'),
879 cfg.StrOpt('provider_net_base_segmentation_id', default=3000,
880 help='Base segmentation ID to create provider networks. '
Balazs Gibizerf294b0d2021-09-29 16:16:44 +0200881 'This value will be increased in case of conflict.'),
882 cfg.BoolOpt('qos_min_bw_and_pps', default=False,
883 help='Does the test environment have minimum bandwidth and '
884 'packet rate inventories configured?'),
Matthew Treinishe3d26142013-11-26 19:14:58 +0000885]
886
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -0600887dashboard_group = cfg.OptGroup(name="dashboard",
888 title="Dashboard options")
889
890DashboardGroup = [
891 cfg.StrOpt('dashboard_url',
892 default='http://localhost/',
893 help="Where the dashboard can be found"),
894 cfg.BoolOpt('disable_ssl_certificate_validation',
895 default=False,
896 help="Set to True if using self-signed SSL certificates."),
897]
898
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000899validation_group = cfg.OptGroup(name='validation',
900 title='SSH Validation options')
901
902ValidationGroup = [
Matthew Treinishe5cca002015-05-11 15:36:50 -0400903 cfg.BoolOpt('run_validation',
Attila Fazekas489e90f2018-09-12 17:30:01 -0600904 default=True,
Matthew Treinishe5cca002015-05-11 15:36:50 -0400905 help='Enable ssh on created servers and creation of additional'
Attila Fazekas489e90f2018-09-12 17:30:01 -0600906 ' validation resources to enable remote access.'
907 ' In case the guest does not support ssh set it'
908 ' to false'),
Brandon Palmc6cc91d2015-08-19 13:20:21 -0500909 cfg.BoolOpt('security_group',
910 default=True,
911 help='Enable/disable security groups.'),
912 cfg.BoolOpt('security_group_rules',
913 default=True,
914 help='Enable/disable security group rules.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000915 cfg.StrOpt('connect_method',
916 default='floating',
917 choices=['fixed', 'floating'],
918 help='Default IP type used for validation: '
919 '-fixed: uses the first IP belonging to the fixed network '
ghanshyamade71d22017-02-15 05:36:14 +0000920 '-floating: creates and uses a floating IP'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000921 cfg.StrOpt('auth_method',
922 default='keypair',
923 choices=['keypair'],
924 help='Default authentication method to the instance. '
925 'Only ssh via keypair is supported for now. '
ghanshyamade71d22017-02-15 05:36:14 +0000926 'Additional methods will be handled in a separate spec.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000927 cfg.IntOpt('ip_version_for_ssh',
928 default=4,
lanoux283273b2015-12-04 03:01:54 -0800929 help='Default IP version for ssh connections.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000930 cfg.IntOpt('ping_timeout',
931 default=120,
ghanshyam244cf7c2017-02-15 06:39:31 +0000932 help='Timeout in seconds to wait for ping to succeed.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000933 cfg.IntOpt('connect_timeout',
934 default=60,
935 help='Timeout in seconds to wait for the TCP connection to be '
lanoux283273b2015-12-04 03:01:54 -0800936 'successful.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000937 cfg.IntOpt('ssh_timeout',
938 default=300,
lanoux283273b2015-12-04 03:01:54 -0800939 help='Timeout in seconds to wait for the ssh banner.'),
940 cfg.StrOpt('image_ssh_user',
941 default="root",
ghanshyam244cf7c2017-02-15 06:39:31 +0000942 help="User name used to authenticate to an instance."),
Weronika Sikorac54a9112019-09-18 13:55:07 +0000943 cfg.StrOpt('image_alt_ssh_user',
944 default="root",
945 help="User name used to authenticate to an alt instance."),
lanoux283273b2015-12-04 03:01:54 -0800946 cfg.StrOpt('image_ssh_password',
947 default="password",
Doug Schveninger6a2be432020-04-29 17:42:31 -0500948 help="Password used to authenticate to an instance.",
949 secret=True),
Weronika Sikorac54a9112019-09-18 13:55:07 +0000950 cfg.StrOpt('image_alt_ssh_password',
951 default="password",
952 help="Password used to authenticate to an alt instance.",
953 secret=True),
lanoux283273b2015-12-04 03:01:54 -0800954 cfg.StrOpt('ssh_shell_prologue',
Lucian Petrut6a7472a2019-08-07 12:43:08 +0300955 default="set -eu -o pipefail; PATH=$$PATH:/sbin:/usr/sbin;",
lanoux283273b2015-12-04 03:01:54 -0800956 help="Shell fragments to use before executing a command "
ghanshyamade71d22017-02-15 05:36:14 +0000957 "when sshing to a guest."),
lanoux283273b2015-12-04 03:01:54 -0800958 cfg.IntOpt('ping_size',
959 default=56,
960 help="The packet size for ping packets originating "
ghanshyamade71d22017-02-15 05:36:14 +0000961 "from remote linux hosts"),
lanoux283273b2015-12-04 03:01:54 -0800962 cfg.IntOpt('ping_count',
963 default=1,
964 help="The number of ping packets originating from remote "
ghanshyamade71d22017-02-15 05:36:14 +0000965 "linux hosts"),
lanoux283273b2015-12-04 03:01:54 -0800966 cfg.StrOpt('floating_ip_range',
967 default='10.0.0.0/29',
968 help='Unallocated floating IP range, which will be used to '
969 'test the floating IP bulk feature for CRUD operation. '
970 'This block must not overlap an existing floating IP '
ghanshyamade71d22017-02-15 05:36:14 +0000971 'pool.'),
lanoux283273b2015-12-04 03:01:54 -0800972 cfg.StrOpt('network_for_ssh',
973 default='public',
974 help="Network used for SSH connections. Ignored if "
ghanshyam244cf7c2017-02-15 06:39:31 +0000975 "connect_method=floating."),
Ade Lee6ded0702021-09-04 15:56:34 -0400976 cfg.StrOpt('ssh_key_type',
977 default='rsa',
978 help='Type of key to use for ssh connections. '
979 'Valid types are rsa, ecdsa'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000980]
981
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500982volume_group = cfg.OptGroup(name='volume',
983 title='Block Storage Options')
Daryl Walleck587385b2012-03-03 13:00:26 -0600984
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500985VolumeGroup = [
986 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -0400987 default=1,
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500988 help='Time in seconds between volume availability checks.'),
989 cfg.IntOpt('build_timeout',
990 default=300,
Eric Harney9b1f89c2014-10-14 14:40:19 -0400991 help='Timeout in seconds to wait for a volume to become '
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500992 'available.'),
993 cfg.StrOpt('catalog_type',
ghanshyam89c213f2017-12-14 07:22:12 +0000994 default='volumev3',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500995 help="Catalog type of the Volume Service"),
Arata Notsu8f440392013-09-13 16:14:20 +0900996 cfg.StrOpt('region',
997 default='',
998 help="The volume region name to use. If empty, the value "
999 "of identity.region is used instead. If no such region "
1000 "is found in the service catalog, the first found one is "
1001 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +00001002 cfg.StrOpt('endpoint_type',
1003 default='publicURL',
1004 choices=['public', 'admin', 'internal',
1005 'publicURL', 'adminURL', 'internalURL'],
1006 help="The endpoint type to use for the volume service."),
Benny Kopilovaf136a92015-11-10 07:37:23 +02001007 cfg.ListOpt('backend_names',
1008 default=['BACKEND_1', 'BACKEND_2'],
april4be58dc2015-12-29 00:07:22 +08001009 help='A list of backend names separated by comma. '
bkopilov27905cc2016-04-12 14:29:13 +03001010 'The backend name must be declared in cinder.conf'),
Ansuman Bebarta46d540d2021-02-16 18:48:33 +05301011 cfg.StrOpt('volume_type',
1012 default='',
1013 help='Volume type to be used while creating volume.'),
Adam Gandelman827ad332013-06-24 17:04:09 -07001014 cfg.StrOpt('storage_protocol',
1015 default='iSCSI',
1016 help='Backend protocol to target when creating volume types'),
1017 cfg.StrOpt('vendor_name',
1018 default='Open Source',
1019 help='Backend vendor to target when creating volume types'),
Ryan Hsua67f4632013-08-29 16:03:06 -07001020 cfg.StrOpt('disk_format',
1021 default='raw',
1022 help='Disk format to use when copying a volume to image'),
Jerry Cai9733d0e2014-03-19 15:50:49 +08001023 cfg.IntOpt('volume_size',
1024 default=1,
1025 help='Default size in GB for volumes created by volumes tests'),
Martin Kopec37c4bd32021-06-24 15:46:00 +00001026 cfg.IntOpt('volume_size_extend',
1027 default=1,
1028 help="Size in GB a volume is extended by - if a test "
1029 "extends a volume, the size of the new volume will be "
1030 "volume_size + volume_size_extend."),
jeremy.zhangf4fbf302017-03-22 11:25:53 +08001031 cfg.ListOpt('manage_volume_ref',
1032 default=['source-name', 'volume-%s'],
1033 help="A reference to existing volume for volume manage. "
1034 "It contains two elements, the first is ref type "
1035 "(like 'source-name', 'source-id', etc), the second is "
1036 "volume name template used in storage backend"),
jeremy.zhangebc752b2017-06-14 13:58:37 +08001037 cfg.ListOpt('manage_snapshot_ref',
1038 default=['source-name', '_snapshot-%s'],
1039 help="A reference to existing snapshot for snapshot manage. "
1040 "It contains two elements, the first is ref type "
1041 "(like 'source-name', 'source-id', etc), the second is "
1042 "snapshot name template used in storage backend"),
Andrew Kerrfcb0b682016-04-01 16:01:34 -04001043 cfg.StrOpt('min_microversion',
1044 default=None,
1045 help="Lower version of the test target microversion range. "
1046 "The format is 'X.Y', where 'X' and 'Y' are int values. "
1047 "Tempest selects tests based on the range between "
1048 "min_microversion and max_microversion. "
1049 "If both values are not specified, Tempest avoids tests "
1050 "which require a microversion. Valid values are string "
1051 "with format 'X.Y' or string 'latest'",),
1052 cfg.StrOpt('max_microversion',
1053 default=None,
1054 help="Upper version of the test target microversion range. "
1055 "The format is 'X.Y', where 'X' and 'Y' are int values. "
1056 "Tempest selects tests based on the range between "
1057 "min_microversion and max_microversion. "
1058 "If both values are not specified, Tempest avoids tests "
1059 "which require a microversion. Valid values are string "
1060 "with format 'X.Y' or string 'latest'",),
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001061]
K Jonathan Harkerd6ba4b42012-12-18 13:50:47 -08001062
Matthew Treinishd5c96022013-10-17 21:51:23 +00001063volume_feature_group = cfg.OptGroup(name='volume-feature-enabled',
1064 title='Enabled Cinder Features')
1065
1066VolumeFeaturesGroup = [
1067 cfg.BoolOpt('multi_backend',
1068 default=False,
Matthew Treinishe3d26142013-11-26 19:14:58 +00001069 help="Runs Cinder multi-backend test (requires 2 backends)"),
Giulio Fidente74b08ad2014-01-18 04:02:51 +01001070 cfg.BoolOpt('backup',
1071 default=True,
1072 help='Runs Cinder volumes backup test'),
JordanPbce55532014-03-19 12:10:32 +01001073 cfg.BoolOpt('snapshot',
1074 default=True,
1075 help='Runs Cinder volume snapshot test'),
Takeaki Matsumoto1702aed2015-08-25 08:44:26 +09001076 cfg.BoolOpt('clone',
1077 default=True,
1078 help='Runs Cinder volume clone test'),
Jordan Pittier31256252017-01-11 14:29:49 +01001079 cfg.BoolOpt('manage_snapshot',
1080 default=False,
1081 help='Runs Cinder manage snapshot tests'),
jeremy.zhangf4fbf302017-03-22 11:25:53 +08001082 cfg.BoolOpt('manage_volume',
1083 default=False,
1084 help='Runs Cinder manage volume tests'),
Matthew Treinishe3d26142013-11-26 19:14:58 +00001085 cfg.ListOpt('api_extensions',
1086 default=['all'],
Zhi Kun Liude25c022014-02-14 13:25:19 +08001087 help='A list of enabled volume extensions with a special '
Simeon Monov5d7effe2014-07-16 07:32:38 +03001088 'entry all which indicates every extension is enabled. '
1089 'Empty list indicates all extensions are disabled'),
Matt Riedemann0cc76bf2017-07-05 17:29:31 -04001090 cfg.BoolOpt('extend_attached_volume',
1091 default=False,
1092 help='Does the cloud support extending the size of a volume '
1093 'which is currently attached to a server instance? This '
1094 'depends on the 3.42 volume API microversion and the '
1095 '2.51 compute API microversion. Also, not all volume or '
Lee Yarwood4bd9edb2020-01-31 17:26:25 +00001096 'compute backends support this operation.'),
1097 cfg.BoolOpt('extend_attached_encrypted_volume',
1098 default=False,
1099 help='Does the cloud support extending the size of an '
1100 'encrypted volume which is currently attached to a '
1101 'server instance? This depends on the 3.42 volume API '
1102 'microversion and the 2.51 compute API microversion. '
1103 'Also, not all volume or compute backends support this '
1104 'operation.')
Matthew Treinishd5c96022013-10-17 21:51:23 +00001105]
1106
Daryl Walleck587385b2012-03-03 13:00:26 -06001107
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001108object_storage_group = cfg.OptGroup(name='object-storage',
1109 title='Object Storage Service Options')
Attila Fazekasa23f5002012-10-23 19:32:45 +02001110
DennyZhang1e71b612013-09-26 12:35:40 -05001111ObjectStoreGroup = [
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001112 cfg.StrOpt('catalog_type',
1113 default='object-store',
1114 help="Catalog type of the Object-Storage service."),
Arata Notsu8f440392013-09-13 16:14:20 +09001115 cfg.StrOpt('region',
1116 default='',
1117 help="The object-storage region name to use. If empty, the "
1118 "value of identity.region is used instead. If no such "
1119 "region is found in the service catalog, the first found "
1120 "one is used."),
JordanP5d29b2c2013-12-18 13:56:03 +00001121 cfg.StrOpt('endpoint_type',
1122 default='publicURL',
1123 choices=['public', 'admin', 'internal',
1124 'publicURL', 'adminURL', 'internalURL'],
1125 help="The endpoint type to use for the object-store service."),
Matthew Treinishf319a732013-10-24 21:39:24 +00001126 cfg.IntOpt('container_sync_timeout',
Daisuke Morita1ac3ee02014-08-25 12:59:18 +09001127 default=600,
Fabien Boucher2178d312013-12-31 15:38:57 +01001128 help="Number of seconds to time on waiting for a container "
nayna-patelb4989b32013-01-09 06:25:13 +00001129 "to container synchronization complete."),
Matthew Treinishf319a732013-10-24 21:39:24 +00001130 cfg.IntOpt('container_sync_interval',
nayna-patelb4989b32013-01-09 06:25:13 +00001131 default=5,
Fabien Boucher2178d312013-12-31 15:38:57 +01001132 help="Number of seconds to wait while looping to check the "
nayna-patelb4989b32013-01-09 06:25:13 +00001133 "status of a container to container synchronization"),
Matthew Treinish3fdb80c2013-08-15 11:13:19 -04001134 cfg.StrOpt('operator_role',
Martin Kopec99d4dae2020-05-27 10:33:17 +00001135 default='member',
Matthew Treinish3fdb80c2013-08-15 11:13:19 -04001136 help="Role to add to users created for swift tests to "
1137 "enable creating containers"),
Matthew Treinish998c91d2014-03-01 12:39:49 -05001138 cfg.StrOpt('reseller_admin_role',
1139 default='ResellerAdmin',
1140 help="User role that has reseller admin"),
Daisuke Morita1ac3ee02014-08-25 12:59:18 +09001141 cfg.StrOpt('realm_name',
1142 default='realm1',
1143 help="Name of sync realm. A sync realm is a set of clusters "
1144 "that have agreed to allow container syncing with each "
1145 "other. Set the same realm name as Swift's "
1146 "container-sync-realms.conf"),
1147 cfg.StrOpt('cluster_name',
1148 default='name1',
1149 help="One name of cluster which is set in the realm whose name "
1150 "is set in 'realm_name' item in this file. Set the "
1151 "same cluster name as Swift's container-sync-realms.conf"),
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001152]
Attila Fazekasa23f5002012-10-23 19:32:45 +02001153
Matthew Treinishd5c96022013-10-17 21:51:23 +00001154object_storage_feature_group = cfg.OptGroup(
1155 name='object-storage-feature-enabled',
1156 title='Enabled object-storage features')
1157
1158ObjectStoreFeaturesGroup = [
Matthew Treinish20345382013-12-13 17:04:23 +00001159 cfg.ListOpt('discoverable_apis',
1160 default=['all'],
1161 help="A list of the enabled optional discoverable apis. "
1162 "A single entry, all, indicates that all of these "
1163 "features are expected to be enabled"),
Daisuke Morita20a183f2014-08-25 14:43:36 +09001164 cfg.BoolOpt('container_sync',
1165 default=True,
1166 help="Execute (old style) container-sync tests"),
1167 cfg.BoolOpt('object_versioning',
1168 default=True,
1169 help="Execute object-versioning tests"),
1170 cfg.BoolOpt('discoverability',
1171 default=True,
1172 help="Execute discoverability tests"),
Matthew Treinishd5c96022013-10-17 21:51:23 +00001173]
1174
Luigi Toscano14d172d2015-01-23 16:37:47 +01001175
Masayuki Igawa73d9f3a2013-05-24 10:30:01 +09001176scenario_group = cfg.OptGroup(name='scenario', title='Scenario Test Options')
1177
1178ScenarioGroup = [
Alessandro Pilottib7c1daa2014-08-16 14:24:13 +03001179 cfg.StrOpt('img_file', deprecated_name='qcow2_img_file',
Martin Kopec02af6a42020-03-03 12:39:12 +00001180 default='/opt/stack/new/devstack/files/images'
1181 '/cirros-0.3.1-x86_64-disk.img',
1182 help='Image full path.'),
Alessandro Pilottib7c1daa2014-08-16 14:24:13 +03001183 cfg.StrOpt('img_disk_format',
1184 default='qcow2',
1185 help='Image disk format'),
1186 cfg.StrOpt('img_container_format',
1187 default='bare',
1188 help='Image container format'),
Evgeny Antyshev7ba0d5f2015-04-28 13:18:07 +00001189 cfg.DictOpt('img_properties', help='Glance image properties. '
1190 'Use for custom images which require them'),
Yair Fried413bf2d2014-11-19 17:07:11 +02001191 # TODO(yfried): add support for dhcpcd
1192 cfg.StrOpt('dhcp_client',
1193 default='udhcpc',
Yaroslav Lobankovceae2042015-09-09 19:25:14 +03001194 choices=["udhcpc", "dhclient", ""],
Yair Fried413bf2d2014-11-19 17:07:11 +02001195 help='DHCP client used by images to renew DCHP lease. '
1196 'If left empty, update operation will be skipped. '
Claudiu Belu33c3e602014-08-28 16:38:01 +03001197 'Supported clients: "udhcpc", "dhclient"'),
1198 cfg.StrOpt('protocol',
1199 default='icmp',
1200 choices=('icmp', 'tcp', 'udp'),
1201 help='The protocol used in security groups tests to check '
1202 'connectivity.'),
Masayuki Igawa73d9f3a2013-05-24 10:30:01 +09001203]
1204
1205
Matthew Treinish4c412922013-07-16 15:27:42 -04001206service_available_group = cfg.OptGroup(name="service_available",
1207 title="Available OpenStack Services")
1208
1209ServiceAvailableGroup = [
1210 cfg.BoolOpt('cinder',
1211 default=True,
1212 help="Whether or not cinder is expected to be available"),
Matthew Treinishfaa340d2013-07-19 16:26:21 -04001213 cfg.BoolOpt('neutron',
1214 default=False,
1215 help="Whether or not neutron is expected to be available"),
Matthew Treinish853ae442013-07-19 16:36:07 -04001216 cfg.BoolOpt('glance',
1217 default=True,
1218 help="Whether or not glance is expected to be available"),
Matthew Treinish61e332b2013-07-19 16:42:31 -04001219 cfg.BoolOpt('swift',
1220 default=True,
1221 help="Whether or not swift is expected to be available"),
Matthew Treinish6b41e242013-07-19 16:49:28 -04001222 cfg.BoolOpt('nova',
1223 default=True,
1224 help="Whether or not nova is expected to be available"),
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001225 cfg.BoolOpt('horizon',
1226 default=True,
1227 help="Whether or not horizon is expected to be available"),
Matthew Treinish4c412922013-07-16 15:27:42 -04001228]
1229
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001230enforce_scope_group = cfg.OptGroup(name="enforce_scope",
1231 title="OpenStack Services with "
1232 "enforce scope")
1233
1234
1235EnforceScopeGroup = [
1236 cfg.BoolOpt('nova',
1237 default=False,
1238 help='Does the compute service API policies enforce scope? '
1239 'This configuration value should be same as '
1240 'nova.conf: [oslo_policy].enforce_scope option.'),
1241 cfg.BoolOpt('neutron',
1242 default=False,
1243 help='Does the network service API policies enforce scope? '
1244 'This configuration value should be same as '
1245 'neutron.conf: [oslo_policy].enforce_scope option.'),
1246 cfg.BoolOpt('glance',
1247 default=False,
1248 help='Does the Image service API policies enforce scope? '
1249 'This configuration value should be same as '
1250 'glance.conf: [oslo_policy].enforce_scope option.'),
1251 cfg.BoolOpt('cinder',
1252 default=False,
1253 help='Does the Volume service API policies enforce scope? '
1254 'This configuration value should be same as '
1255 'cinder.conf: [oslo_policy].enforce_scope option.'),
1256 cfg.BoolOpt('keystone',
1257 default=False,
1258 help='Does the Identity service API policies enforce scope? '
1259 'This configuration value should be same as '
1260 'keystone.conf: [oslo_policy].enforce_scope option.'),
1261]
1262
Attila Fazekasaeeeefd2013-08-06 17:01:56 +02001263debug_group = cfg.OptGroup(name="debug",
1264 title="Debug System")
1265
1266DebugGroup = [
Sean Daguec522c092014-03-24 10:43:22 -04001267 cfg.StrOpt('trace_requests',
1268 default='',
1269 help="""A regex to determine which requests should be traced.
1270
1271This is a regex to match the caller for rest client requests to be able to
1272selectively trace calls out of specific classes and methods. It largely
1273exists for test development, and is not expected to be used in a real deploy
1274of tempest. This will be matched against the discovered ClassName:method
1275in the test environment.
1276
1277Expected values for this field are:
1278
1279 * ClassName:test_method_name - traces one test_method
1280 * ClassName:setUp(Class) - traces specific setup functions
1281 * ClassName:tearDown(Class) - traces specific teardown functions
1282 * ClassName:_run_cleanups - traces the cleanup functions
1283
1284If nothing is specified, this feature is not enabled. To trace everything
1285specify .* as the regex.
1286""")
Attila Fazekasaeeeefd2013-08-06 17:01:56 +02001287]
1288
Ilya Shakhat1291bb42017-11-29 18:08:16 +01001289
1290profiler_group = cfg.OptGroup(name="profiler",
1291 title="OpenStack Profiler")
1292
1293ProfilerGroup = [
1294 cfg.StrOpt('key',
1295 help="The secret key to enable OpenStack Profiler. The value "
1296 "should match the one configured in OpenStack services "
1297 "under `[profiler]/hmac_keys` property. The default empty "
1298 "value keeps profiling disabled"),
1299]
1300
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001301DefaultGroup = [
Martin Kopecae155b72017-06-26 09:41:21 +00001302 cfg.BoolOpt('pause_teardown',
1303 default=False,
1304 help="""Whether to pause a test in global teardown.
1305
1306The best use case is investigating used resources of one test.
1307A test can be run as follows:
Soniya Vyase42bd932019-11-26 16:14:33 +05301308 $ stestr run --pdb TEST_ID
Martin Kopecae155b72017-06-26 09:41:21 +00001309or
1310 $ python -m testtools.run TEST_ID"""),
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001311]
1312
Jon Grimm270bd7f2014-08-05 18:11:29 +00001313_opts = [
1314 (auth_group, AuthGroup),
1315 (compute_group, ComputeGroup),
1316 (compute_features_group, ComputeFeaturesGroup),
1317 (identity_group, IdentityGroup),
zhufl071e94c2016-07-12 10:26:34 +08001318 (service_clients_group, ServiceClientsGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001319 (identity_feature_group, IdentityFeatureGroup),
1320 (image_group, ImageGroup),
1321 (image_feature_group, ImageFeaturesGroup),
1322 (network_group, NetworkGroup),
1323 (network_feature_group, NetworkFeaturesGroup),
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001324 (dashboard_group, DashboardGroup),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001325 (validation_group, ValidationGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001326 (volume_group, VolumeGroup),
1327 (volume_feature_group, VolumeFeaturesGroup),
1328 (object_storage_group, ObjectStoreGroup),
1329 (object_storage_feature_group, ObjectStoreFeaturesGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001330 (scenario_group, ScenarioGroup),
1331 (service_available_group, ServiceAvailableGroup),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001332 (enforce_scope_group, EnforceScopeGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001333 (debug_group, DebugGroup),
Lajos Katonaceb88212018-11-30 14:54:12 +01001334 (placement_group, PlacementGroup),
Ilya Shakhat1291bb42017-11-29 18:08:16 +01001335 (profiler_group, ProfilerGroup),
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001336 (None, DefaultGroup)
Jon Grimm270bd7f2014-08-05 18:11:29 +00001337]
1338
Roman Prykhodchenko62b1ed12013-10-16 21:51:47 +03001339
Matthew Treinish43b296a2014-02-28 15:23:00 -05001340def register_opts():
Matthew Treinisha966d0f2015-07-01 17:37:31 -04001341 ext_plugins = plugins.TempestTestPluginManager()
1342 # Register in-tree tempest config options
Jon Grimm270bd7f2014-08-05 18:11:29 +00001343 for g, o in _opts:
Maru Newbyf440c292015-03-31 15:58:47 +00001344 register_opt_group(_CONF, g, o)
Matthew Treinisha966d0f2015-07-01 17:37:31 -04001345 # Call external plugin config option registration
1346 ext_plugins.register_plugin_opts(_CONF)
Jon Grimm270bd7f2014-08-05 18:11:29 +00001347
1348
1349def list_opts():
1350 """Return a list of oslo.config options available.
1351
1352 The purpose of this is to allow tools like the Oslo sample config file
1353 generator to discover the options exposed to users.
1354 """
Matthew Treinish83a19aa2015-07-23 13:06:13 -04001355 ext_plugins = plugins.TempestTestPluginManager()
Chris Hoged7b4fd12015-11-11 10:24:52 -08001356 # Make a shallow copy of the options list that can be
1357 # extended by plugins. Send back the group object
1358 # to allow group help text to be generated.
1359 opt_list = [(g, o) for g, o in _opts]
Matthew Treinish83a19aa2015-07-23 13:06:13 -04001360 opt_list.extend(ext_plugins.get_plugin_options_list())
1361 return opt_list
Matthew Treinish43b296a2014-02-28 15:23:00 -05001362
1363
Ken'ichi Ohmichi3f5c1392018-04-11 14:38:22 -07001364# This should never be called outside of this module
Sean Dague3b9b1f32013-12-20 17:04:54 -05001365class TempestConfigPrivate(object):
Daryl Walleck1465d612011-11-02 02:22:15 -05001366 """Provides OpenStack configuration information."""
1367
David Patersonbe9f9832015-10-15 09:10:45 -07001368 DEFAULT_CONFIG_DIR = os.path.join(os.getcwd(), "etc")
Daryl Walleck1465d612011-11-02 02:22:15 -05001369
Brian Waldon738cd632011-12-12 18:45:09 -05001370 DEFAULT_CONFIG_FILE = "tempest.conf"
1371
Andrea Frittolia96ee212014-08-15 18:34:20 +01001372 def __getattr__(self, attr):
1373 # Handles config options from the default group
Maru Newbyf440c292015-03-31 15:58:47 +00001374 return getattr(_CONF, attr)
Andrea Frittolia96ee212014-08-15 18:34:20 +01001375
Matthew Treinish43b296a2014-02-28 15:23:00 -05001376 def _set_attrs(self):
Andrea Frittoli382a6f12017-03-09 11:52:17 +00001377 # This methods ensures that config options in Tempest as well as
1378 # in Tempest plugins can be accessed via:
1379 # CONF.<normalised_group_name>.<key_name>
1380 # where:
1381 # normalised_group_name = group_name.replace('-', '_')
1382 # Attributes are set at __init__ time *only* for known option groups
Maru Newbyf440c292015-03-31 15:58:47 +00001383 self.auth = _CONF.auth
1384 self.compute = _CONF.compute
1385 self.compute_feature_enabled = _CONF['compute-feature-enabled']
1386 self.identity = _CONF.identity
zhufl071e94c2016-07-12 10:26:34 +08001387 self.service_clients = _CONF['service-clients']
Maru Newbyf440c292015-03-31 15:58:47 +00001388 self.identity_feature_enabled = _CONF['identity-feature-enabled']
1389 self.image = _CONF.image
1390 self.image_feature_enabled = _CONF['image-feature-enabled']
1391 self.network = _CONF.network
1392 self.network_feature_enabled = _CONF['network-feature-enabled']
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001393 self.dashboard = _CONF.dashboard
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001394 self.validation = _CONF.validation
Maru Newbyf440c292015-03-31 15:58:47 +00001395 self.volume = _CONF.volume
1396 self.volume_feature_enabled = _CONF['volume-feature-enabled']
1397 self.object_storage = _CONF['object-storage']
1398 self.object_storage_feature_enabled = _CONF[
Matthew Treinishd5c96022013-10-17 21:51:23 +00001399 'object-storage-feature-enabled']
Maru Newbyf440c292015-03-31 15:58:47 +00001400 self.scenario = _CONF.scenario
1401 self.service_available = _CONF.service_available
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001402 self.enforce_scope = _CONF.enforce_scope
Maru Newbyf440c292015-03-31 15:58:47 +00001403 self.debug = _CONF.debug
Matthew Treinish46008082015-04-14 18:32:47 -04001404 logging.tempest_set_log_file('tempest.log')
Andrea Frittoli382a6f12017-03-09 11:52:17 +00001405 # Setting attributes for plugins
1406 # NOTE(andreaf) Plugins have no access to the TempestConfigPrivate
1407 # instance at discovery time, so they have no way of setting these
1408 # aliases themselves.
1409 ext_plugins = plugins.TempestTestPluginManager()
1410 for group, _ in ext_plugins.get_plugin_options_list():
1411 if isinstance(group, cfg.OptGroup):
1412 # If we have an OptGroup
1413 group_name = group.name
1414 group_dest = group.dest
1415 else:
1416 # If we have a group name as a string
1417 group_name = group
1418 group_dest = group.replace('-', '_')
1419 # NOTE(andreaf) We can set the attribute safely here since in
1420 # case of name conflict we would not have reached this point.
1421 setattr(self, group_dest, _CONF[group_name])
Sean Dague86bd8422013-12-20 09:56:44 -05001422
Joe Gordon28a84ae2014-07-17 15:38:28 +00001423 def __init__(self, parse_conf=True, config_path=None):
Matthew Treinish43b296a2014-02-28 15:23:00 -05001424 """Initialize a configuration from a conf directory and conf file."""
1425 super(TempestConfigPrivate, self).__init__()
1426 config_files = []
1427 failsafe_path = "/etc/tempest/" + self.DEFAULT_CONFIG_FILE
1428
Joe Gordon28a84ae2014-07-17 15:38:28 +00001429 if config_path:
1430 path = config_path
1431 else:
1432 # Environment variables override defaults...
1433 conf_dir = os.environ.get('TEMPEST_CONFIG_DIR',
1434 self.DEFAULT_CONFIG_DIR)
1435 conf_file = os.environ.get('TEMPEST_CONFIG',
1436 self.DEFAULT_CONFIG_FILE)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001437
Joe Gordon28a84ae2014-07-17 15:38:28 +00001438 path = os.path.join(conf_dir, conf_file)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001439
1440 if not os.path.isfile(path):
1441 path = failsafe_path
1442
1443 # only parse the config file if we expect one to exist. This is needed
1444 # to remove an issue with the config file up to date checker.
1445 if parse_conf:
1446 config_files.append(path)
Maru Newbyf440c292015-03-31 15:58:47 +00001447 logging.register_options(_CONF)
Matthew Treinish5440a402014-10-02 14:36:16 -04001448 if os.path.isfile(path):
Maru Newbyf440c292015-03-31 15:58:47 +00001449 _CONF([], project='tempest', default_config_files=config_files)
Matthew Treinish5440a402014-10-02 14:36:16 -04001450 else:
Maru Newbyf440c292015-03-31 15:58:47 +00001451 _CONF([], project='tempest')
Marc Kodererc81c7672015-12-17 12:10:12 +01001452
1453 logging_cfg_path = "%s/logging.conf" % os.path.dirname(path)
Tom Patzige6f7c7d2016-02-17 16:46:11 +01001454 if ((not hasattr(_CONF, 'log_config_append') or
afazekas40fcb9b2019-03-08 11:25:11 +01001455 _CONF.log_config_append is None) and
Marc Kodererc81c7672015-12-17 12:10:12 +01001456 os.path.isfile(logging_cfg_path)):
1457 # if logging conf is in place we need to set log_config_append
1458 _CONF.log_config_append = logging_cfg_path
1459
Maru Newbyf440c292015-03-31 15:58:47 +00001460 logging.setup(_CONF, 'tempest')
Matthew Treinish43b296a2014-02-28 15:23:00 -05001461 LOG = logging.getLogger('tempest')
Jordan Pittier525ec712016-12-07 17:51:26 +01001462 LOG.info("Using tempest config file %s", path)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001463 register_opts()
1464 self._set_attrs()
Masayuki Igawa9ec4cd82014-02-05 15:04:16 +09001465 if parse_conf:
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301466 _CONF.log_opt_values(LOG, logging.DEBUG)
Masayuki Igawa9ec4cd82014-02-05 15:04:16 +09001467
Sean Dague86bd8422013-12-20 09:56:44 -05001468
1469class TempestConfigProxy(object):
1470 _config = None
Joe Gordon28a84ae2014-07-17 15:38:28 +00001471 _path = None
Sean Dague86bd8422013-12-20 09:56:44 -05001472
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001473 _extra_log_defaults = [
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301474 ('paramiko.transport', logging.INFO),
1475 ('requests.packages.urllib3.connectionpool', logging.WARN),
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001476 ]
1477
1478 def _fix_log_levels(self):
1479 """Tweak the oslo log defaults."""
Doug Hellmann583ce2c2015-03-11 14:55:46 +00001480 for name, level in self._extra_log_defaults:
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301481 logging.getLogger(name).logger.setLevel(level)
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001482
Sean Dague86bd8422013-12-20 09:56:44 -05001483 def __getattr__(self, attr):
1484 if not self._config:
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001485 self._fix_log_levels()
Matthew Treinishaa29c7e2015-04-23 16:35:09 -04001486 lock_dir = os.path.join(tempfile.gettempdir(), 'tempest-lock')
1487 lockutils.set_defaults(lock_dir)
Joe Gordon28a84ae2014-07-17 15:38:28 +00001488 self._config = TempestConfigPrivate(config_path=self._path)
Sean Dague86bd8422013-12-20 09:56:44 -05001489
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001490 # Pushing tempest internal service client configuration to the
1491 # service clients register. Doing this in the config module ensures
1492 # that the configuration is available by the time we register the
1493 # service clients.
1494 # NOTE(andreaf) This has to be done at the time the first
1495 # attribute is accessed, to ensure all plugins have been already
1496 # loaded, options registered, and _config is set.
1497 _register_tempest_service_clients()
1498
Andrea Frittoli8b23c792017-03-09 13:17:01 +00001499 # Registering service clients and pushing their configuration to
1500 # the service clients register. Doing this in the config module
1501 # ensures that the configuration is available by the time we
1502 # discover tests from plugins.
1503 plugins.TempestTestPluginManager()._register_service_clients()
1504
Sean Dague86bd8422013-12-20 09:56:44 -05001505 return getattr(self._config, attr)
1506
Joe Gordon28a84ae2014-07-17 15:38:28 +00001507 def set_config_path(self, path):
1508 self._path = path
Masayuki Igawa79159f82018-07-27 15:00:37 +09001509 # FIXME(masayukig): bug#1783751 To pass the config file path to child
1510 # processes, we need to set the environment variables here as a
1511 # workaround.
1512 os.environ['TEMPEST_CONFIG_DIR'] = os.path.dirname(path)
1513 os.environ['TEMPEST_CONFIG'] = os.path.basename(path)
Joe Gordon28a84ae2014-07-17 15:38:28 +00001514
Sean Dague86bd8422013-12-20 09:56:44 -05001515
1516CONF = TempestConfigProxy()
Matthew Treinishca5a9ff2016-04-16 15:04:34 -04001517
1518
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001519def service_client_config(service_client_name=None):
1520 """Return a dict with the parameters to init service clients
1521
1522 Extracts from CONF the settings specific to the service_client_name and
1523 api_version, and formats them as dict ready to be passed to the service
1524 clients __init__:
1525
1526 * `region` (default to identity)
1527 * `catalog_type`
1528 * `endpoint_type`
1529 * `build_timeout` (object-storage and identity default to compute)
1530 * `build_interval` (object-storage and identity default to compute)
1531
1532 The following common settings are always returned, even if
1533 `service_client_name` is None:
1534
1535 * `disable_ssl_certificate_validation`
1536 * `ca_certs`
1537 * `trace_requests`
zhufl071e94c2016-07-12 10:26:34 +08001538 * `http_timeout`
Matthew Treinish74514402016-09-01 11:44:57 -04001539 * `proxy_url`
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001540
1541 The dict returned by this does not fit a few service clients:
1542
1543 * The endpoint type is not returned for identity client, since it takes
1544 three different values for v2 admin, v2 public and v3
1545 * The `ServersClient` from compute accepts an optional
1546 `enable_instance_password` parameter, which is not returned.
1547 * The `VolumesClient` for both v1 and v2 volume accept an optional
1548 `default_volume_size` parameter, which is not returned.
1549 * The `TokenClient` and `V3TokenClient` have a very different
1550 interface, only auth_url is needed for them.
1551
1552 :param service_client_name: str Name of the service. Supported values are
1553 'compute', 'identity', 'image', 'network', 'object-storage', 'volume'
1554 :return: dictionary of __init__ parameters for the service clients
1555 :rtype: dict
1556 """
1557 _parameters = {
1558 'disable_ssl_certificate_validation':
Daniel Melladocad3f3d2016-08-19 14:17:16 +00001559 CONF.identity.disable_ssl_certificate_validation,
1560 'ca_certs': CONF.identity.ca_certificates_file,
zhufl071e94c2016-07-12 10:26:34 +08001561 'trace_requests': CONF.debug.trace_requests,
Matthew Treinish74514402016-09-01 11:44:57 -04001562 'http_timeout': CONF.service_clients.http_timeout,
1563 'proxy_url': CONF.service_clients.proxy_url,
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001564 }
1565
1566 if service_client_name is None:
1567 return _parameters
1568
1569 # Get the group of options first, by normalising the service_group_name
1570 # Services with a '-' in the name have an '_' in the option group name
1571 config_group = service_client_name.replace('-', '_')
1572 # NOTE(andreaf) Check if the config group exists. This allows for this
1573 # helper to be used for settings from registered plugins as well
1574 try:
1575 options = getattr(CONF, config_group)
1576 except cfg.NoSuchOptError:
1577 # Option group not defined
1578 raise exceptions.UnknownServiceClient(services=service_client_name)
1579 # Set endpoint_type
1580 # Identity uses different settings depending on API version, so do not
1581 # return the endpoint at all.
1582 if service_client_name != 'identity':
1583 _parameters['endpoint_type'] = getattr(options, 'endpoint_type')
1584 # Set build_*
1585 # Object storage and identity groups do not have conf settings for
1586 # build_* parameters, and we default to compute in any case
1587 for setting in ['build_timeout', 'build_interval']:
1588 if not hasattr(options, setting) or not getattr(options, setting):
1589 _parameters[setting] = getattr(CONF.compute, setting)
1590 else:
1591 _parameters[setting] = getattr(options, setting)
1592 # Set region
1593 # If a service client does not define region or region is not set
1594 # default to the identity region
1595 if not hasattr(options, 'region') or not getattr(options, 'region'):
1596 _parameters['region'] = CONF.identity.region
1597 else:
1598 _parameters['region'] = getattr(options, 'region')
1599 # Set service
1600 _parameters['service'] = getattr(options, 'catalog_type')
1601 return _parameters
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001602
1603
1604def _register_tempest_service_clients():
1605 # Register tempest own service clients using the same mechanism used
1606 # for external plugins.
1607 # The configuration data is pushed to the registry so that automatic
1608 # configuration of tempest own service clients is possible both for
1609 # tempest as well as for the plugins.
1610 service_clients = clients.tempest_modules()
1611 registry = clients.ClientsRegistry()
1612 all_clients = []
1613 for service_client in service_clients:
1614 module = service_clients[service_client]
1615 configs = service_client.split('.')[0]
1616 service_client_data = dict(
Andrea Frittoli986407d2017-10-11 10:23:17 +00001617 name=service_client.replace('.', '_').replace('-', '_'),
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001618 service_version=service_client,
1619 module_path=module.__name__,
1620 client_names=module.__all__,
1621 **service_client_config(configs)
1622 )
1623 all_clients.append(service_client_data)
1624 # NOTE(andreaf) Internal service clients do not actually belong
1625 # to a plugin, so using '__tempest__' to indicate a virtual plugin
1626 # which holds internal service clients.
1627 registry.register_service_client('__tempest__', all_clients)