blob: 00b394effd110f544487ce5f61b2503009bc312b [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.")),
Abhishek Kekane0188f462022-01-18 06:47:28 +0000677 cfg.BoolOpt('image_caching_enabled',
678 default=False,
679 help=("Flag to enable if caching is enabled by image "
680 "service, operator should set this parameter to True"
681 "if 'image_cache_dir' is set in glance-api.conf")),
Sean Dague83401992013-05-06 17:46:36 -0400682 cfg.StrOpt('http_image',
683 default='http://download.cirros-cloud.net/0.3.1/'
684 'cirros-0.3.1-x86_64-uec.tar.gz',
Lucian Petrut1cfe2982015-01-06 13:57:36 +0200685 help='http accessible image'),
686 cfg.IntOpt('build_timeout',
687 default=300,
688 help="Timeout in seconds to wait for an image to "
689 "become available."),
690 cfg.IntOpt('build_interval',
691 default=1,
692 help="Time in seconds between image operation status "
Takashi NATSUME12a48512015-08-10 18:33:16 +0900693 "checks."),
694 cfg.ListOpt('container_formats',
695 default=['ami', 'ari', 'aki', 'bare', 'ovf', 'ova'],
696 help="A list of image's container formats "
697 "users can specify."),
698 cfg.ListOpt('disk_formats',
699 default=['ami', 'ari', 'aki', 'vhd', 'vmdk', 'raw', 'qcow2',
Benny Kopilov97c74192017-03-30 09:34:59 +0300700 'vdi', 'iso', 'vhdx'],
Takashi NATSUME12a48512015-08-10 18:33:16 +0900701 help="A list of image's disk formats "
702 "users can specify.")
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500703]
Jay Pipesf38eaac2012-06-21 13:37:35 -0400704
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000705image_feature_group = cfg.OptGroup(name='image-feature-enabled',
706 title='Enabled image service features')
707
708ImageFeaturesGroup = [
709 cfg.BoolOpt('api_v2',
710 default=True,
ghanshyam6b0b8b72017-03-08 04:22:53 +0000711 help="Is the v2 image API enabled",
712 deprecated_for_removal=True,
713 deprecated_reason='Glance v1 APIs are deprecated and v2 APIs '
714 'are current one. In future, Tempest will '
715 'test v2 APIs only so this config option '
716 'will be removed.'),
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000717 cfg.BoolOpt('api_v1',
zhufldc68af72018-09-05 15:47:39 +0800718 default=False,
ghanshyam6b0b8b72017-03-08 04:22:53 +0000719 help="Is the v1 image API enabled",
720 deprecated_for_removal=True,
721 deprecated_reason='Glance v1 APIs are deprecated and v2 APIs '
722 'are current one. In future, Tempest will '
723 'test v2 APIs only so this config option '
724 'will be removed.'),
Abhishek Kekane7cff1302020-07-16 10:30:13 +0000725 # Image import feature is setup in devstack victoria onwards.
726 # Once all stable branches setup the same via glance standalone
727 # mode or with uwsgi, we can remove this config option.
728 cfg.BoolOpt('import_image',
729 default=False,
730 help="Is image import feature enabled"),
Dan Smithe044dad2021-01-15 12:45:16 -0800731 # NOTE(danms): Starting mid-Wallaby glance began enforcing the
732 # previously-informal requirement that os_glance_* properties are
733 # reserved for internal use. Thus, we can only run these checks
734 # if we know we are on a new enough glance.
735 cfg.BoolOpt('os_glance_reserved',
736 default=False,
737 help="Should we check that os_glance namespace is reserved"),
Dan Smith9eaaa5a2022-10-07 09:16:20 -0700738 cfg.BoolOpt('manage_locations',
739 default=False,
740 help=('Is show_multiple_locations enabled in glance. '
741 'Note that at least one http store must be enabled as '
742 'well, because we use that location scheme to test.')),
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000743]
Jay Pipesf38eaac2012-06-21 13:37:35 -0400744
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500745network_group = cfg.OptGroup(name='network',
746 title='Network Service Options')
Daryl Walleck587385b2012-03-03 13:00:26 -0600747
Noam Angel3c6b0162018-07-08 17:05:35 +0300748ProfileType = types.Dict(types.List(types.String(), bounds=True))
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500749NetworkGroup = [
750 cfg.StrOpt('catalog_type',
751 default='network',
Mark McClainf2982e82013-07-06 17:48:03 -0400752 help='Catalog type of the Neutron service.'),
Arata Notsu8f440392013-09-13 16:14:20 +0900753 cfg.StrOpt('region',
754 default='',
755 help="The network region name to use. If empty, the value "
756 "of identity.region is used instead. If no such region "
757 "is found in the service catalog, the first found one is "
758 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000759 cfg.StrOpt('endpoint_type',
760 default='publicURL',
761 choices=['public', 'admin', 'internal',
762 'publicURL', 'adminURL', 'internalURL'],
763 help="The endpoint type to use for the network service."),
Sean Dagueed6e5862016-04-04 10:49:13 -0400764 cfg.StrOpt('project_network_cidr',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500765 default="10.100.0.0/16",
Sean Dagueed6e5862016-04-04 10:49:13 -0400766 help="The cidr block to allocate project ipv4 subnets from"),
767 cfg.IntOpt('project_network_mask_bits',
Attila Fazekas8ea181b2013-07-13 16:26:14 +0200768 default=28,
Sean Dagueed6e5862016-04-04 10:49:13 -0400769 help="The mask bits for project ipv4 subnets"),
770 cfg.StrOpt('project_network_v6_cidr',
Brian Haley56893552019-09-19 17:50:37 -0400771 default="2001:db8::/48",
Sean Dagueed6e5862016-04-04 10:49:13 -0400772 help="The cidr block to allocate project ipv6 subnets from"),
773 cfg.IntOpt('project_network_v6_mask_bits',
Sergey Shnaidman1f3659a2014-08-27 18:26:42 +0400774 default=64,
Sean Dagueed6e5862016-04-04 10:49:13 -0400775 help="The mask bits for project ipv6 subnets"),
776 cfg.BoolOpt('project_networks_reachable',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500777 default=False,
Sean Dagueed6e5862016-04-04 10:49:13 -0400778 help="Whether project networks can be reached directly from "
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000779 "the test client. This must be set to True when the "
Matt Riedemann4b0f7e72016-08-08 15:29:26 -0400780 "'fixed' connect_method is selected."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500781 cfg.StrOpt('public_network_id',
782 default="",
783 help="Id of the public network that provides external "
784 "connectivity"),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000785 cfg.StrOpt('floating_network_name',
786 help="Default floating network name. Used to allocate floating "
787 "IPs when neutron is enabled."),
Lukas Piwowarski2385e042020-01-31 12:28:20 +0000788 cfg.StrOpt('subnet_id',
789 default="",
790 help="Subnet id of subnet which is used for allocation of "
791 "floating IPs. Specify when two or more subnets are "
792 "present in network."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500793 cfg.StrOpt('public_router_id',
794 default="",
795 help="Id of the public router that provides external "
Yair Fried1eb27f52014-11-10 15:24:19 +0200796 "connectivity. This should only be used when Neutron's "
797 "'allow_overlapping_ips' is set to 'False' in "
798 "neutron.conf. usually not needed past 'Grizzly' release"),
izikpensod9a01a62014-02-17 20:02:32 +0200799 cfg.IntOpt('build_timeout',
800 default=300,
801 help="Timeout in seconds to wait for network operation to "
802 "complete."),
803 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -0400804 default=1,
izikpensod9a01a62014-02-17 20:02:32 +0200805 help="Time in seconds between network operation status "
806 "checks."),
Attila Fazekas640392b2014-06-12 15:58:10 +0200807 cfg.ListOpt('dns_servers',
808 default=["8.8.8.8", "8.8.4.4"],
Itzik Brown5be44582014-12-24 09:05:13 +0200809 help="List of dns servers which should be used"
zhufle027ea92019-05-07 14:02:23 +0800810 " for subnet creation",
811 deprecated_for_removal=True,
812 deprecated_reason="This config option is no longer "
813 "used anywhere, so it can be removed."),
Itzik Brown2ca01cd2014-12-08 12:58:20 +0200814 cfg.StrOpt('port_vnic_type',
Tom Stappaerts27fd5cb2020-11-26 12:07:47 +0100815 choices=[None, 'normal', 'direct', 'macvtap', 'direct-physical',
816 'baremetal', 'virtio-forwarder'],
Moshe Levie2c2fb12017-08-31 15:18:58 +0300817 help="vnic_type to use when launching instances"
Itzik Brown2ca01cd2014-12-08 12:58:20 +0200818 " with pre-configured ports."
819 " Supported ports are:"
Tom Stappaerts27fd5cb2020-11-26 12:07:47 +0100820 " ['normal', 'direct', 'macvtap', 'direct-physical', "
821 "'baremetal', 'virtio-forwarder']"),
Noam Angel3c6b0162018-07-08 17:05:35 +0300822 cfg.Opt('port_profile',
823 type=ProfileType,
824 default={},
825 help="port profile to use when launching instances"
826 " with pre-configured ports."),
piyush11078648e35d52015-09-24 12:56:43 +0530827 cfg.ListOpt('default_network',
828 default=["1.0.0.0/16", "2.0.0.0/16"],
829 help="List of ip pools"
830 " for subnetpools creation"),
Thiago Paiva66cded22016-08-15 14:55:58 -0300831 cfg.BoolOpt('shared_physical_network',
832 default=False,
833 help="The environment does not support network separation "
834 "between tenants."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500835]
Jay Pipes3f981df2012-03-27 18:59:44 -0400836
Matthew Treinishe3d26142013-11-26 19:14:58 +0000837network_feature_group = cfg.OptGroup(name='network-feature-enabled',
838 title='Enabled network service features')
839
840NetworkFeaturesGroup = [
Matthew Treinishe2e33cf2014-03-03 19:28:41 +0000841 cfg.BoolOpt('ipv6',
842 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500843 help="Allow the execution of IPv6 tests."),
Matthew Treinishe3d26142013-11-26 19:14:58 +0000844 cfg.ListOpt('api_extensions',
845 default=['all'],
Alexander Gubanov36e1f9b2015-06-12 18:02:10 +0300846 help="A list of enabled network extensions with a special "
847 "entry all which indicates every extension is enabled. "
848 "Empty list indicates all extensions are disabled. "
Brian Haley3d701092020-11-23 14:03:25 -0500849 "To get the list of extensions run: "
850 "'openstack extension list --network'"),
elajkatf9bb8b82020-11-02 13:41:06 +0100851 cfg.ListOpt('available_features',
852 default=['all'],
853 help="A list of available network features with a special "
854 "entry all that indicates every feature is available. "
Brian Haley3d701092020-11-23 14:03:25 -0500855 "Empty list indicates all features are disabled. "
elajkatf9bb8b82020-11-02 13:41:06 +0100856 "This list can contain features that are not "
Brian Haley3d701092020-11-23 14:03:25 -0500857 "discoverable through the API."),
Sean M. Collinsdd27a4d2014-05-13 10:33:15 -0400858 cfg.BoolOpt('ipv6_subnet_attributes',
859 default=False,
860 help="Allow the execution of IPv6 subnet tests that use "
861 "the extended IPv6 attributes ipv6_ra_mode "
Brian Haley3d701092020-11-23 14:03:25 -0500862 "and ipv6_address_mode."
Mark McClain6e07c0d2014-10-10 11:25:03 -0400863 ),
Itzik Brownbeb30d32015-03-29 09:42:54 +0300864 cfg.BoolOpt('port_admin_state_change',
865 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500866 help="Does the test environment support changing "
867 "port admin state?"),
Matt Riedemann039b2fe2016-09-15 16:12:24 -0400868 cfg.BoolOpt('port_security',
869 default=False,
870 help="Does the test environment support port security?"),
Matthew Treinish3312de32017-05-19 12:08:17 -0400871 cfg.BoolOpt('floating_ips',
872 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500873 help='Does the test environment support floating_ips?'),
Lajos Katonac87a06b2019-01-04 13:21:48 +0100874 cfg.StrOpt('qos_placement_physnet', default=None,
875 help='Name of the physnet for placement based minimum '
876 'bandwidth allocation.'),
Takashi Kajinami7138e352022-02-03 09:16:34 +0900877 cfg.StrOpt('provider_net_base_segmentation_id', default='3000',
Lajos Katonac87a06b2019-01-04 13:21:48 +0100878 help='Base segmentation ID to create provider networks. '
Balazs Gibizerf294b0d2021-09-29 16:16:44 +0200879 'This value will be increased in case of conflict.'),
880 cfg.BoolOpt('qos_min_bw_and_pps', default=False,
881 help='Does the test environment have minimum bandwidth and '
882 'packet rate inventories configured?'),
Matthew Treinishe3d26142013-11-26 19:14:58 +0000883]
884
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -0600885dashboard_group = cfg.OptGroup(name="dashboard",
886 title="Dashboard options")
887
888DashboardGroup = [
889 cfg.StrOpt('dashboard_url',
890 default='http://localhost/',
891 help="Where the dashboard can be found"),
892 cfg.BoolOpt('disable_ssl_certificate_validation',
893 default=False,
894 help="Set to True if using self-signed SSL certificates."),
895]
896
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000897validation_group = cfg.OptGroup(name='validation',
898 title='SSH Validation options')
899
900ValidationGroup = [
Matthew Treinishe5cca002015-05-11 15:36:50 -0400901 cfg.BoolOpt('run_validation',
Attila Fazekas489e90f2018-09-12 17:30:01 -0600902 default=True,
Matthew Treinishe5cca002015-05-11 15:36:50 -0400903 help='Enable ssh on created servers and creation of additional'
Attila Fazekas489e90f2018-09-12 17:30:01 -0600904 ' validation resources to enable remote access.'
905 ' In case the guest does not support ssh set it'
906 ' to false'),
Brandon Palmc6cc91d2015-08-19 13:20:21 -0500907 cfg.BoolOpt('security_group',
908 default=True,
909 help='Enable/disable security groups.'),
910 cfg.BoolOpt('security_group_rules',
911 default=True,
912 help='Enable/disable security group rules.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000913 cfg.StrOpt('connect_method',
914 default='floating',
915 choices=['fixed', 'floating'],
916 help='Default IP type used for validation: '
917 '-fixed: uses the first IP belonging to the fixed network '
ghanshyamade71d22017-02-15 05:36:14 +0000918 '-floating: creates and uses a floating IP'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000919 cfg.StrOpt('auth_method',
920 default='keypair',
921 choices=['keypair'],
922 help='Default authentication method to the instance. '
923 'Only ssh via keypair is supported for now. '
ghanshyamade71d22017-02-15 05:36:14 +0000924 'Additional methods will be handled in a separate spec.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000925 cfg.IntOpt('ip_version_for_ssh',
926 default=4,
lanoux283273b2015-12-04 03:01:54 -0800927 help='Default IP version for ssh connections.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000928 cfg.IntOpt('ping_timeout',
929 default=120,
ghanshyam244cf7c2017-02-15 06:39:31 +0000930 help='Timeout in seconds to wait for ping to succeed.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000931 cfg.IntOpt('connect_timeout',
932 default=60,
933 help='Timeout in seconds to wait for the TCP connection to be '
lanoux283273b2015-12-04 03:01:54 -0800934 'successful.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000935 cfg.IntOpt('ssh_timeout',
936 default=300,
lanoux283273b2015-12-04 03:01:54 -0800937 help='Timeout in seconds to wait for the ssh banner.'),
938 cfg.StrOpt('image_ssh_user',
939 default="root",
ghanshyam244cf7c2017-02-15 06:39:31 +0000940 help="User name used to authenticate to an instance."),
Weronika Sikorac54a9112019-09-18 13:55:07 +0000941 cfg.StrOpt('image_alt_ssh_user',
942 default="root",
943 help="User name used to authenticate to an alt instance."),
lanoux283273b2015-12-04 03:01:54 -0800944 cfg.StrOpt('image_ssh_password',
945 default="password",
Doug Schveninger6a2be432020-04-29 17:42:31 -0500946 help="Password used to authenticate to an instance.",
947 secret=True),
Weronika Sikorac54a9112019-09-18 13:55:07 +0000948 cfg.StrOpt('image_alt_ssh_password',
949 default="password",
950 help="Password used to authenticate to an alt instance.",
951 secret=True),
lanoux283273b2015-12-04 03:01:54 -0800952 cfg.StrOpt('ssh_shell_prologue',
Lucian Petrut6a7472a2019-08-07 12:43:08 +0300953 default="set -eu -o pipefail; PATH=$$PATH:/sbin:/usr/sbin;",
lanoux283273b2015-12-04 03:01:54 -0800954 help="Shell fragments to use before executing a command "
ghanshyamade71d22017-02-15 05:36:14 +0000955 "when sshing to a guest."),
lanoux283273b2015-12-04 03:01:54 -0800956 cfg.IntOpt('ping_size',
957 default=56,
958 help="The packet size for ping packets originating "
ghanshyamade71d22017-02-15 05:36:14 +0000959 "from remote linux hosts"),
lanoux283273b2015-12-04 03:01:54 -0800960 cfg.IntOpt('ping_count',
961 default=1,
962 help="The number of ping packets originating from remote "
ghanshyamade71d22017-02-15 05:36:14 +0000963 "linux hosts"),
lanoux283273b2015-12-04 03:01:54 -0800964 cfg.StrOpt('floating_ip_range',
965 default='10.0.0.0/29',
966 help='Unallocated floating IP range, which will be used to '
967 'test the floating IP bulk feature for CRUD operation. '
968 'This block must not overlap an existing floating IP '
ghanshyamade71d22017-02-15 05:36:14 +0000969 'pool.'),
lanoux283273b2015-12-04 03:01:54 -0800970 cfg.StrOpt('network_for_ssh',
971 default='public',
972 help="Network used for SSH connections. Ignored if "
ghanshyam244cf7c2017-02-15 06:39:31 +0000973 "connect_method=floating."),
Ade Lee6ded0702021-09-04 15:56:34 -0400974 cfg.StrOpt('ssh_key_type',
Martin Kopec75ca0b82022-04-20 17:57:45 +0200975 default='ecdsa',
Ade Lee6ded0702021-09-04 15:56:34 -0400976 help='Type of key to use for ssh connections. '
977 'Valid types are rsa, ecdsa'),
Roman Safronov72575882022-02-10 12:26:43 +0200978 cfg.IntOpt('allowed_network_downtime',
979 default=5.0,
980 help="Allowed VM network connection downtime during live "
981 "migration, in seconds. "
982 "When the measured downtime exceeds this value, an "
983 "exception is raised."),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000984]
985
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500986volume_group = cfg.OptGroup(name='volume',
987 title='Block Storage Options')
Daryl Walleck587385b2012-03-03 13:00:26 -0600988
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500989VolumeGroup = [
990 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -0400991 default=1,
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500992 help='Time in seconds between volume availability checks.'),
993 cfg.IntOpt('build_timeout',
994 default=300,
Eric Harney9b1f89c2014-10-14 14:40:19 -0400995 help='Timeout in seconds to wait for a volume to become '
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500996 'available.'),
997 cfg.StrOpt('catalog_type',
ghanshyam89c213f2017-12-14 07:22:12 +0000998 default='volumev3',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500999 help="Catalog type of the Volume Service"),
Arata Notsu8f440392013-09-13 16:14:20 +09001000 cfg.StrOpt('region',
1001 default='',
1002 help="The volume region name to use. If empty, the value "
1003 "of identity.region is used instead. If no such region "
1004 "is found in the service catalog, the first found one is "
1005 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +00001006 cfg.StrOpt('endpoint_type',
1007 default='publicURL',
1008 choices=['public', 'admin', 'internal',
1009 'publicURL', 'adminURL', 'internalURL'],
1010 help="The endpoint type to use for the volume service."),
Benny Kopilovaf136a92015-11-10 07:37:23 +02001011 cfg.ListOpt('backend_names',
1012 default=['BACKEND_1', 'BACKEND_2'],
april4be58dc2015-12-29 00:07:22 +08001013 help='A list of backend names separated by comma. '
bkopilov27905cc2016-04-12 14:29:13 +03001014 'The backend name must be declared in cinder.conf'),
Ansuman Bebarta46d540d2021-02-16 18:48:33 +05301015 cfg.StrOpt('volume_type',
1016 default='',
1017 help='Volume type to be used while creating volume.'),
Adam Gandelman827ad332013-06-24 17:04:09 -07001018 cfg.StrOpt('storage_protocol',
1019 default='iSCSI',
1020 help='Backend protocol to target when creating volume types'),
1021 cfg.StrOpt('vendor_name',
1022 default='Open Source',
1023 help='Backend vendor to target when creating volume types'),
Ryan Hsua67f4632013-08-29 16:03:06 -07001024 cfg.StrOpt('disk_format',
1025 default='raw',
1026 help='Disk format to use when copying a volume to image'),
Jerry Cai9733d0e2014-03-19 15:50:49 +08001027 cfg.IntOpt('volume_size',
1028 default=1,
1029 help='Default size in GB for volumes created by volumes tests'),
Martin Kopec37c4bd32021-06-24 15:46:00 +00001030 cfg.IntOpt('volume_size_extend',
1031 default=1,
1032 help="Size in GB a volume is extended by - if a test "
1033 "extends a volume, the size of the new volume will be "
1034 "volume_size + volume_size_extend."),
jeremy.zhangf4fbf302017-03-22 11:25:53 +08001035 cfg.ListOpt('manage_volume_ref',
1036 default=['source-name', 'volume-%s'],
1037 help="A reference to existing volume for volume manage. "
1038 "It contains two elements, the first is ref type "
1039 "(like 'source-name', 'source-id', etc), the second is "
1040 "volume name template used in storage backend"),
jeremy.zhangebc752b2017-06-14 13:58:37 +08001041 cfg.ListOpt('manage_snapshot_ref',
1042 default=['source-name', '_snapshot-%s'],
1043 help="A reference to existing snapshot for snapshot manage. "
1044 "It contains two elements, the first is ref type "
1045 "(like 'source-name', 'source-id', etc), the second is "
1046 "snapshot name template used in storage backend"),
Andrew Kerrfcb0b682016-04-01 16:01:34 -04001047 cfg.StrOpt('min_microversion',
1048 default=None,
1049 help="Lower version of the test target microversion range. "
1050 "The format is 'X.Y', where 'X' and 'Y' are int values. "
1051 "Tempest selects tests based on the range between "
1052 "min_microversion and max_microversion. "
1053 "If both values are not specified, Tempest avoids tests "
1054 "which require a microversion. Valid values are string "
1055 "with format 'X.Y' or string 'latest'",),
1056 cfg.StrOpt('max_microversion',
1057 default=None,
1058 help="Upper version of the test target microversion range. "
1059 "The format is 'X.Y', where 'X' and 'Y' are int values. "
1060 "Tempest selects tests based on the range between "
1061 "min_microversion and max_microversion. "
1062 "If both values are not specified, Tempest avoids tests "
1063 "which require a microversion. Valid values are string "
1064 "with format 'X.Y' or string 'latest'",),
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001065]
K Jonathan Harkerd6ba4b42012-12-18 13:50:47 -08001066
Matthew Treinishd5c96022013-10-17 21:51:23 +00001067volume_feature_group = cfg.OptGroup(name='volume-feature-enabled',
1068 title='Enabled Cinder Features')
1069
1070VolumeFeaturesGroup = [
1071 cfg.BoolOpt('multi_backend',
1072 default=False,
Matthew Treinishe3d26142013-11-26 19:14:58 +00001073 help="Runs Cinder multi-backend test (requires 2 backends)"),
Giulio Fidente74b08ad2014-01-18 04:02:51 +01001074 cfg.BoolOpt('backup',
1075 default=True,
1076 help='Runs Cinder volumes backup test'),
JordanPbce55532014-03-19 12:10:32 +01001077 cfg.BoolOpt('snapshot',
1078 default=True,
1079 help='Runs Cinder volume snapshot test'),
Takeaki Matsumoto1702aed2015-08-25 08:44:26 +09001080 cfg.BoolOpt('clone',
1081 default=True,
1082 help='Runs Cinder volume clone test'),
Jordan Pittier31256252017-01-11 14:29:49 +01001083 cfg.BoolOpt('manage_snapshot',
1084 default=False,
1085 help='Runs Cinder manage snapshot tests'),
jeremy.zhangf4fbf302017-03-22 11:25:53 +08001086 cfg.BoolOpt('manage_volume',
1087 default=False,
1088 help='Runs Cinder manage volume tests'),
Matthew Treinishe3d26142013-11-26 19:14:58 +00001089 cfg.ListOpt('api_extensions',
1090 default=['all'],
Zhi Kun Liude25c022014-02-14 13:25:19 +08001091 help='A list of enabled volume extensions with a special '
Simeon Monov5d7effe2014-07-16 07:32:38 +03001092 'entry all which indicates every extension is enabled. '
1093 'Empty list indicates all extensions are disabled'),
Matt Riedemann0cc76bf2017-07-05 17:29:31 -04001094 cfg.BoolOpt('extend_attached_volume',
1095 default=False,
1096 help='Does the cloud support extending the size of a volume '
1097 'which is currently attached to a server instance? This '
1098 'depends on the 3.42 volume API microversion and the '
1099 '2.51 compute API microversion. Also, not all volume or '
Lee Yarwood4bd9edb2020-01-31 17:26:25 +00001100 'compute backends support this operation.'),
1101 cfg.BoolOpt('extend_attached_encrypted_volume',
1102 default=False,
1103 help='Does the cloud support extending the size of an '
1104 'encrypted volume which is currently attached to a '
1105 'server instance? This depends on the 3.42 volume API '
1106 'microversion and the 2.51 compute API microversion. '
1107 'Also, not all volume or compute backends support this '
1108 'operation.')
Matthew Treinishd5c96022013-10-17 21:51:23 +00001109]
1110
Daryl Walleck587385b2012-03-03 13:00:26 -06001111
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001112object_storage_group = cfg.OptGroup(name='object-storage',
1113 title='Object Storage Service Options')
Attila Fazekasa23f5002012-10-23 19:32:45 +02001114
DennyZhang1e71b612013-09-26 12:35:40 -05001115ObjectStoreGroup = [
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001116 cfg.StrOpt('catalog_type',
1117 default='object-store',
1118 help="Catalog type of the Object-Storage service."),
Arata Notsu8f440392013-09-13 16:14:20 +09001119 cfg.StrOpt('region',
1120 default='',
1121 help="The object-storage region name to use. If empty, the "
1122 "value of identity.region is used instead. If no such "
1123 "region is found in the service catalog, the first found "
1124 "one is used."),
JordanP5d29b2c2013-12-18 13:56:03 +00001125 cfg.StrOpt('endpoint_type',
1126 default='publicURL',
1127 choices=['public', 'admin', 'internal',
1128 'publicURL', 'adminURL', 'internalURL'],
1129 help="The endpoint type to use for the object-store service."),
Matthew Treinishf319a732013-10-24 21:39:24 +00001130 cfg.IntOpt('container_sync_timeout',
Daisuke Morita1ac3ee02014-08-25 12:59:18 +09001131 default=600,
Fabien Boucher2178d312013-12-31 15:38:57 +01001132 help="Number of seconds to time on waiting for a container "
nayna-patelb4989b32013-01-09 06:25:13 +00001133 "to container synchronization complete."),
Matthew Treinishf319a732013-10-24 21:39:24 +00001134 cfg.IntOpt('container_sync_interval',
nayna-patelb4989b32013-01-09 06:25:13 +00001135 default=5,
Fabien Boucher2178d312013-12-31 15:38:57 +01001136 help="Number of seconds to wait while looping to check the "
nayna-patelb4989b32013-01-09 06:25:13 +00001137 "status of a container to container synchronization"),
Matthew Treinish3fdb80c2013-08-15 11:13:19 -04001138 cfg.StrOpt('operator_role',
Martin Kopec99d4dae2020-05-27 10:33:17 +00001139 default='member',
Matthew Treinish3fdb80c2013-08-15 11:13:19 -04001140 help="Role to add to users created for swift tests to "
1141 "enable creating containers"),
Matthew Treinish998c91d2014-03-01 12:39:49 -05001142 cfg.StrOpt('reseller_admin_role',
1143 default='ResellerAdmin',
1144 help="User role that has reseller admin"),
Daisuke Morita1ac3ee02014-08-25 12:59:18 +09001145 cfg.StrOpt('realm_name',
1146 default='realm1',
1147 help="Name of sync realm. A sync realm is a set of clusters "
1148 "that have agreed to allow container syncing with each "
1149 "other. Set the same realm name as Swift's "
1150 "container-sync-realms.conf"),
1151 cfg.StrOpt('cluster_name',
1152 default='name1',
1153 help="One name of cluster which is set in the realm whose name "
1154 "is set in 'realm_name' item in this file. Set the "
1155 "same cluster name as Swift's container-sync-realms.conf"),
Bas de Bruijnec9f9a032022-07-19 11:16:02 -03001156 cfg.IntOpt('build_timeout',
1157 default=10,
1158 help="Timeout in seconds to wait for objects to create."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001159]
Attila Fazekasa23f5002012-10-23 19:32:45 +02001160
Matthew Treinishd5c96022013-10-17 21:51:23 +00001161object_storage_feature_group = cfg.OptGroup(
1162 name='object-storage-feature-enabled',
1163 title='Enabled object-storage features')
1164
1165ObjectStoreFeaturesGroup = [
Matthew Treinish20345382013-12-13 17:04:23 +00001166 cfg.ListOpt('discoverable_apis',
1167 default=['all'],
1168 help="A list of the enabled optional discoverable apis. "
1169 "A single entry, all, indicates that all of these "
1170 "features are expected to be enabled"),
Daisuke Morita20a183f2014-08-25 14:43:36 +09001171 cfg.BoolOpt('container_sync',
1172 default=True,
1173 help="Execute (old style) container-sync tests"),
1174 cfg.BoolOpt('object_versioning',
1175 default=True,
1176 help="Execute object-versioning tests"),
1177 cfg.BoolOpt('discoverability',
1178 default=True,
1179 help="Execute discoverability tests"),
Giulio Fidente95758b12022-07-14 15:14:24 +02001180 cfg.StrOpt('tempurl_digest_hashlib',
1181 default='sha256',
1182 help="Hashing algorithm to use for the temp_url tests. "
1183 "Needs to be supported both by Swift and the "
1184 "hashlib module, for example sha1 or sha256"),
Matthew Treinishd5c96022013-10-17 21:51:23 +00001185]
1186
Luigi Toscano14d172d2015-01-23 16:37:47 +01001187
Masayuki Igawa73d9f3a2013-05-24 10:30:01 +09001188scenario_group = cfg.OptGroup(name='scenario', title='Scenario Test Options')
1189
1190ScenarioGroup = [
Alessandro Pilottib7c1daa2014-08-16 14:24:13 +03001191 cfg.StrOpt('img_file', deprecated_name='qcow2_img_file',
Martin Kopec02af6a42020-03-03 12:39:12 +00001192 default='/opt/stack/new/devstack/files/images'
1193 '/cirros-0.3.1-x86_64-disk.img',
1194 help='Image full path.'),
Alessandro Pilottib7c1daa2014-08-16 14:24:13 +03001195 cfg.StrOpt('img_disk_format',
1196 default='qcow2',
1197 help='Image disk format'),
1198 cfg.StrOpt('img_container_format',
1199 default='bare',
1200 help='Image container format'),
Evgeny Antyshev7ba0d5f2015-04-28 13:18:07 +00001201 cfg.DictOpt('img_properties', help='Glance image properties. '
1202 'Use for custom images which require them'),
Yair Fried413bf2d2014-11-19 17:07:11 +02001203 cfg.StrOpt('dhcp_client',
1204 default='udhcpc',
Slawek Kaplonski49163f92023-01-20 12:20:35 +01001205 choices=["udhcpc", "dhclient", "dhcpcd", ""],
Yair Fried413bf2d2014-11-19 17:07:11 +02001206 help='DHCP client used by images to renew DCHP lease. '
1207 'If left empty, update operation will be skipped. '
Slawek Kaplonski49163f92023-01-20 12:20:35 +01001208 'Supported clients: "udhcpc", "dhclient", "dhcpcd"'),
Claudiu Belu33c3e602014-08-28 16:38:01 +03001209 cfg.StrOpt('protocol',
1210 default='icmp',
1211 choices=('icmp', 'tcp', 'udp'),
1212 help='The protocol used in security groups tests to check '
1213 'connectivity.'),
Masayuki Igawa73d9f3a2013-05-24 10:30:01 +09001214]
1215
1216
Matthew Treinish4c412922013-07-16 15:27:42 -04001217service_available_group = cfg.OptGroup(name="service_available",
1218 title="Available OpenStack Services")
1219
1220ServiceAvailableGroup = [
1221 cfg.BoolOpt('cinder',
1222 default=True,
1223 help="Whether or not cinder is expected to be available"),
Matthew Treinishfaa340d2013-07-19 16:26:21 -04001224 cfg.BoolOpt('neutron',
1225 default=False,
1226 help="Whether or not neutron is expected to be available"),
Matthew Treinish853ae442013-07-19 16:36:07 -04001227 cfg.BoolOpt('glance',
1228 default=True,
1229 help="Whether or not glance is expected to be available"),
Matthew Treinish61e332b2013-07-19 16:42:31 -04001230 cfg.BoolOpt('swift',
1231 default=True,
1232 help="Whether or not swift is expected to be available"),
Matthew Treinish6b41e242013-07-19 16:49:28 -04001233 cfg.BoolOpt('nova',
1234 default=True,
1235 help="Whether or not nova is expected to be available"),
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001236 cfg.BoolOpt('horizon',
1237 default=True,
1238 help="Whether or not horizon is expected to be available"),
Matthew Treinish4c412922013-07-16 15:27:42 -04001239]
1240
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001241enforce_scope_group = cfg.OptGroup(name="enforce_scope",
1242 title="OpenStack Services with "
1243 "enforce scope")
1244
1245
1246EnforceScopeGroup = [
1247 cfg.BoolOpt('nova',
1248 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001249 help='Does the compute service API policies enforce scope and '
1250 'new defaults? This configuration value should be '
1251 'enabled when nova.conf: [oslo_policy]. '
1252 'enforce_new_defaults and nova.conf: [oslo_policy]. '
1253 'enforce_scope options are enabled in nova conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001254 cfg.BoolOpt('neutron',
1255 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001256 help='Does the network service API policies enforce scope and '
1257 'new defaults? This configuration value should be '
1258 'enabled when neutron.conf: [oslo_policy]. '
1259 'enforce_new_defaults and neutron.conf: [oslo_policy]. '
1260 'enforce_scope options are enabled in neutron conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001261 cfg.BoolOpt('glance',
1262 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001263 help='Does the Image service API policies enforce scope and '
1264 'new defaults? This configuration value should be '
1265 'enabled when glance.conf: [oslo_policy]. '
1266 'enforce_new_defaults and glance.conf: [oslo_policy]. '
1267 'enforce_scope options are enabled in glance conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001268 cfg.BoolOpt('cinder',
1269 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001270 help='Does the Volume service API policies enforce scope and '
1271 'new defaults? This configuration value should be '
1272 'enabled when cinder.conf: [oslo_policy]. '
1273 'enforce_new_defaults and cinder.conf: [oslo_policy]. '
1274 'enforce_scope options are enabled in cinder conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001275 cfg.BoolOpt('keystone',
1276 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001277 help='Does the Identity service API policies enforce scope '
1278 'and new defaults? This configuration value should be '
1279 'enabled when keystone.conf: [oslo_policy]. '
1280 'enforce_new_defaults and keystone.conf: [oslo_policy]. '
1281 'enforce_scope options are enabled in keystone conf.'),
Ghanshyam Mannb6521a82022-11-30 14:31:30 -06001282 cfg.BoolOpt('placement',
1283 default=False,
1284 help='Does the placement service API policies enforce scope '
1285 'and new defaults? This configuration value should be '
1286 'enabled when placement.conf: [oslo_policy]. '
1287 'enforce_new_defaults and nova.conf: [oslo_policy]. '
1288 'enforce_scope options are enabled in placement conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001289]
1290
Attila Fazekasaeeeefd2013-08-06 17:01:56 +02001291debug_group = cfg.OptGroup(name="debug",
1292 title="Debug System")
1293
1294DebugGroup = [
Sean Daguec522c092014-03-24 10:43:22 -04001295 cfg.StrOpt('trace_requests',
1296 default='',
1297 help="""A regex to determine which requests should be traced.
1298
1299This is a regex to match the caller for rest client requests to be able to
1300selectively trace calls out of specific classes and methods. It largely
1301exists for test development, and is not expected to be used in a real deploy
1302of tempest. This will be matched against the discovered ClassName:method
1303in the test environment.
1304
1305Expected values for this field are:
1306
1307 * ClassName:test_method_name - traces one test_method
1308 * ClassName:setUp(Class) - traces specific setup functions
1309 * ClassName:tearDown(Class) - traces specific teardown functions
1310 * ClassName:_run_cleanups - traces the cleanup functions
1311
1312If nothing is specified, this feature is not enabled. To trace everything
1313specify .* as the regex.
1314""")
Attila Fazekasaeeeefd2013-08-06 17:01:56 +02001315]
1316
Ilya Shakhat1291bb42017-11-29 18:08:16 +01001317
1318profiler_group = cfg.OptGroup(name="profiler",
1319 title="OpenStack Profiler")
1320
1321ProfilerGroup = [
1322 cfg.StrOpt('key',
1323 help="The secret key to enable OpenStack Profiler. The value "
1324 "should match the one configured in OpenStack services "
1325 "under `[profiler]/hmac_keys` property. The default empty "
1326 "value keeps profiling disabled"),
1327]
1328
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001329DefaultGroup = [
Martin Kopecae155b72017-06-26 09:41:21 +00001330 cfg.BoolOpt('pause_teardown',
1331 default=False,
1332 help="""Whether to pause a test in global teardown.
1333
1334The best use case is investigating used resources of one test.
1335A test can be run as follows:
Soniya Vyase42bd932019-11-26 16:14:33 +05301336 $ stestr run --pdb TEST_ID
Martin Kopecae155b72017-06-26 09:41:21 +00001337or
1338 $ python -m testtools.run TEST_ID"""),
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001339]
1340
Jon Grimm270bd7f2014-08-05 18:11:29 +00001341_opts = [
1342 (auth_group, AuthGroup),
1343 (compute_group, ComputeGroup),
1344 (compute_features_group, ComputeFeaturesGroup),
1345 (identity_group, IdentityGroup),
zhufl071e94c2016-07-12 10:26:34 +08001346 (service_clients_group, ServiceClientsGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001347 (identity_feature_group, IdentityFeatureGroup),
1348 (image_group, ImageGroup),
1349 (image_feature_group, ImageFeaturesGroup),
1350 (network_group, NetworkGroup),
1351 (network_feature_group, NetworkFeaturesGroup),
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001352 (dashboard_group, DashboardGroup),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001353 (validation_group, ValidationGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001354 (volume_group, VolumeGroup),
1355 (volume_feature_group, VolumeFeaturesGroup),
1356 (object_storage_group, ObjectStoreGroup),
1357 (object_storage_feature_group, ObjectStoreFeaturesGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001358 (scenario_group, ScenarioGroup),
1359 (service_available_group, ServiceAvailableGroup),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001360 (enforce_scope_group, EnforceScopeGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001361 (debug_group, DebugGroup),
Lajos Katonaceb88212018-11-30 14:54:12 +01001362 (placement_group, PlacementGroup),
Ilya Shakhat1291bb42017-11-29 18:08:16 +01001363 (profiler_group, ProfilerGroup),
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001364 (None, DefaultGroup)
Jon Grimm270bd7f2014-08-05 18:11:29 +00001365]
1366
Roman Prykhodchenko62b1ed12013-10-16 21:51:47 +03001367
Matthew Treinish43b296a2014-02-28 15:23:00 -05001368def register_opts():
Matthew Treinisha966d0f2015-07-01 17:37:31 -04001369 ext_plugins = plugins.TempestTestPluginManager()
1370 # Register in-tree tempest config options
Jon Grimm270bd7f2014-08-05 18:11:29 +00001371 for g, o in _opts:
Maru Newbyf440c292015-03-31 15:58:47 +00001372 register_opt_group(_CONF, g, o)
Matthew Treinisha966d0f2015-07-01 17:37:31 -04001373 # Call external plugin config option registration
1374 ext_plugins.register_plugin_opts(_CONF)
Jon Grimm270bd7f2014-08-05 18:11:29 +00001375
1376
1377def list_opts():
1378 """Return a list of oslo.config options available.
1379
1380 The purpose of this is to allow tools like the Oslo sample config file
1381 generator to discover the options exposed to users.
1382 """
Matthew Treinish83a19aa2015-07-23 13:06:13 -04001383 ext_plugins = plugins.TempestTestPluginManager()
Chris Hoged7b4fd12015-11-11 10:24:52 -08001384 # Make a shallow copy of the options list that can be
1385 # extended by plugins. Send back the group object
1386 # to allow group help text to be generated.
1387 opt_list = [(g, o) for g, o in _opts]
Matthew Treinish83a19aa2015-07-23 13:06:13 -04001388 opt_list.extend(ext_plugins.get_plugin_options_list())
1389 return opt_list
Matthew Treinish43b296a2014-02-28 15:23:00 -05001390
1391
Ken'ichi Ohmichi3f5c1392018-04-11 14:38:22 -07001392# This should never be called outside of this module
Sean Dague3b9b1f32013-12-20 17:04:54 -05001393class TempestConfigPrivate(object):
Daryl Walleck1465d612011-11-02 02:22:15 -05001394 """Provides OpenStack configuration information."""
1395
David Patersonbe9f9832015-10-15 09:10:45 -07001396 DEFAULT_CONFIG_DIR = os.path.join(os.getcwd(), "etc")
Daryl Walleck1465d612011-11-02 02:22:15 -05001397
Brian Waldon738cd632011-12-12 18:45:09 -05001398 DEFAULT_CONFIG_FILE = "tempest.conf"
1399
Andrea Frittolia96ee212014-08-15 18:34:20 +01001400 def __getattr__(self, attr):
1401 # Handles config options from the default group
Maru Newbyf440c292015-03-31 15:58:47 +00001402 return getattr(_CONF, attr)
Andrea Frittolia96ee212014-08-15 18:34:20 +01001403
Matthew Treinish43b296a2014-02-28 15:23:00 -05001404 def _set_attrs(self):
Andrea Frittoli382a6f12017-03-09 11:52:17 +00001405 # This methods ensures that config options in Tempest as well as
1406 # in Tempest plugins can be accessed via:
1407 # CONF.<normalised_group_name>.<key_name>
1408 # where:
1409 # normalised_group_name = group_name.replace('-', '_')
1410 # Attributes are set at __init__ time *only* for known option groups
Maru Newbyf440c292015-03-31 15:58:47 +00001411 self.auth = _CONF.auth
1412 self.compute = _CONF.compute
1413 self.compute_feature_enabled = _CONF['compute-feature-enabled']
1414 self.identity = _CONF.identity
zhufl071e94c2016-07-12 10:26:34 +08001415 self.service_clients = _CONF['service-clients']
Maru Newbyf440c292015-03-31 15:58:47 +00001416 self.identity_feature_enabled = _CONF['identity-feature-enabled']
1417 self.image = _CONF.image
1418 self.image_feature_enabled = _CONF['image-feature-enabled']
1419 self.network = _CONF.network
1420 self.network_feature_enabled = _CONF['network-feature-enabled']
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001421 self.dashboard = _CONF.dashboard
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001422 self.validation = _CONF.validation
Maru Newbyf440c292015-03-31 15:58:47 +00001423 self.volume = _CONF.volume
1424 self.volume_feature_enabled = _CONF['volume-feature-enabled']
1425 self.object_storage = _CONF['object-storage']
1426 self.object_storage_feature_enabled = _CONF[
Matthew Treinishd5c96022013-10-17 21:51:23 +00001427 'object-storage-feature-enabled']
Maru Newbyf440c292015-03-31 15:58:47 +00001428 self.scenario = _CONF.scenario
1429 self.service_available = _CONF.service_available
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001430 self.enforce_scope = _CONF.enforce_scope
Maru Newbyf440c292015-03-31 15:58:47 +00001431 self.debug = _CONF.debug
Matthew Treinish46008082015-04-14 18:32:47 -04001432 logging.tempest_set_log_file('tempest.log')
Andrea Frittoli382a6f12017-03-09 11:52:17 +00001433 # Setting attributes for plugins
1434 # NOTE(andreaf) Plugins have no access to the TempestConfigPrivate
1435 # instance at discovery time, so they have no way of setting these
1436 # aliases themselves.
1437 ext_plugins = plugins.TempestTestPluginManager()
1438 for group, _ in ext_plugins.get_plugin_options_list():
1439 if isinstance(group, cfg.OptGroup):
1440 # If we have an OptGroup
1441 group_name = group.name
1442 group_dest = group.dest
1443 else:
1444 # If we have a group name as a string
1445 group_name = group
1446 group_dest = group.replace('-', '_')
1447 # NOTE(andreaf) We can set the attribute safely here since in
1448 # case of name conflict we would not have reached this point.
1449 setattr(self, group_dest, _CONF[group_name])
Sean Dague86bd8422013-12-20 09:56:44 -05001450
Joe Gordon28a84ae2014-07-17 15:38:28 +00001451 def __init__(self, parse_conf=True, config_path=None):
Matthew Treinish43b296a2014-02-28 15:23:00 -05001452 """Initialize a configuration from a conf directory and conf file."""
1453 super(TempestConfigPrivate, self).__init__()
1454 config_files = []
1455 failsafe_path = "/etc/tempest/" + self.DEFAULT_CONFIG_FILE
1456
Joe Gordon28a84ae2014-07-17 15:38:28 +00001457 if config_path:
1458 path = config_path
1459 else:
1460 # Environment variables override defaults...
1461 conf_dir = os.environ.get('TEMPEST_CONFIG_DIR',
1462 self.DEFAULT_CONFIG_DIR)
1463 conf_file = os.environ.get('TEMPEST_CONFIG',
1464 self.DEFAULT_CONFIG_FILE)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001465
Joe Gordon28a84ae2014-07-17 15:38:28 +00001466 path = os.path.join(conf_dir, conf_file)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001467
1468 if not os.path.isfile(path):
1469 path = failsafe_path
1470
1471 # only parse the config file if we expect one to exist. This is needed
1472 # to remove an issue with the config file up to date checker.
1473 if parse_conf:
1474 config_files.append(path)
Maru Newbyf440c292015-03-31 15:58:47 +00001475 logging.register_options(_CONF)
Matthew Treinish5440a402014-10-02 14:36:16 -04001476 if os.path.isfile(path):
Maru Newbyf440c292015-03-31 15:58:47 +00001477 _CONF([], project='tempest', default_config_files=config_files)
Matthew Treinish5440a402014-10-02 14:36:16 -04001478 else:
Maru Newbyf440c292015-03-31 15:58:47 +00001479 _CONF([], project='tempest')
Marc Kodererc81c7672015-12-17 12:10:12 +01001480
1481 logging_cfg_path = "%s/logging.conf" % os.path.dirname(path)
Tom Patzige6f7c7d2016-02-17 16:46:11 +01001482 if ((not hasattr(_CONF, 'log_config_append') or
afazekas40fcb9b2019-03-08 11:25:11 +01001483 _CONF.log_config_append is None) and
Marc Kodererc81c7672015-12-17 12:10:12 +01001484 os.path.isfile(logging_cfg_path)):
1485 # if logging conf is in place we need to set log_config_append
1486 _CONF.log_config_append = logging_cfg_path
1487
Maru Newbyf440c292015-03-31 15:58:47 +00001488 logging.setup(_CONF, 'tempest')
Matthew Treinish43b296a2014-02-28 15:23:00 -05001489 LOG = logging.getLogger('tempest')
Jordan Pittier525ec712016-12-07 17:51:26 +01001490 LOG.info("Using tempest config file %s", path)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001491 register_opts()
1492 self._set_attrs()
Masayuki Igawa9ec4cd82014-02-05 15:04:16 +09001493 if parse_conf:
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301494 _CONF.log_opt_values(LOG, logging.DEBUG)
Masayuki Igawa9ec4cd82014-02-05 15:04:16 +09001495
Sean Dague86bd8422013-12-20 09:56:44 -05001496
1497class TempestConfigProxy(object):
1498 _config = None
Joe Gordon28a84ae2014-07-17 15:38:28 +00001499 _path = None
Sean Dague86bd8422013-12-20 09:56:44 -05001500
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001501 _extra_log_defaults = [
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301502 ('paramiko.transport', logging.INFO),
1503 ('requests.packages.urllib3.connectionpool', logging.WARN),
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001504 ]
1505
1506 def _fix_log_levels(self):
1507 """Tweak the oslo log defaults."""
Doug Hellmann583ce2c2015-03-11 14:55:46 +00001508 for name, level in self._extra_log_defaults:
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301509 logging.getLogger(name).logger.setLevel(level)
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001510
Sean Dague86bd8422013-12-20 09:56:44 -05001511 def __getattr__(self, attr):
1512 if not self._config:
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001513 self._fix_log_levels()
Matthew Treinishaa29c7e2015-04-23 16:35:09 -04001514 lock_dir = os.path.join(tempfile.gettempdir(), 'tempest-lock')
1515 lockutils.set_defaults(lock_dir)
Joe Gordon28a84ae2014-07-17 15:38:28 +00001516 self._config = TempestConfigPrivate(config_path=self._path)
Sean Dague86bd8422013-12-20 09:56:44 -05001517
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001518 # Pushing tempest internal service client configuration to the
1519 # service clients register. Doing this in the config module ensures
1520 # that the configuration is available by the time we register the
1521 # service clients.
1522 # NOTE(andreaf) This has to be done at the time the first
1523 # attribute is accessed, to ensure all plugins have been already
1524 # loaded, options registered, and _config is set.
1525 _register_tempest_service_clients()
1526
Andrea Frittoli8b23c792017-03-09 13:17:01 +00001527 # Registering service clients and pushing their configuration to
1528 # the service clients register. Doing this in the config module
1529 # ensures that the configuration is available by the time we
1530 # discover tests from plugins.
1531 plugins.TempestTestPluginManager()._register_service_clients()
1532
Sean Dague86bd8422013-12-20 09:56:44 -05001533 return getattr(self._config, attr)
1534
Joe Gordon28a84ae2014-07-17 15:38:28 +00001535 def set_config_path(self, path):
1536 self._path = path
Masayuki Igawa79159f82018-07-27 15:00:37 +09001537 # FIXME(masayukig): bug#1783751 To pass the config file path to child
1538 # processes, we need to set the environment variables here as a
1539 # workaround.
1540 os.environ['TEMPEST_CONFIG_DIR'] = os.path.dirname(path)
1541 os.environ['TEMPEST_CONFIG'] = os.path.basename(path)
Joe Gordon28a84ae2014-07-17 15:38:28 +00001542
Sean Dague86bd8422013-12-20 09:56:44 -05001543
1544CONF = TempestConfigProxy()
Matthew Treinishca5a9ff2016-04-16 15:04:34 -04001545
1546
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001547def service_client_config(service_client_name=None):
1548 """Return a dict with the parameters to init service clients
1549
1550 Extracts from CONF the settings specific to the service_client_name and
1551 api_version, and formats them as dict ready to be passed to the service
1552 clients __init__:
1553
1554 * `region` (default to identity)
1555 * `catalog_type`
1556 * `endpoint_type`
1557 * `build_timeout` (object-storage and identity default to compute)
1558 * `build_interval` (object-storage and identity default to compute)
1559
1560 The following common settings are always returned, even if
1561 `service_client_name` is None:
1562
1563 * `disable_ssl_certificate_validation`
1564 * `ca_certs`
1565 * `trace_requests`
zhufl071e94c2016-07-12 10:26:34 +08001566 * `http_timeout`
Matthew Treinish74514402016-09-01 11:44:57 -04001567 * `proxy_url`
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001568
1569 The dict returned by this does not fit a few service clients:
1570
1571 * The endpoint type is not returned for identity client, since it takes
1572 three different values for v2 admin, v2 public and v3
1573 * The `ServersClient` from compute accepts an optional
1574 `enable_instance_password` parameter, which is not returned.
1575 * The `VolumesClient` for both v1 and v2 volume accept an optional
1576 `default_volume_size` parameter, which is not returned.
1577 * The `TokenClient` and `V3TokenClient` have a very different
1578 interface, only auth_url is needed for them.
1579
1580 :param service_client_name: str Name of the service. Supported values are
1581 'compute', 'identity', 'image', 'network', 'object-storage', 'volume'
1582 :return: dictionary of __init__ parameters for the service clients
1583 :rtype: dict
1584 """
1585 _parameters = {
1586 'disable_ssl_certificate_validation':
Daniel Melladocad3f3d2016-08-19 14:17:16 +00001587 CONF.identity.disable_ssl_certificate_validation,
1588 'ca_certs': CONF.identity.ca_certificates_file,
zhufl071e94c2016-07-12 10:26:34 +08001589 'trace_requests': CONF.debug.trace_requests,
Matthew Treinish74514402016-09-01 11:44:57 -04001590 'http_timeout': CONF.service_clients.http_timeout,
1591 'proxy_url': CONF.service_clients.proxy_url,
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001592 }
1593
1594 if service_client_name is None:
1595 return _parameters
1596
1597 # Get the group of options first, by normalising the service_group_name
1598 # Services with a '-' in the name have an '_' in the option group name
1599 config_group = service_client_name.replace('-', '_')
1600 # NOTE(andreaf) Check if the config group exists. This allows for this
1601 # helper to be used for settings from registered plugins as well
1602 try:
1603 options = getattr(CONF, config_group)
1604 except cfg.NoSuchOptError:
1605 # Option group not defined
1606 raise exceptions.UnknownServiceClient(services=service_client_name)
1607 # Set endpoint_type
1608 # Identity uses different settings depending on API version, so do not
1609 # return the endpoint at all.
1610 if service_client_name != 'identity':
1611 _parameters['endpoint_type'] = getattr(options, 'endpoint_type')
1612 # Set build_*
1613 # Object storage and identity groups do not have conf settings for
1614 # build_* parameters, and we default to compute in any case
1615 for setting in ['build_timeout', 'build_interval']:
1616 if not hasattr(options, setting) or not getattr(options, setting):
1617 _parameters[setting] = getattr(CONF.compute, setting)
1618 else:
1619 _parameters[setting] = getattr(options, setting)
1620 # Set region
1621 # If a service client does not define region or region is not set
1622 # default to the identity region
1623 if not hasattr(options, 'region') or not getattr(options, 'region'):
1624 _parameters['region'] = CONF.identity.region
1625 else:
1626 _parameters['region'] = getattr(options, 'region')
1627 # Set service
1628 _parameters['service'] = getattr(options, 'catalog_type')
1629 return _parameters
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001630
1631
1632def _register_tempest_service_clients():
1633 # Register tempest own service clients using the same mechanism used
1634 # for external plugins.
1635 # The configuration data is pushed to the registry so that automatic
1636 # configuration of tempest own service clients is possible both for
1637 # tempest as well as for the plugins.
1638 service_clients = clients.tempest_modules()
1639 registry = clients.ClientsRegistry()
1640 all_clients = []
1641 for service_client in service_clients:
1642 module = service_clients[service_client]
1643 configs = service_client.split('.')[0]
1644 service_client_data = dict(
Andrea Frittoli986407d2017-10-11 10:23:17 +00001645 name=service_client.replace('.', '_').replace('-', '_'),
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001646 service_version=service_client,
1647 module_path=module.__name__,
1648 client_names=module.__all__,
1649 **service_client_config(configs)
1650 )
1651 all_clients.append(service_client_data)
1652 # NOTE(andreaf) Internal service clients do not actually belong
1653 # to a plugin, so using '__tempest__' to indicate a virtual plugin
1654 # which holds internal service clients.
1655 registry.register_service_client('__tempest__', all_clients)