blob: f0ed2ab8c4da882bdf3e600df02e24ed6e86df81 [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.'),
Takashi Kajinami0ed15dc2024-01-24 11:09:53 +0900129 cfg.URIOpt('uri',
130 schemes=['http', 'https'],
Takashi Kajinamic0c90272024-01-20 11:23:09 +0900131 deprecated_for_removal=True,
132 deprecated_reason='The identity v2 API tests were removed '
133 'and this option has no effect',
Brant Knudsonc7ca3342013-03-28 21:08:50 -0500134 help="Full URI of the OpenStack Identity API (Keystone), v2"),
Takashi Kajinami0ed15dc2024-01-24 11:09:53 +0900135 cfg.URIOpt('uri_v3',
136 schemes=['http', 'https'],
Brant Knudsonc7ca3342013-03-28 21:08:50 -0500137 help='Full URI of the OpenStack Identity API (Keystone), v3'),
Andrea Frittoli8bbdb162014-01-06 11:06:13 +0000138 cfg.StrOpt('auth_version',
Ken'ichi Ohmichia6065a62017-03-03 16:40:22 -0800139 default='v3',
Takashi Kajinamic0c90272024-01-20 11:23:09 +0900140 deprecated_for_removal=True,
141 deprecated_reason='Identity v2 API was removed and v3 is '
142 'the only available identity API version now',
Andrea Frittoli8bbdb162014-01-06 11:06:13 +0000143 help="Identity API version to be used for authentication "
Andrea Frittoli77f9da42014-02-06 11:18:19 +0000144 "for API tests."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500145 cfg.StrOpt('region',
Attila Fazekascadcb1f2013-01-21 23:10:53 +0100146 default='RegionOne',
Arata Notsu8f440392013-09-13 16:14:20 +0900147 help="The identity region name to use. Also used as the other "
148 "services' region name unless they are set explicitly. "
149 "If no such region is found in the service catalog, the "
150 "first found one is used."),
Jane Zadorozhnac7862132015-07-10 14:34:50 +0300151 cfg.StrOpt('v2_admin_endpoint_type',
152 default='adminURL',
153 choices=['public', 'admin', 'internal',
154 'publicURL', 'adminURL', 'internalURL'],
Takashi Kajinamic0c90272024-01-20 11:23:09 +0900155 deprecated_for_removal=True,
156 deprecated_reason='This option has no effect',
Jane Zadorozhnac7862132015-07-10 14:34:50 +0300157 help="The admin endpoint type to use for OpenStack Identity "
ghanshyamf58b9fd2015-09-01 16:11:39 +0900158 "(Keystone) API v2"),
Jane Zadorozhnac7862132015-07-10 14:34:50 +0300159 cfg.StrOpt('v2_public_endpoint_type',
JordanP5d29b2c2013-12-18 13:56:03 +0000160 default='publicURL',
161 choices=['public', 'admin', 'internal',
162 'publicURL', 'adminURL', 'internalURL'],
Takashi Kajinamic0c90272024-01-20 11:23:09 +0900163 deprecated_for_removal=True,
164 deprecated_reason='This option has no effect',
Jane Zadorozhnac7862132015-07-10 14:34:50 +0300165 help="The public endpoint type to use for OpenStack Identity "
zhuflf4d35922019-06-06 15:07:05 +0800166 "(Keystone) API v2"),
Jane Zadorozhnac7862132015-07-10 14:34:50 +0300167 cfg.StrOpt('v3_endpoint_type',
Arx Cruz05c805f2023-04-28 15:35:14 +0200168 default='public',
Jane Zadorozhnac7862132015-07-10 14:34:50 +0300169 choices=['public', 'admin', 'internal',
170 'publicURL', 'adminURL', 'internalURL'],
171 help="The endpoint type to use for OpenStack Identity "
Arx Cruz05c805f2023-04-28 15:35:14 +0200172 "(Keystone) API v3."),
Russell Sim7f894a52013-09-13 10:35:21 +1000173 cfg.StrOpt('admin_role',
174 default='admin',
175 help="Role required to administrate keystone."),
Martin Pavlasek4c3f2ab2014-04-15 17:15:15 +0200176 cfg.StrOpt('default_domain_id',
177 default='default',
178 help="ID of the default domain"),
Andrea Frittoli (andreaf)100d18d2016-05-05 23:34:52 +0100179 cfg.BoolOpt('admin_domain_scope',
180 default=False,
181 help="Whether keystone identity v3 policy required "
Rodrigo Duarte Sousa2d78e8e2016-09-28 10:38:08 -0300182 "a domain scoped token to use admin APIs"),
183 # Security Compliance (PCI-DSS)
184 cfg.IntOpt('user_lockout_failure_attempts',
185 default=2,
186 help="The number of unsuccessful login attempts the user is "
ghanshyama5c28bf2018-10-19 07:51:09 +0000187 "allowed before having the account locked. This only "
188 "takes effect when identity-feature-enabled."
189 "security_compliance is set to 'True'. For more details, "
190 "refer to keystone config options keystone.conf:"
191 "security_compliance.lockout_failure_attempts. "
192 "This feature is disabled by default in keystone."),
Rodrigo Duarte Sousa2d78e8e2016-09-28 10:38:08 -0300193 cfg.IntOpt('user_lockout_duration',
194 default=5,
195 help="The number of seconds a user account will remain "
ghanshyama5c28bf2018-10-19 07:51:09 +0000196 "locked. This only takes "
197 "effect when identity-feature-enabled.security_compliance "
198 "is set to 'True'. For more details, refer to "
199 "keystone config options "
200 "keystone.conf:security_compliance.lockout_duration. "
201 "Setting this option will have no effect unless you also "
202 "set identity.user_lockout_failure_attempts."),
Rodrigo Duarte Sousa2d78e8e2016-09-28 10:38:08 -0300203 cfg.IntOpt('user_unique_last_password_count',
204 default=2,
205 help="The number of passwords for a user that must be unique "
zhuflb11f85a2018-10-15 15:21:34 +0800206 "before an old password can be reused. This only takes "
207 "effect when identity-feature-enabled.security_compliance "
Sergey Vilgelm36fdd202018-11-20 16:10:47 -0600208 "is set to 'True'. "
zhuflb11f85a2018-10-15 15:21:34 +0800209 "This config option corresponds to keystone.conf: "
210 "security_compliance.unique_last_password_count, whose "
211 "default value is 0 meaning disabling this feature. "
212 "NOTE: This config option value must be same as "
213 "keystone.conf: security_compliance.unique_last_password_"
Katarina Strenkova702f0be2023-08-07 12:53:28 +0000214 "count otherwise test might fail"),
215 cfg.IntOpt('user_minimum_password_age',
216 default=0,
217 help="The number of days that a password must be used before "
218 "the user can change it. This only takes effect when "
219 "identity-feature-enabled.security_compliance is set to "
220 "'True'. For more details, refer to keystone config "
221 "options "
Ghanshyam Maan95c6fd42026-01-07 03:30:02 +0000222 "keystone.conf:security_compliance.minimum_password_age."),
223 cfg.BoolOpt('use_system_token',
224 default=False,
225 help="Keystone supports both system as well as project "
226 "scoped token. This config option tells tempest to "
227 "use the system scoped token for keystone identity "
228 "tests.")
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500229]
Jay Pipes3f981df2012-03-27 18:59:44 -0400230
zhufl071e94c2016-07-12 10:26:34 +0800231service_clients_group = cfg.OptGroup(name='service-clients',
232 title="Service Clients Options")
233
234ServiceClientsGroup = [
235 cfg.IntOpt('http_timeout',
236 default=60,
237 help='Timeout in seconds to wait for the http request to '
238 'return'),
Matthew Treinish74514402016-09-01 11:44:57 -0400239 cfg.StrOpt('proxy_url',
240 help='Specify an http proxy to use.')
zhufl071e94c2016-07-12 10:26:34 +0800241]
242
Matthew Treinishd5021a72014-01-09 18:42:51 +0000243identity_feature_group = cfg.OptGroup(name='identity-feature-enabled',
244 title='Enabled Identity Features')
245
246IdentityFeatureGroup = [
247 cfg.BoolOpt('trust',
248 default=True,
249 help='Does the identity service have delegation and '
Matthew Treinishdb2c5972014-01-31 22:18:59 +0000250 'impersonation enabled'),
251 cfg.BoolOpt('api_v2',
Lance Bragstad1fbad232017-09-22 18:58:53 +0000252 default=False,
Lance Bragstad1fbad232017-09-22 18:58:53 +0000253 deprecated_for_removal=True,
Takashi Kajinamic0c90272024-01-20 11:23:09 +0900254 deprecated_reason='The identity v2 API tests were removed '
255 'and this option has no effect',
256 help='Is the v2 identity API enabled'),
Andrea Frittoli1413ba92017-04-21 14:33:23 +0100257 cfg.BoolOpt('api_v2_admin',
258 default=True,
Takashi Kajinamic0c90272024-01-20 11:23:09 +0900259 deprecated_for_removal=True,
260 deprecated_reason='The identity v2 API tests were removed '
261 'and this option has no effect',
262 help="Is the v2 identity admin API available?"),
Matthew Treinishdb2c5972014-01-31 22:18:59 +0000263 cfg.BoolOpt('api_v3',
264 default=True,
Takashi Kajinamic0c90272024-01-20 11:23:09 +0900265 deprecated_for_removal=True,
266 deprecated_reason='Identity v2 API was removed and v3 is '
267 'the only available identity API version '
268 'now',
Matthew Treinishdb2c5972014-01-31 22:18:59 +0000269 help='Is the v3 identity API enabled'),
Jane Zadorozhna121576d2015-06-23 12:57:13 +0300270 cfg.ListOpt('api_extensions',
271 default=['all'],
272 help="A list of enabled identity extensions with a special "
273 "entry all which indicates every extension is enabled. "
274 "Empty list indicates all extensions are disabled. "
zhufld28a2712017-11-07 13:55:18 +0800275 "To get the list of extensions run: "
276 "'openstack extension list --identity'"),
Leticia Wanderley9cafd3d2017-08-04 00:22:34 -0300277 cfg.BoolOpt('domain_specific_drivers',
278 default=False,
279 help='Are domain specific drivers enabled? '
280 'This configuration value should be same as '
281 '[identity]->domain_specific_drivers_enabled '
282 'in keystone.conf.'),
Rodrigo Duarte Sousa2d78e8e2016-09-28 10:38:08 -0300283 cfg.BoolOpt('security_compliance',
284 default=False,
285 help='Does the environment have the security compliance '
Felipe Monteiro6f960782018-03-16 02:08:38 +0000286 'settings enabled?'),
Colleen Murphyd2cbd3a2019-12-17 16:31:14 -0800287 cfg.BoolOpt('access_rules',
Takashi Kajinami73005a12024-01-20 11:56:45 +0900288 default=True,
289 deprecated_for_removal=True,
290 deprecated_reason='Access rules for application credentials '
291 'is a default feature since Train',
Colleen Murphyd2cbd3a2019-12-17 16:31:14 -0800292 help='Does the environment have access rules enabled?'),
Anna Pankiewicza0710662018-07-24 14:56:42 -0500293 cfg.BoolOpt('immutable_user_source',
294 default=False,
295 help='Set to True if the environment has a read-only '
296 'user source. This will skip all tests that attempt to '
297 'create, delete, or modify users. This should not be set '
298 'to True if using dynamic credentials')
Matthew Treinishd5021a72014-01-09 18:42:51 +0000299]
300
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500301compute_group = cfg.OptGroup(name='compute',
302 title='Compute Service Options')
Rohit Karajgie1b050d2011-12-02 16:13:18 -0800303
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500304ComputeGroup = [
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500305 cfg.StrOpt('image_ref',
Matthew Treinishafcb6b42014-05-27 13:50:02 -0400306 help="Valid primary image reference to be used in tests. "
307 "This is a required option"),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500308 cfg.StrOpt('image_ref_alt',
Matthew Treinishafcb6b42014-05-27 13:50:02 -0400309 help="Valid secondary image reference to be used in tests. "
310 "This is a required option, but if only one image is "
311 "available duplicate the value of image_ref above"),
Lee Yarwood7f7c2322019-06-06 10:57:19 +0100312 cfg.StrOpt('certified_image_ref',
313 help="Valid image reference to be used in image certificate "
314 "validation tests when enabled. This image must also "
315 "have the required img_signature_* properties set. "
316 "Additional details available within the following Nova "
317 "documentation: https://docs.openstack.org/nova/latest/"
318 "user/certificate-validation.html"),
319 cfg.ListOpt('certified_image_trusted_certs',
320 help="A list of trusted certificates to be used when the "
321 "image certificate validation compute feature is "
322 "enabled."),
Ken'ichi Ohmichi35772602013-11-14 15:03:27 +0900323 cfg.StrOpt('flavor_ref',
324 default="1",
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500325 help="Valid primary flavor to use in tests."),
Ken'ichi Ohmichi35772602013-11-14 15:03:27 +0900326 cfg.StrOpt('flavor_ref_alt',
327 default="2",
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500328 help='Valid secondary flavor to be used in tests.'),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500329 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -0400330 default=1,
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500331 help="Time in seconds between build status checks."),
332 cfg.IntOpt('build_timeout',
333 default=300,
Hugh Saunders5b139ad2014-12-15 09:08:41 +0000334 help="Timeout in seconds to wait for an instance to build. "
335 "Other services that do not define build_timeout will "
Lucian Petrut1cfe2982015-01-06 13:57:36 +0200336 "inherit this value."),
Attila Fazekas0abbc952013-07-01 19:19:42 +0200337 cfg.IntOpt('ready_wait',
338 default=0,
DennyZhang8912d012013-09-25 18:08:34 -0500339 help="Additional wait time for clean state, when there is "
340 "no OS-EXT-STS extension available"),
Attila Fazekasb0661652013-05-08 13:01:36 +0200341 cfg.StrOpt('fixed_network_name',
Chris Hoge8f1401b2014-11-19 14:00:37 -0800342 help="Name of the fixed network that is visible to all test "
Sean Dagueed6e5862016-04-04 10:49:13 -0400343 "projects. If multiple networks are available for a "
344 "project, this is the network which will be used for "
345 "creating servers if tempest does not create a network or "
zhufl0bad33e2016-10-14 17:21:46 +0800346 "a network is not specified elsewhere. It may be used for "
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000347 "ssh validation only if floating IPs are disabled."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500348 cfg.StrOpt('catalog_type',
349 default='compute',
350 help="Catalog type of the Compute service."),
Arata Notsu8f440392013-09-13 16:14:20 +0900351 cfg.StrOpt('region',
352 default='',
353 help="The compute region name to use. If empty, the value "
354 "of identity.region is used instead. If no such region "
355 "is found in the service catalog, the first found one is "
356 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000357 cfg.StrOpt('endpoint_type',
358 default='publicURL',
359 choices=['public', 'admin', 'internal',
360 'publicURL', 'adminURL', 'internalURL'],
361 help="The endpoint type to use for the compute service."),
Ryan Hsucb2e1252013-09-03 21:44:49 -0700362 cfg.StrOpt('volume_device_name',
363 default='vdb',
364 help="Expected device name when a volume is attached to "
Kevin_Zheng79ec3342017-03-25 17:33:27 +0800365 "an instance. Not all hypervisors guarantee that they "
366 "will respect the user defined device name, tests may "
367 "fail if inappropriate device name is set."),
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900368 cfg.IntOpt('shelved_offload_time',
369 default=0,
370 help='Time in seconds before a shelved instance is eligible '
371 'for removing from a host. -1 never offload, 0 offload '
zhufl917b5552017-11-27 16:07:24 +0800372 'when shelved. This configuration value should be same as '
zhufldc7eeb42018-09-12 11:10:16 +0800373 'nova.conf: DEFAULT.shelved_offload_time, and '
zhufl917b5552017-11-27 16:07:24 +0800374 'some tests will run for as long as the time.'),
Sean Dague782f6772015-11-11 11:26:45 -0500375 cfg.IntOpt('min_compute_nodes',
376 default=1,
377 help=('The minimum number of compute nodes expected. This will '
378 'be utilized by some multinode specific tests to ensure '
379 'that requests match the expected size of the cluster '
ghanshyam29591532016-03-11 17:12:43 +0900380 'you are testing with.')),
Ken'ichi Ohmichi49db4fe2016-08-12 15:26:51 -0700381 cfg.StrOpt('hypervisor_type',
382 default=None,
383 help="Hypervisor type of the test target on heterogeneous "
384 "compute environment. The value can be 'QEMU', 'xen' or "
385 "something."),
Ken'ichi Ohmichi4d237e72015-11-05 06:32:33 +0000386 cfg.StrOpt('min_microversion',
387 default=None,
388 help="Lower version of the test target microversion range. "
389 "The format is 'X.Y', where 'X' and 'Y' are int values. "
390 "Tempest selects tests based on the range between "
391 "min_microversion and max_microversion. "
Ghanshyam395c5b52015-12-04 17:27:16 +0900392 "If both values are not specified, Tempest avoids tests "
393 "which require a microversion. Valid values are string "
ghanshyam8889d2b2017-02-14 02:29:06 +0000394 "with format 'X.Y' or string 'latest'"),
Ken'ichi Ohmichi4d237e72015-11-05 06:32:33 +0000395 cfg.StrOpt('max_microversion',
396 default=None,
397 help="Upper version of the test target microversion range. "
398 "The format is 'X.Y', where 'X' and 'Y' are int values. "
399 "Tempest selects tests based on the range between "
400 "min_microversion and max_microversion. "
Ghanshyam395c5b52015-12-04 17:27:16 +0900401 "If both values are not specified, Tempest avoids tests "
402 "which require a microversion. Valid values are string "
ghanshyam8889d2b2017-02-14 02:29:06 +0000403 "with format 'X.Y' or string 'latest'"),
Marc Koderer979e4942016-12-08 10:07:59 +0100404 cfg.StrOpt('compute_volume_common_az',
405 default=None,
406 help='AZ to be used for Cinder and Nova. Set this parameter '
407 'when the cloud has nova.conf: cinder.cross_az_attach '
408 'set to false. Which means volumes attached to an '
409 'instance must be in the same availability zone in Cinder '
410 'as the instance availability zone in Nova. Set the '
411 'common availability zone in this config which will be '
412 'used to boot an instance as well as creating a volume. '
413 'NOTE: If that AZ is not in Cinder (or '
414 'allow_availability_zone_fallback=False in cinder.conf), '
415 'the volume create request will fail and the instance '
416 'will fail the build request.'),
jskunda5a7ed972023-08-10 22:04:19 +0200417 cfg.StrOpt('migration_source_host',
418 default=None,
419 help="Specify source host for live-migration, cold-migration"
420 " and resize tests. If option is not set tests will use"
421 " host automatically."),
422 cfg.StrOpt('migration_dest_host',
423 default=None,
424 help="Specify destination host for live-migration and cold"
425 " migration. If option is not set tests will use host"
426 " automatically."),
jamepark49d8d6312024-07-23 16:27:27 -0400427 cfg.StrOpt('target_hosts_to_avoid',
428 default='-ironic',
429 help="When aggregating available hypervisors for testing,"
430 " avoid migrating to and booting any test VM on hosts with"
431 " a name that matches the provided pattern"),
ghanshyam29591532016-03-11 17:12:43 +0900432]
433
Lajos Katonaceb88212018-11-30 14:54:12 +0100434placement_group = cfg.OptGroup(name='placement',
435 title='Placement Service Options')
436
437PlacementGroup = [
438 cfg.StrOpt('endpoint_type',
439 default='public',
440 choices=['public', 'admin', 'internal'],
441 help="The endpoint type to use for the placement service."),
442 cfg.StrOpt('catalog_type',
443 default='placement',
444 help="Catalog type of the Placement service."),
445 cfg.StrOpt('region',
Swapnil Chhanikara89eea82020-01-24 17:04:42 +0530446 default='',
Lajos Katonaceb88212018-11-30 14:54:12 +0100447 help="The placement region name to use. If empty, the value "
448 "of [identity]/region is used instead. If no such region "
449 "is found in the service catalog, the first region found "
450 "is used."),
451 cfg.StrOpt('min_microversion',
452 default=None,
453 help="Lower version of the test target microversion range. "
454 "The format is 'X.Y', where 'X' and 'Y' are int values. "
455 "Valid values are string with format 'X.Y' or string "
456 "'latest'"),
457 cfg.StrOpt('max_microversion',
458 default=None,
459 help="Upper version of the test target microversion range. "
460 "The format is 'X.Y', where 'X' and 'Y' are int values. "
461 "Valid values are string with format 'X.Y' or string "
462 "'latest'"),
463]
464
465
ghanshyam29591532016-03-11 17:12:43 +0900466compute_features_group = cfg.OptGroup(name='compute-feature-enabled',
467 title="Enabled Compute Service Features")
468
469ComputeFeaturesGroup = [
Matthew Treinishd5c96022013-10-17 21:51:23 +0000470 cfg.BoolOpt('disk_config',
471 default=True,
472 help="If false, skip disk config tests"),
Pavan Kesava Raodeff57e2021-06-09 15:21:37 -0500473 # TODO(pkesav): Make it True by default once wallaby
474 # is oldest supported stable for Tempest.
475 cfg.BoolOpt('hostname_fqdn_sanitization',
476 default=False,
477 help="If false, skip fqdn instance sanitization tests. "
478 "Nova started sanitizing the instance name by replacing "
479 "the '.' with '-' to comply with fqdn hostname. Nova "
480 "changed that in Wallaby cycle, if your cloud is older "
481 "than wallaby then you can keep/make it False."),
Ashish Guptae27a9d62024-06-19 22:36:24 +0530482 cfg.StrOpt('dhcp_domain',
483 default='.novalocal',
484 help="Configure a fully-qualified domain name for instance "
485 "hostnames. The value is suffixed to instance hostname "
486 "from the database to construct the hostname that "
487 "appears in the metadata API. To disable this behavior "
488 "(for example in order to correctly support "
489 "microversion's 2.94 FQDN hostnames), set this to the "
490 "empty string."),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000491 cfg.BoolOpt('change_password',
492 default=False,
493 help="Does the test environment support changing the admin "
494 "password?"),
Adam Gandelmanc6eefb42014-07-15 16:44:08 -0700495 cfg.BoolOpt('console_output',
496 default=True,
497 help="Does the test environment support obtaining instance "
498 "serial console output?"),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000499 cfg.BoolOpt('resize',
500 default=False,
Masayuki Igawad91094d2017-04-12 16:20:09 +0900501 help="Does the test environment support resizing? When you "
502 "enable this feature, 'flavor_ref_alt' should be set and "
503 "it should refer to a larger flavor than 'flavor_ref' "
504 "one."),
Eric Windischb5538072014-03-09 23:47:35 -0400505 cfg.BoolOpt('pause',
506 default=True,
507 help="Does the test environment support pausing?"),
David Shrewsbury25f666f2014-07-22 12:17:59 -0400508 cfg.BoolOpt('shelve',
509 default=True,
510 help="Does the test environment support shelving/unshelving?"),
Alexandre Arents0a9b8232020-07-29 09:52:57 +0000511 cfg.BoolOpt('shelve_migrate',
512 default=False,
513 help="Does the test environment support "
514 "cold migration of unshelved server?"),
Eric Windischaeb7e842014-03-10 01:10:50 -0400515 cfg.BoolOpt('suspend',
516 default=True,
517 help="Does the test environment support suspend/resume?"),
Ludovic Beliveauae314882016-09-15 13:34:14 -0400518 cfg.BoolOpt('cold_migration',
519 default=True,
zhufl0bad33e2016-10-14 17:21:46 +0800520 help="Does the test environment support cold migration?"),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000521 cfg.BoolOpt('live_migration',
Joe Gordon31a139a2014-11-17 16:39:04 -0800522 default=True,
zhufl0bad33e2016-10-14 17:21:46 +0800523 help="Does the test environment support live migration?"),
Sarafraj Singh61e40452016-09-29 13:06:59 -0500524 cfg.BoolOpt('live_migrate_back_and_forth',
525 default=False,
526 help="Does the test environment support live migrating "
527 "VM back and forth between different versions of "
528 "nova-compute?"),
YAMAMOTO Takashi1f62af22015-06-16 03:29:50 +0900529 cfg.BoolOpt('metadata_service',
530 default=True,
531 help="Does the test environment support metadata service? "
532 "Ignored unless validation.run_validation=true."),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000533 cfg.BoolOpt('block_migration_for_live_migration',
534 default=False,
535 help="Does the test environment use block devices for live "
536 "migration"),
zhuflbe052d62019-11-04 10:56:02 +0800537 cfg.BoolOpt('can_migrate_between_any_hosts',
538 default=True,
539 help="Does the test environment support migrating between "
540 "any hosts? In environments with non-homogeneous compute "
541 "nodes you can set this to False so that it will select "
542 "destination host for migrating automatically"),
Ghanshyam Mann41c17572014-02-27 18:52:56 +0900543 cfg.BoolOpt('vnc_console',
544 default=False,
545 help='Enable VNC console. This configuration value should '
zhufldc7eeb42018-09-12 11:10:16 +0800546 'be same as nova.conf: vnc.enabled'),
Ghanshyam70876d02014-03-11 11:40:18 +0900547 cfg.BoolOpt('spice_console',
548 default=False,
Michael Stillfbbf01b2025-02-12 18:05:57 +1100549 help='Enable SPICE console. This configuration value should '
550 'be same as nova.conf: spice.enabled'),
Markus Zoeller69d58b82017-02-17 10:09:22 +0100551 cfg.BoolOpt('serial_console',
552 default=False,
553 help='Enable serial console. This configuration value '
zhufldc7eeb42018-09-12 11:10:16 +0800554 'should be the same as '
555 'nova.conf: serial_console.enabled'),
Adam Gandelman2e37b4f2014-06-18 17:34:21 -0700556 cfg.BoolOpt('rescue',
557 default=True,
558 help='Does the test environment support instance rescue '
Ghanshyam9c2e50d2014-07-22 21:32:05 +0900559 'mode?'),
Lee Yarwoodc0ad55c2019-12-06 13:39:19 +0000560 cfg.BoolOpt('stable_rescue',
561 default=False,
562 help='Does the test environment support stable device '
563 'instance rescue mode?'),
Ghanshyam9c2e50d2014-07-22 21:32:05 +0900564 cfg.BoolOpt('enable_instance_password',
565 default=True,
566 help='Enables returning of the instance password by the '
567 'relevant server API calls such as create, rebuild '
zhufle8a703b2016-09-09 15:23:03 +0800568 'or rescue. This configuration value should be same as '
569 'nova.conf: DEFAULT.enable_instance_password'),
Adam Gandelman7186f7a2014-07-23 09:28:56 -0400570 cfg.BoolOpt('interface_attach',
571 default=True,
572 help='Does the test environment support dynamic network '
Adam Gandelmanfbc95ac2014-06-19 17:33:43 -0700573 'interface attachment?'),
574 cfg.BoolOpt('snapshot',
575 default=True,
576 help='Does the test environment support creating snapshot '
Matthew Treinishdfd7ac02015-02-09 17:47:31 -0500577 'images of running instances?'),
Takeaki Matsumotod7e04b22015-09-04 15:13:38 +0900578 cfg.BoolOpt('personality',
Matt Riedemann0baba702016-07-03 19:24:08 -0400579 default=False,
Takeaki Matsumotod7e04b22015-09-04 15:13:38 +0900580 help='Does the test environment support server personality'),
Matt Riedemann79b3b492015-06-20 14:20:44 -0700581 cfg.BoolOpt('attach_encrypted_volume',
582 default=True,
583 help='Does the test environment support attaching an '
584 'encrypted volume to a running server instance? This may '
585 'depend on the combination of compute_driver in nova and '
586 'the volume_driver(s) in cinder.'),
Alexander Gubanov509e2842015-06-09 15:29:51 +0300587 cfg.BoolOpt('config_drive',
588 default=True,
589 help='Enable special configuration drive with metadata.'),
Artom Lifshitz595ae162018-05-23 10:19:18 -0400590 cfg.ListOpt('scheduler_enabled_filters',
Stephen Finucane88a49e82020-08-26 11:34:58 +0100591 default=[
592 "ComputeFilter",
593 "ComputeCapabilitiesFilter",
594 "ImagePropertiesFilter",
595 "ServerGroupAntiAffinityFilter",
596 "ServerGroupAffinityFilter",
597 ],
Artom Lifshitz595ae162018-05-23 10:19:18 -0400598 help="A list of enabled filters that Nova will accept as "
599 "hints to the scheduler when creating a server. If the "
ghanshyam5817e142016-12-01 11:38:46 +0900600 "default value is overridden in nova.conf by the test "
601 "environment (which means that a different set of "
602 "filters is enabled than what is included in Nova by "
Artom Lifshitz595ae162018-05-23 10:19:18 -0400603 "default), then this option must be configured to "
ghanshyam5817e142016-12-01 11:38:46 +0900604 "contain the same filters that Nova uses in the test "
Artom Lifshitz595ae162018-05-23 10:19:18 -0400605 "environment. A special entry 'all' indicates all "
606 "filters that are included with Nova are enabled. If "
607 "using 'all', be sure to enable all filters in "
608 "nova.conf, as tests can fail in unpredictable ways if "
609 "Nova's and Tempest's enabled filters don't match. "
610 "Empty list indicates all filters are disabled. The "
611 "full list of enabled filters is in nova.conf: "
612 "filter_scheduler.enabled_filters.",
613 deprecated_opts=[cfg.DeprecatedOpt(
614 'scheduler_available_filters',
615 group='compute-feature-enabled')]),
Matt Riedemann342b37c2016-09-21 15:38:12 -0400616 cfg.BoolOpt('swap_volume',
617 default=False,
618 help='Does the test environment support in-place swapping of '
619 'volumes attached to a server instance?'),
melanie witt334f3132017-12-14 21:49:55 +0000620 cfg.BoolOpt('volume_backed_live_migration',
621 default=False,
622 help='Does the test environment support volume-backed live '
623 'migration?'),
Matt Riedemann81fa9b62016-01-14 13:04:38 -0800624 cfg.BoolOpt('volume_multiattach',
625 default=False,
626 help='Does the test environment support attaching a volume to '
627 'more than one instance? This depends on hypervisor and '
628 'volume backend/type and compute API version 2.60.'),
Lee Yarwood56a446d2021-02-15 13:34:35 +0000629 cfg.BoolOpt('ide_bus',
630 default=True,
631 help='Does the test environment support attaching devices '
632 'using an IDE bus to the instance?'),
melanie witt74fa5052021-05-06 22:41:30 +0000633 cfg.BoolOpt('unified_limits',
634 default=False,
635 help='Does the test environment support unified limits?'),
Ghanshyam Mannd60609f2025-06-24 19:54:27 -0700636 cfg.ListOpt('nova_policy_roles',
637 default=['admin', 'member', 'reader'],
638 help='Compute service API policies roles list. List all the '
639 'roles which are used as default in Nova policy rules. '
640 'This config option value is used to run the tests with '
641 'the available roles in Nova. For example, if manager '
642 'role is not present in the nova release then tempest '
643 'will use old defaults role token to call nova APIs'),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000644]
645
646
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500647image_group = cfg.OptGroup(name='image',
648 title="Image Service Options")
Jay Pipesf38eaac2012-06-21 13:37:35 -0400649
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500650ImageGroup = [
Matthew Treinish72ea4422013-02-07 14:42:49 -0500651 cfg.StrOpt('catalog_type',
652 default='image',
Sean Dague83401992013-05-06 17:46:36 -0400653 help='Catalog type of the Image service.'),
Arata Notsu8f440392013-09-13 16:14:20 +0900654 cfg.StrOpt('region',
655 default='',
656 help="The image region name to use. If empty, the value "
657 "of identity.region is used instead. If no such region "
658 "is found in the service catalog, the first found one is "
659 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000660 cfg.StrOpt('endpoint_type',
661 default='publicURL',
662 choices=['public', 'admin', 'internal',
663 'publicURL', 'adminURL', 'internalURL'],
664 help="The endpoint type to use for the image service."),
Dan Smithd4bc9a82021-01-12 17:25:07 -0800665 cfg.StrOpt('alternate_image_endpoint',
666 default=None,
667 help="Alternate endpoint name for cross-worker testing"),
668 cfg.StrOpt('alternate_image_endpoint_type',
669 default='publicURL',
670 choices=['public', 'admin', 'internal',
671 'publicURL', 'adminURL', 'internalURL'],
672 help=("The endpoint type to use for the alternate image "
673 "service.")),
Abhishek Kekane0188f462022-01-18 06:47:28 +0000674 cfg.BoolOpt('image_caching_enabled',
675 default=False,
676 help=("Flag to enable if caching is enabled by image "
Takashi Kajinamic87c6a12024-05-05 01:19:09 +0900677 "service, operator should set this parameter to True "
Abhishek Kekane0188f462022-01-18 06:47:28 +0000678 "if 'image_cache_dir' is set in glance-api.conf")),
Sean Dague83401992013-05-06 17:46:36 -0400679 cfg.StrOpt('http_image',
Abhishek Kekane9eea03c2024-07-04 06:38:42 +0000680 default='http://download.cirros-cloud.net/0.6.2/'
681 'cirros-0.6.2-x86_64-uec.tar.gz',
Lucian Petrut1cfe2982015-01-06 13:57:36 +0200682 help='http accessible image'),
Abhishek Kekane9aa41442024-07-03 06:59:59 +0000683 cfg.StrOpt('http_qcow2_image',
684 default='http://download.cirros-cloud.net/0.6.2/'
685 'cirros-0.6.2-x86_64-disk.img',
686 help='http qcow2 accessible image which will be used '
687 'for image conversion if enabled.'),
Lucian Petrut1cfe2982015-01-06 13:57:36 +0200688 cfg.IntOpt('build_timeout',
689 default=300,
690 help="Timeout in seconds to wait for an image to "
691 "become available."),
692 cfg.IntOpt('build_interval',
693 default=1,
694 help="Time in seconds between image operation status "
Takashi NATSUME12a48512015-08-10 18:33:16 +0900695 "checks."),
696 cfg.ListOpt('container_formats',
Luigi Toscanob73ead02024-07-17 01:00:09 +0200697 default=['bare', 'ami', 'ari', 'aki', 'ovf', 'ova'],
Takashi NATSUME12a48512015-08-10 18:33:16 +0900698 help="A list of image's container formats "
699 "users can specify."),
700 cfg.ListOpt('disk_formats',
Luigi Toscanob73ead02024-07-17 01:00:09 +0200701 default=['qcow2', 'raw', 'ami', 'ari', 'aki', 'vhd', 'vmdk',
Benny Kopilov97c74192017-03-30 09:34:59 +0300702 'vdi', 'iso', 'vhdx'],
Takashi NATSUME12a48512015-08-10 18:33:16 +0900703 help="A list of image's disk formats "
Dan Smith97ef2862024-07-31 12:33:46 -0700704 "users can specify."),
Abhishek Kekane102d7622025-06-02 18:54:48 +0000705 cfg.StrOpt('hashing_algorithm',
706 default='sha512',
707 help=('Hashing algorithm used by glance to calculate image '
708 'hashes. This configuration value should be same as '
709 'glance-api.conf: hashing_algorithm config option.')),
Dan Smith97ef2862024-07-31 12:33:46 -0700710 cfg.StrOpt('images_manifest_file',
711 default=None,
712 help="A path to a manifest.yml generated using the "
713 "os-test-images project"),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500714]
Jay Pipesf38eaac2012-06-21 13:37:35 -0400715
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000716image_feature_group = cfg.OptGroup(name='image-feature-enabled',
717 title='Enabled image service features')
718
719ImageFeaturesGroup = [
720 cfg.BoolOpt('api_v2',
721 default=True,
ghanshyam6b0b8b72017-03-08 04:22:53 +0000722 help="Is the v2 image API enabled",
723 deprecated_for_removal=True,
724 deprecated_reason='Glance v1 APIs are deprecated and v2 APIs '
725 'are current one. In future, Tempest will '
726 'test v2 APIs only so this config option '
727 'will be removed.'),
Abhishek Kekane7cff1302020-07-16 10:30:13 +0000728 cfg.BoolOpt('import_image',
Takashi Kajinami85129462024-04-13 00:13:55 +0900729 default=True,
730 help="Is image import feature enabled",
731 deprecated_for_removal=True,
732 deprecated_reason='Issue with image import in WSGI mode was '
733 'fixed in Victoria, and this feature works '
734 'in any deployment architecture now.'),
Dan Smithe044dad2021-01-15 12:45:16 -0800735 cfg.BoolOpt('os_glance_reserved',
Takashi Kajinami9fcc4a32024-01-24 10:55:20 +0900736 default=True,
737 help="Should we check that os_glance namespace is reserved",
738 deprecated_for_removal=True,
739 deprecated_reason='os_glance namespace is always reserved '
740 'since Wallaby'),
Dan Smith9eaaa5a2022-10-07 09:16:20 -0700741 cfg.BoolOpt('manage_locations',
742 default=False,
743 help=('Is show_multiple_locations enabled in glance. '
744 'Note that at least one http store must be enabled as '
745 'well, because we use that location scheme to test.')),
Dan Smithe8efa4f2024-08-01 06:59:50 -0700746 cfg.BoolOpt('image_conversion',
747 default=False,
748 help=('Is image_conversion enabled in glance.')),
Dan Smith2ba7ed82024-10-01 07:33:09 -0700749 cfg.BoolOpt('image_format_enforcement',
750 default=True,
751 help=('Indicates that image format is enforced by glance, '
752 'such that we should not expect to be able to upload '
753 'bad images for testing other services.')),
Abhishek Kekane102d7622025-06-02 18:54:48 +0000754 cfg.BoolOpt('do_secure_hash',
755 default=True,
756 help=('Is do_secure_hash enabled in glance. '
757 'This configuration value should be same as '
758 'glance-api.conf: do_secure_hash config option.')),
759 cfg.BoolOpt('http_store_enabled',
760 default=False,
761 help=('Is http store is enabled in glance. '
762 'http store needs to be mentioned either in '
763 'glance-api.conf: stores or in enabled_backends '
764 'configuration option.')),
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000765]
Jay Pipesf38eaac2012-06-21 13:37:35 -0400766
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500767network_group = cfg.OptGroup(name='network',
768 title='Network Service Options')
Daryl Walleck587385b2012-03-03 13:00:26 -0600769
Noam Angel3c6b0162018-07-08 17:05:35 +0300770ProfileType = types.Dict(types.List(types.String(), bounds=True))
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500771NetworkGroup = [
772 cfg.StrOpt('catalog_type',
773 default='network',
Mark McClainf2982e82013-07-06 17:48:03 -0400774 help='Catalog type of the Neutron service.'),
Arata Notsu8f440392013-09-13 16:14:20 +0900775 cfg.StrOpt('region',
776 default='',
777 help="The network region name to use. If empty, the value "
778 "of identity.region is used instead. If no such region "
779 "is found in the service catalog, the first found one is "
780 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000781 cfg.StrOpt('endpoint_type',
782 default='publicURL',
783 choices=['public', 'admin', 'internal',
784 'publicURL', 'adminURL', 'internalURL'],
785 help="The endpoint type to use for the network service."),
Sean Dagueed6e5862016-04-04 10:49:13 -0400786 cfg.StrOpt('project_network_cidr',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500787 default="10.100.0.0/16",
Sean Dagueed6e5862016-04-04 10:49:13 -0400788 help="The cidr block to allocate project ipv4 subnets from"),
789 cfg.IntOpt('project_network_mask_bits',
Attila Fazekas8ea181b2013-07-13 16:26:14 +0200790 default=28,
Sean Dagueed6e5862016-04-04 10:49:13 -0400791 help="The mask bits for project ipv4 subnets"),
792 cfg.StrOpt('project_network_v6_cidr',
Brian Haley56893552019-09-19 17:50:37 -0400793 default="2001:db8::/48",
Sean Dagueed6e5862016-04-04 10:49:13 -0400794 help="The cidr block to allocate project ipv6 subnets from"),
795 cfg.IntOpt('project_network_v6_mask_bits',
Sergey Shnaidman1f3659a2014-08-27 18:26:42 +0400796 default=64,
Sean Dagueed6e5862016-04-04 10:49:13 -0400797 help="The mask bits for project ipv6 subnets"),
798 cfg.BoolOpt('project_networks_reachable',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500799 default=False,
Sean Dagueed6e5862016-04-04 10:49:13 -0400800 help="Whether project networks can be reached directly from "
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000801 "the test client. This must be set to True when the "
Matt Riedemann4b0f7e72016-08-08 15:29:26 -0400802 "'fixed' connect_method is selected."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500803 cfg.StrOpt('public_network_id',
804 default="",
805 help="Id of the public network that provides external "
806 "connectivity"),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000807 cfg.StrOpt('floating_network_name',
808 help="Default floating network name. Used to allocate floating "
809 "IPs when neutron is enabled."),
Lukas Piwowarski2385e042020-01-31 12:28:20 +0000810 cfg.StrOpt('subnet_id',
811 default="",
812 help="Subnet id of subnet which is used for allocation of "
813 "floating IPs. Specify when two or more subnets are "
814 "present in network."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500815 cfg.StrOpt('public_router_id',
816 default="",
817 help="Id of the public router that provides external "
Yair Fried1eb27f52014-11-10 15:24:19 +0200818 "connectivity. This should only be used when Neutron's "
819 "'allow_overlapping_ips' is set to 'False' in "
820 "neutron.conf. usually not needed past 'Grizzly' release"),
izikpensod9a01a62014-02-17 20:02:32 +0200821 cfg.IntOpt('build_timeout',
822 default=300,
823 help="Timeout in seconds to wait for network operation to "
824 "complete."),
825 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -0400826 default=1,
izikpensod9a01a62014-02-17 20:02:32 +0200827 help="Time in seconds between network operation status "
828 "checks."),
Itzik Brown2ca01cd2014-12-08 12:58:20 +0200829 cfg.StrOpt('port_vnic_type',
Tom Stappaerts27fd5cb2020-11-26 12:07:47 +0100830 choices=[None, 'normal', 'direct', 'macvtap', 'direct-physical',
831 'baremetal', 'virtio-forwarder'],
Moshe Levie2c2fb12017-08-31 15:18:58 +0300832 help="vnic_type to use when launching instances"
Itzik Brown2ca01cd2014-12-08 12:58:20 +0200833 " with pre-configured ports."
834 " Supported ports are:"
Tom Stappaerts27fd5cb2020-11-26 12:07:47 +0100835 " ['normal', 'direct', 'macvtap', 'direct-physical', "
836 "'baremetal', 'virtio-forwarder']"),
Noam Angel3c6b0162018-07-08 17:05:35 +0300837 cfg.Opt('port_profile',
838 type=ProfileType,
839 default={},
840 help="port profile to use when launching instances"
841 " with pre-configured ports."),
piyush11078648e35d52015-09-24 12:56:43 +0530842 cfg.ListOpt('default_network',
843 default=["1.0.0.0/16", "2.0.0.0/16"],
844 help="List of ip pools"
845 " for subnetpools creation"),
Thiago Paiva66cded22016-08-15 14:55:58 -0300846 cfg.BoolOpt('shared_physical_network',
847 default=False,
848 help="The environment does not support network separation "
849 "between tenants."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500850]
Jay Pipes3f981df2012-03-27 18:59:44 -0400851
Matthew Treinishe3d26142013-11-26 19:14:58 +0000852network_feature_group = cfg.OptGroup(name='network-feature-enabled',
853 title='Enabled network service features')
854
855NetworkFeaturesGroup = [
Matthew Treinishe2e33cf2014-03-03 19:28:41 +0000856 cfg.BoolOpt('ipv6',
857 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500858 help="Allow the execution of IPv6 tests."),
Matthew Treinishe3d26142013-11-26 19:14:58 +0000859 cfg.ListOpt('api_extensions',
860 default=['all'],
Alexander Gubanov36e1f9b2015-06-12 18:02:10 +0300861 help="A list of enabled network extensions with a special "
862 "entry all which indicates every extension is enabled. "
863 "Empty list indicates all extensions are disabled. "
Brian Haley3d701092020-11-23 14:03:25 -0500864 "To get the list of extensions run: "
865 "'openstack extension list --network'"),
elajkatf9bb8b82020-11-02 13:41:06 +0100866 cfg.ListOpt('available_features',
867 default=['all'],
868 help="A list of available network features with a special "
869 "entry all that indicates every feature is available. "
Brian Haley3d701092020-11-23 14:03:25 -0500870 "Empty list indicates all features are disabled. "
elajkatf9bb8b82020-11-02 13:41:06 +0100871 "This list can contain features that are not "
Brian Haley3d701092020-11-23 14:03:25 -0500872 "discoverable through the API."),
Sean M. Collinsdd27a4d2014-05-13 10:33:15 -0400873 cfg.BoolOpt('ipv6_subnet_attributes',
874 default=False,
875 help="Allow the execution of IPv6 subnet tests that use "
876 "the extended IPv6 attributes ipv6_ra_mode "
Brian Haley3d701092020-11-23 14:03:25 -0500877 "and ipv6_address_mode."
Mark McClain6e07c0d2014-10-10 11:25:03 -0400878 ),
Itzik Brownbeb30d32015-03-29 09:42:54 +0300879 cfg.BoolOpt('port_admin_state_change',
880 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500881 help="Does the test environment support changing "
882 "port admin state?"),
Matt Riedemann039b2fe2016-09-15 16:12:24 -0400883 cfg.BoolOpt('port_security',
884 default=False,
885 help="Does the test environment support port security?"),
Matthew Treinish3312de32017-05-19 12:08:17 -0400886 cfg.BoolOpt('floating_ips',
887 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500888 help='Does the test environment support floating_ips?'),
Lajos Katonac87a06b2019-01-04 13:21:48 +0100889 cfg.StrOpt('qos_placement_physnet', default=None,
890 help='Name of the physnet for placement based minimum '
891 'bandwidth allocation.'),
Takashi Kajinami7138e352022-02-03 09:16:34 +0900892 cfg.StrOpt('provider_net_base_segmentation_id', default='3000',
Lajos Katonac87a06b2019-01-04 13:21:48 +0100893 help='Base segmentation ID to create provider networks. '
Balazs Gibizerf294b0d2021-09-29 16:16:44 +0200894 'This value will be increased in case of conflict.'),
895 cfg.BoolOpt('qos_min_bw_and_pps', default=False,
896 help='Does the test environment have minimum bandwidth and '
897 'packet rate inventories configured?'),
Matthew Treinishe3d26142013-11-26 19:14:58 +0000898]
899
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -0600900dashboard_group = cfg.OptGroup(name="dashboard",
901 title="Dashboard options")
902
903DashboardGroup = [
Takashi Kajinami0ed15dc2024-01-24 11:09:53 +0900904 cfg.URIOpt('dashboard_url',
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -0600905 default='http://localhost/',
Takashi Kajinami0ed15dc2024-01-24 11:09:53 +0900906 schemes=['http', 'https'],
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -0600907 help="Where the dashboard can be found"),
908 cfg.BoolOpt('disable_ssl_certificate_validation',
909 default=False,
910 help="Set to True if using self-signed SSL certificates."),
911]
912
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000913validation_group = cfg.OptGroup(name='validation',
914 title='SSH Validation options')
915
916ValidationGroup = [
Matthew Treinishe5cca002015-05-11 15:36:50 -0400917 cfg.BoolOpt('run_validation',
Attila Fazekas489e90f2018-09-12 17:30:01 -0600918 default=True,
Matthew Treinishe5cca002015-05-11 15:36:50 -0400919 help='Enable ssh on created servers and creation of additional'
Attila Fazekas489e90f2018-09-12 17:30:01 -0600920 ' validation resources to enable remote access.'
921 ' In case the guest does not support ssh set it'
922 ' to false'),
Brandon Palmc6cc91d2015-08-19 13:20:21 -0500923 cfg.BoolOpt('security_group',
924 default=True,
925 help='Enable/disable security groups.'),
926 cfg.BoolOpt('security_group_rules',
927 default=True,
928 help='Enable/disable security group rules.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000929 cfg.StrOpt('connect_method',
930 default='floating',
Takashi Kajinamib9f775d2024-01-20 11:17:33 +0900931 choices=[('fixed',
932 'uses the first IP belonging to the fixed network'),
933 ('floating',
934 'creates and uses a floating IP')],
935 help='Default IP type used for validation'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000936 cfg.StrOpt('auth_method',
937 default='keypair',
938 choices=['keypair'],
939 help='Default authentication method to the instance. '
940 'Only ssh via keypair is supported for now. '
ghanshyamade71d22017-02-15 05:36:14 +0000941 'Additional methods will be handled in a separate spec.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000942 cfg.IntOpt('ip_version_for_ssh',
943 default=4,
lanoux283273b2015-12-04 03:01:54 -0800944 help='Default IP version for ssh connections.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000945 cfg.IntOpt('ping_timeout',
946 default=120,
ghanshyam244cf7c2017-02-15 06:39:31 +0000947 help='Timeout in seconds to wait for ping to succeed.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000948 cfg.IntOpt('connect_timeout',
949 default=60,
950 help='Timeout in seconds to wait for the TCP connection to be '
lanoux283273b2015-12-04 03:01:54 -0800951 'successful.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000952 cfg.IntOpt('ssh_timeout',
953 default=300,
lanoux283273b2015-12-04 03:01:54 -0800954 help='Timeout in seconds to wait for the ssh banner.'),
955 cfg.StrOpt('image_ssh_user',
956 default="root",
ghanshyam244cf7c2017-02-15 06:39:31 +0000957 help="User name used to authenticate to an instance."),
Weronika Sikorac54a9112019-09-18 13:55:07 +0000958 cfg.StrOpt('image_alt_ssh_user',
959 default="root",
960 help="User name used to authenticate to an alt instance."),
lanoux283273b2015-12-04 03:01:54 -0800961 cfg.StrOpt('image_ssh_password',
962 default="password",
Doug Schveninger6a2be432020-04-29 17:42:31 -0500963 help="Password used to authenticate to an instance.",
964 secret=True),
Weronika Sikorac54a9112019-09-18 13:55:07 +0000965 cfg.StrOpt('image_alt_ssh_password',
966 default="password",
967 help="Password used to authenticate to an alt instance.",
968 secret=True),
lanoux283273b2015-12-04 03:01:54 -0800969 cfg.StrOpt('ssh_shell_prologue',
Lucian Petrut6a7472a2019-08-07 12:43:08 +0300970 default="set -eu -o pipefail; PATH=$$PATH:/sbin:/usr/sbin;",
lanoux283273b2015-12-04 03:01:54 -0800971 help="Shell fragments to use before executing a command "
ghanshyamade71d22017-02-15 05:36:14 +0000972 "when sshing to a guest."),
lanoux283273b2015-12-04 03:01:54 -0800973 cfg.IntOpt('ping_size',
974 default=56,
975 help="The packet size for ping packets originating "
ghanshyamade71d22017-02-15 05:36:14 +0000976 "from remote linux hosts"),
lanoux283273b2015-12-04 03:01:54 -0800977 cfg.IntOpt('ping_count',
978 default=1,
979 help="The number of ping packets originating from remote "
ghanshyamade71d22017-02-15 05:36:14 +0000980 "linux hosts"),
lanoux283273b2015-12-04 03:01:54 -0800981 cfg.StrOpt('floating_ip_range',
982 default='10.0.0.0/29',
983 help='Unallocated floating IP range, which will be used to '
984 'test the floating IP bulk feature for CRUD operation. '
985 'This block must not overlap an existing floating IP '
ghanshyamade71d22017-02-15 05:36:14 +0000986 'pool.'),
lanoux283273b2015-12-04 03:01:54 -0800987 cfg.StrOpt('network_for_ssh',
988 default='public',
989 help="Network used for SSH connections. Ignored if "
ghanshyam244cf7c2017-02-15 06:39:31 +0000990 "connect_method=floating."),
Ade Lee6ded0702021-09-04 15:56:34 -0400991 cfg.StrOpt('ssh_key_type',
Martin Kopec75ca0b82022-04-20 17:57:45 +0200992 default='ecdsa',
Takashi Kajinamifb116382024-05-05 01:24:54 +0900993 choices=['ecdsa', 'rsa'],
994 help='Type of key to use for ssh connections.'),
Roman Safronovf2357852023-02-20 15:21:13 +0200995 cfg.FloatOpt('allowed_network_downtime',
996 default=5.0,
997 help="Allowed VM network connection downtime during live "
998 "migration, in seconds. "
999 "When the measured downtime exceeds this value, an "
1000 "exception is raised."),
Eduardo Olivaresb530c1f2024-10-03 16:14:09 +02001001 cfg.FloatOpt('allowed_metadata_downtime',
1002 default=6.0,
1003 help="Allowed VM metadata connection downtime during live "
1004 "migration, in seconds. "
1005 "When the measured downtime exceeds this value, an "
1006 "exception is raised."),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001007]
1008
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001009volume_group = cfg.OptGroup(name='volume',
1010 title='Block Storage Options')
Daryl Walleck587385b2012-03-03 13:00:26 -06001011
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001012VolumeGroup = [
1013 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -04001014 default=1,
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001015 help='Time in seconds between volume availability checks.'),
1016 cfg.IntOpt('build_timeout',
1017 default=300,
Eric Harney9b1f89c2014-10-14 14:40:19 -04001018 help='Timeout in seconds to wait for a volume to become '
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001019 'available.'),
1020 cfg.StrOpt('catalog_type',
Stephen Finucane1a744c82024-09-24 13:08:46 +01001021 default='block-storage',
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001022 help="Catalog type of the Volume Service"),
Arata Notsu8f440392013-09-13 16:14:20 +09001023 cfg.StrOpt('region',
1024 default='',
1025 help="The volume region name to use. If empty, the value "
1026 "of identity.region is used instead. If no such region "
1027 "is found in the service catalog, the first found one is "
1028 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +00001029 cfg.StrOpt('endpoint_type',
1030 default='publicURL',
1031 choices=['public', 'admin', 'internal',
1032 'publicURL', 'adminURL', 'internalURL'],
1033 help="The endpoint type to use for the volume service."),
Lukáš Piwowarski553d91b2023-09-21 11:14:24 +02001034 cfg.StrOpt('backup_driver',
1035 default='ceph',
1036 choices=['ceph', 'swift', 'nfs', 'glusterfs', 'posix', 'google',
1037 's3'],
1038 help="What kind of backup_driver does cinder use?"
1039 "https://docs.openstack.org/cinder/latest/configuration/"
1040 "block-storage/backup-drivers.html"),
Benny Kopilovaf136a92015-11-10 07:37:23 +02001041 cfg.ListOpt('backend_names',
1042 default=['BACKEND_1', 'BACKEND_2'],
april4be58dc2015-12-29 00:07:22 +08001043 help='A list of backend names separated by comma. '
bkopilov27905cc2016-04-12 14:29:13 +03001044 'The backend name must be declared in cinder.conf'),
Ansuman Bebarta46d540d2021-02-16 18:48:33 +05301045 cfg.StrOpt('volume_type',
1046 default='',
1047 help='Volume type to be used while creating volume.'),
whoami-rajatb04b1022023-02-27 09:41:22 +00001048 cfg.StrOpt('volume_type_multiattach',
1049 default='',
1050 help='Multiattach volume type used while creating multiattach '
1051 'volume.'),
Adam Gandelman827ad332013-06-24 17:04:09 -07001052 cfg.StrOpt('storage_protocol',
1053 default='iSCSI',
1054 help='Backend protocol to target when creating volume types'),
1055 cfg.StrOpt('vendor_name',
1056 default='Open Source',
1057 help='Backend vendor to target when creating volume types'),
Rajat Dhasmanafbd90e92025-01-07 22:53:12 +05301058 cfg.ListOpt('disk_format',
1059 default=['raw', 'qcow2'],
1060 help='Disk format to use when copying a volume to image'),
Jerry Cai9733d0e2014-03-19 15:50:49 +08001061 cfg.IntOpt('volume_size',
1062 default=1,
Takashi Kajinamia06cf362024-01-20 11:44:00 +09001063 min=1,
Jerry Cai9733d0e2014-03-19 15:50:49 +08001064 help='Default size in GB for volumes created by volumes tests'),
Martin Kopec37c4bd32021-06-24 15:46:00 +00001065 cfg.IntOpt('volume_size_extend',
1066 default=1,
Takashi Kajinamia06cf362024-01-20 11:44:00 +09001067 min=1,
Martin Kopec37c4bd32021-06-24 15:46:00 +00001068 help="Size in GB a volume is extended by - if a test "
1069 "extends a volume, the size of the new volume will be "
1070 "volume_size + volume_size_extend."),
jeremy.zhangf4fbf302017-03-22 11:25:53 +08001071 cfg.ListOpt('manage_volume_ref',
1072 default=['source-name', 'volume-%s'],
1073 help="A reference to existing volume for volume manage. "
1074 "It contains two elements, the first is ref type "
1075 "(like 'source-name', 'source-id', etc), the second is "
1076 "volume name template used in storage backend"),
jeremy.zhangebc752b2017-06-14 13:58:37 +08001077 cfg.ListOpt('manage_snapshot_ref',
1078 default=['source-name', '_snapshot-%s'],
1079 help="A reference to existing snapshot for snapshot manage. "
1080 "It contains two elements, the first is ref type "
1081 "(like 'source-name', 'source-id', etc), the second is "
1082 "snapshot name template used in storage backend"),
Andrew Kerrfcb0b682016-04-01 16:01:34 -04001083 cfg.StrOpt('min_microversion',
1084 default=None,
1085 help="Lower version of the test target microversion range. "
1086 "The format is 'X.Y', where 'X' and 'Y' are int values. "
1087 "Tempest selects tests based on the range between "
1088 "min_microversion and max_microversion. "
1089 "If both values are not specified, Tempest avoids tests "
1090 "which require a microversion. Valid values are string "
1091 "with format 'X.Y' or string 'latest'",),
1092 cfg.StrOpt('max_microversion',
1093 default=None,
1094 help="Upper version of the test target microversion range. "
1095 "The format is 'X.Y', where 'X' and 'Y' are int values. "
1096 "Tempest selects tests based on the range between "
1097 "min_microversion and max_microversion. "
1098 "If both values are not specified, Tempest avoids tests "
1099 "which require a microversion. Valid values are string "
1100 "with format 'X.Y' or string 'latest'",),
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001101]
K Jonathan Harkerd6ba4b42012-12-18 13:50:47 -08001102
Matthew Treinishd5c96022013-10-17 21:51:23 +00001103volume_feature_group = cfg.OptGroup(name='volume-feature-enabled',
1104 title='Enabled Cinder Features')
1105
1106VolumeFeaturesGroup = [
1107 cfg.BoolOpt('multi_backend',
1108 default=False,
Matthew Treinishe3d26142013-11-26 19:14:58 +00001109 help="Runs Cinder multi-backend test (requires 2 backends)"),
Giulio Fidente74b08ad2014-01-18 04:02:51 +01001110 cfg.BoolOpt('backup',
1111 default=True,
1112 help='Runs Cinder volumes backup test'),
JordanPbce55532014-03-19 12:10:32 +01001113 cfg.BoolOpt('snapshot',
1114 default=True,
1115 help='Runs Cinder volume snapshot test'),
Takeaki Matsumoto1702aed2015-08-25 08:44:26 +09001116 cfg.BoolOpt('clone',
1117 default=True,
1118 help='Runs Cinder volume clone test'),
Jordan Pittier31256252017-01-11 14:29:49 +01001119 cfg.BoolOpt('manage_snapshot',
1120 default=False,
1121 help='Runs Cinder manage snapshot tests'),
jeremy.zhangf4fbf302017-03-22 11:25:53 +08001122 cfg.BoolOpt('manage_volume',
1123 default=False,
1124 help='Runs Cinder manage volume tests'),
Matthew Treinishe3d26142013-11-26 19:14:58 +00001125 cfg.ListOpt('api_extensions',
1126 default=['all'],
Zhi Kun Liude25c022014-02-14 13:25:19 +08001127 help='A list of enabled volume extensions with a special '
Simeon Monov5d7effe2014-07-16 07:32:38 +03001128 'entry all which indicates every extension is enabled. '
1129 'Empty list indicates all extensions are disabled'),
Matt Riedemann0cc76bf2017-07-05 17:29:31 -04001130 cfg.BoolOpt('extend_attached_volume',
1131 default=False,
1132 help='Does the cloud support extending the size of a volume '
1133 'which is currently attached to a server instance? This '
1134 'depends on the 3.42 volume API microversion and the '
1135 '2.51 compute API microversion. Also, not all volume or '
Lee Yarwood4bd9edb2020-01-31 17:26:25 +00001136 'compute backends support this operation.'),
1137 cfg.BoolOpt('extend_attached_encrypted_volume',
1138 default=False,
1139 help='Does the cloud support extending the size of an '
1140 'encrypted volume which is currently attached to a '
1141 'server instance? This depends on the 3.42 volume API '
1142 'microversion and the 2.51 compute API microversion. '
1143 'Also, not all volume or compute backends support this '
Jake Yip2ba26af2023-05-05 20:37:10 +10001144 'operation.'),
1145 cfg.BoolOpt('extend_volume_with_snapshot',
1146 default=True,
1147 help='Does the cloud support extending the size of a volume '
1148 'which has snapshot? Some drivers do not support this '
jskundad7445982023-10-18 13:49:02 +02001149 'operation.'),
1150 cfg.StrOpt('volume_types_for_data_volume',
1151 default=None,
1152 help='Volume types used for data volumes. Multiple volume '
1153 'types can be assigned.'),
Maxim Sava4bd81f82024-06-25 11:17:16 +03001154 cfg.BoolOpt('enable_volume_image_dep_tests',
Maxim Savacd0f4bc2024-11-03 09:17:38 +02001155 deprecated_name='volume_image_dep_tests',
Maxim Sava1be8cab2024-03-26 14:23:22 +02001156 default=True,
Christian Berendt045252f2024-12-17 11:52:26 +01001157 help='Run tests for dependencies between images, volumes '
Maxim Sava1be8cab2024-03-26 14:23:22 +02001158 'and instance snapshots')
Matthew Treinishd5c96022013-10-17 21:51:23 +00001159]
1160
Daryl Walleck587385b2012-03-03 13:00:26 -06001161
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001162object_storage_group = cfg.OptGroup(name='object-storage',
1163 title='Object Storage Service Options')
Attila Fazekasa23f5002012-10-23 19:32:45 +02001164
DennyZhang1e71b612013-09-26 12:35:40 -05001165ObjectStoreGroup = [
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001166 cfg.StrOpt('catalog_type',
1167 default='object-store',
1168 help="Catalog type of the Object-Storage service."),
Arata Notsu8f440392013-09-13 16:14:20 +09001169 cfg.StrOpt('region',
1170 default='',
1171 help="The object-storage region name to use. If empty, the "
1172 "value of identity.region is used instead. If no such "
1173 "region is found in the service catalog, the first found "
1174 "one is used."),
JordanP5d29b2c2013-12-18 13:56:03 +00001175 cfg.StrOpt('endpoint_type',
1176 default='publicURL',
1177 choices=['public', 'admin', 'internal',
1178 'publicURL', 'adminURL', 'internalURL'],
1179 help="The endpoint type to use for the object-store service."),
Matthew Treinishf319a732013-10-24 21:39:24 +00001180 cfg.IntOpt('container_sync_timeout',
Daisuke Morita1ac3ee02014-08-25 12:59:18 +09001181 default=600,
Fabien Boucher2178d312013-12-31 15:38:57 +01001182 help="Number of seconds to time on waiting for a container "
nayna-patelb4989b32013-01-09 06:25:13 +00001183 "to container synchronization complete."),
Matthew Treinishf319a732013-10-24 21:39:24 +00001184 cfg.IntOpt('container_sync_interval',
nayna-patelb4989b32013-01-09 06:25:13 +00001185 default=5,
Fabien Boucher2178d312013-12-31 15:38:57 +01001186 help="Number of seconds to wait while looping to check the "
nayna-patelb4989b32013-01-09 06:25:13 +00001187 "status of a container to container synchronization"),
Matthew Treinish3fdb80c2013-08-15 11:13:19 -04001188 cfg.StrOpt('operator_role',
Martin Kopec99d4dae2020-05-27 10:33:17 +00001189 default='member',
Matthew Treinish3fdb80c2013-08-15 11:13:19 -04001190 help="Role to add to users created for swift tests to "
1191 "enable creating containers"),
Matthew Treinish998c91d2014-03-01 12:39:49 -05001192 cfg.StrOpt('reseller_admin_role',
1193 default='ResellerAdmin',
1194 help="User role that has reseller admin"),
Daisuke Morita1ac3ee02014-08-25 12:59:18 +09001195 cfg.StrOpt('realm_name',
1196 default='realm1',
1197 help="Name of sync realm. A sync realm is a set of clusters "
1198 "that have agreed to allow container syncing with each "
1199 "other. Set the same realm name as Swift's "
1200 "container-sync-realms.conf"),
1201 cfg.StrOpt('cluster_name',
1202 default='name1',
1203 help="One name of cluster which is set in the realm whose name "
1204 "is set in 'realm_name' item in this file. Set the "
1205 "same cluster name as Swift's container-sync-realms.conf"),
Bas de Bruijnec9f9a032022-07-19 11:16:02 -03001206 cfg.IntOpt('build_timeout',
1207 default=10,
1208 help="Timeout in seconds to wait for objects to create."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001209]
Attila Fazekasa23f5002012-10-23 19:32:45 +02001210
Matthew Treinishd5c96022013-10-17 21:51:23 +00001211object_storage_feature_group = cfg.OptGroup(
1212 name='object-storage-feature-enabled',
1213 title='Enabled object-storage features')
1214
1215ObjectStoreFeaturesGroup = [
Matthew Treinish20345382013-12-13 17:04:23 +00001216 cfg.ListOpt('discoverable_apis',
1217 default=['all'],
1218 help="A list of the enabled optional discoverable apis. "
1219 "A single entry, all, indicates that all of these "
1220 "features are expected to be enabled"),
Daisuke Morita20a183f2014-08-25 14:43:36 +09001221 cfg.BoolOpt('container_sync',
1222 default=True,
1223 help="Execute (old style) container-sync tests"),
1224 cfg.BoolOpt('object_versioning',
1225 default=True,
1226 help="Execute object-versioning tests"),
1227 cfg.BoolOpt('discoverability',
1228 default=True,
1229 help="Execute discoverability tests"),
Giulio Fidente95758b12022-07-14 15:14:24 +02001230 cfg.StrOpt('tempurl_digest_hashlib',
1231 default='sha256',
1232 help="Hashing algorithm to use for the temp_url tests. "
1233 "Needs to be supported both by Swift and the "
1234 "hashlib module, for example sha1 or sha256"),
Matthew Treinishd5c96022013-10-17 21:51:23 +00001235]
1236
Luigi Toscano14d172d2015-01-23 16:37:47 +01001237
Masayuki Igawa73d9f3a2013-05-24 10:30:01 +09001238scenario_group = cfg.OptGroup(name='scenario', title='Scenario Test Options')
1239
1240ScenarioGroup = [
Alessandro Pilottib7c1daa2014-08-16 14:24:13 +03001241 cfg.StrOpt('img_file', deprecated_name='qcow2_img_file',
Martin Kopec02af6a42020-03-03 12:39:12 +00001242 default='/opt/stack/new/devstack/files/images'
1243 '/cirros-0.3.1-x86_64-disk.img',
1244 help='Image full path.'),
Alessandro Pilottib7c1daa2014-08-16 14:24:13 +03001245 cfg.StrOpt('img_disk_format',
1246 default='qcow2',
1247 help='Image disk format'),
1248 cfg.StrOpt('img_container_format',
1249 default='bare',
1250 help='Image container format'),
Evgeny Antyshev7ba0d5f2015-04-28 13:18:07 +00001251 cfg.DictOpt('img_properties', help='Glance image properties. '
1252 'Use for custom images which require them'),
Yair Fried413bf2d2014-11-19 17:07:11 +02001253 cfg.StrOpt('dhcp_client',
1254 default='udhcpc',
Slawek Kaplonski49163f92023-01-20 12:20:35 +01001255 choices=["udhcpc", "dhclient", "dhcpcd", ""],
Rajesh Tailora85bdb42024-04-02 12:01:53 +05301256 help='DHCP client used by images to renew DHCP lease. '
Yair Fried413bf2d2014-11-19 17:07:11 +02001257 'If left empty, update operation will be skipped. '
Slawek Kaplonski49163f92023-01-20 12:20:35 +01001258 'Supported clients: "udhcpc", "dhclient", "dhcpcd"'),
Claudiu Belu33c3e602014-08-28 16:38:01 +03001259 cfg.StrOpt('protocol',
1260 default='icmp',
1261 choices=('icmp', 'tcp', 'udp'),
1262 help='The protocol used in security groups tests to check '
Martin Kopec9086dca2024-03-20 13:18:57 +01001263 'connectivity.'),
1264 cfg.StrOpt('target_dir',
1265 default='/tmp',
1266 help='Directory in which to write the timestamp file.'),
Masayuki Igawa73d9f3a2013-05-24 10:30:01 +09001267]
1268
1269
Matthew Treinish4c412922013-07-16 15:27:42 -04001270service_available_group = cfg.OptGroup(name="service_available",
1271 title="Available OpenStack Services")
1272
1273ServiceAvailableGroup = [
1274 cfg.BoolOpt('cinder',
1275 default=True,
1276 help="Whether or not cinder is expected to be available"),
Matthew Treinishfaa340d2013-07-19 16:26:21 -04001277 cfg.BoolOpt('neutron',
Takashi Kajinamia4f57d32024-05-05 01:00:52 +09001278 default=True,
Matthew Treinishfaa340d2013-07-19 16:26:21 -04001279 help="Whether or not neutron is expected to be available"),
Matthew Treinish853ae442013-07-19 16:36:07 -04001280 cfg.BoolOpt('glance',
1281 default=True,
1282 help="Whether or not glance is expected to be available"),
Matthew Treinish61e332b2013-07-19 16:42:31 -04001283 cfg.BoolOpt('swift',
1284 default=True,
1285 help="Whether or not swift is expected to be available"),
Matthew Treinish6b41e242013-07-19 16:49:28 -04001286 cfg.BoolOpt('nova',
1287 default=True,
1288 help="Whether or not nova is expected to be available"),
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001289 cfg.BoolOpt('horizon',
1290 default=True,
1291 help="Whether or not horizon is expected to be available"),
Matthew Treinish4c412922013-07-16 15:27:42 -04001292]
1293
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001294enforce_scope_group = cfg.OptGroup(name="enforce_scope",
1295 title="OpenStack Services with "
1296 "enforce scope")
1297
1298
1299EnforceScopeGroup = [
1300 cfg.BoolOpt('nova',
1301 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001302 help='Does the compute service API policies enforce scope and '
1303 'new defaults? This configuration value should be '
1304 'enabled when nova.conf: [oslo_policy]. '
1305 'enforce_new_defaults and nova.conf: [oslo_policy]. '
1306 'enforce_scope options are enabled in nova conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001307 cfg.BoolOpt('neutron',
1308 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001309 help='Does the network service API policies enforce scope and '
1310 'new defaults? This configuration value should be '
1311 'enabled when neutron.conf: [oslo_policy]. '
1312 'enforce_new_defaults and neutron.conf: [oslo_policy]. '
1313 'enforce_scope options are enabled in neutron conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001314 cfg.BoolOpt('glance',
1315 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001316 help='Does the Image service API policies enforce scope and '
1317 'new defaults? This configuration value should be '
1318 'enabled when glance.conf: [oslo_policy]. '
1319 'enforce_new_defaults and glance.conf: [oslo_policy]. '
1320 'enforce_scope options are enabled in glance conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001321 cfg.BoolOpt('cinder',
1322 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001323 help='Does the Volume service API policies enforce scope and '
1324 'new defaults? This configuration value should be '
1325 'enabled when cinder.conf: [oslo_policy]. '
1326 'enforce_new_defaults and cinder.conf: [oslo_policy]. '
1327 'enforce_scope options are enabled in cinder conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001328 cfg.BoolOpt('keystone',
1329 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001330 help='Does the Identity service API policies enforce scope '
1331 'and new defaults? This configuration value should be '
1332 'enabled when keystone.conf: [oslo_policy]. '
1333 'enforce_new_defaults and keystone.conf: [oslo_policy]. '
1334 'enforce_scope options are enabled in keystone conf.'),
Ghanshyam Mannb6521a82022-11-30 14:31:30 -06001335 cfg.BoolOpt('placement',
1336 default=False,
1337 help='Does the placement service API policies enforce scope '
1338 'and new defaults? This configuration value should be '
1339 'enabled when placement.conf: [oslo_policy]. '
1340 'enforce_new_defaults and nova.conf: [oslo_policy]. '
1341 'enforce_scope options are enabled in placement conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001342]
1343
Attila Fazekasaeeeefd2013-08-06 17:01:56 +02001344debug_group = cfg.OptGroup(name="debug",
1345 title="Debug System")
1346
1347DebugGroup = [
Sean Daguec522c092014-03-24 10:43:22 -04001348 cfg.StrOpt('trace_requests',
1349 default='',
1350 help="""A regex to determine which requests should be traced.
1351
1352This is a regex to match the caller for rest client requests to be able to
1353selectively trace calls out of specific classes and methods. It largely
1354exists for test development, and is not expected to be used in a real deploy
1355of tempest. This will be matched against the discovered ClassName:method
1356in the test environment.
1357
1358Expected values for this field are:
1359
1360 * ClassName:test_method_name - traces one test_method
1361 * ClassName:setUp(Class) - traces specific setup functions
1362 * ClassName:tearDown(Class) - traces specific teardown functions
1363 * ClassName:_run_cleanups - traces the cleanup functions
1364
1365If nothing is specified, this feature is not enabled. To trace everything
1366specify .* as the regex.
1367""")
Attila Fazekasaeeeefd2013-08-06 17:01:56 +02001368]
1369
Ilya Shakhat1291bb42017-11-29 18:08:16 +01001370
1371profiler_group = cfg.OptGroup(name="profiler",
1372 title="OpenStack Profiler")
1373
1374ProfilerGroup = [
1375 cfg.StrOpt('key',
1376 help="The secret key to enable OpenStack Profiler. The value "
1377 "should match the one configured in OpenStack services "
1378 "under `[profiler]/hmac_keys` property. The default empty "
1379 "value keeps profiling disabled"),
1380]
1381
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001382DefaultGroup = [
Martin Kopecae155b72017-06-26 09:41:21 +00001383 cfg.BoolOpt('pause_teardown',
1384 default=False,
1385 help="""Whether to pause a test in global teardown.
1386
1387The best use case is investigating used resources of one test.
1388A test can be run as follows:
Michael Johnsonafe134a2024-11-06 00:05:58 +00001389$ stestr run --pdb TEST_ID
Martin Kopecae155b72017-06-26 09:41:21 +00001390or
Michael Johnsonafe134a2024-11-06 00:05:58 +00001391$ python -m testtools.run TEST_ID"""),
Luigi Dino Tamagnone17053d62023-10-03 14:05:25 +00001392 cfg.StrOpt('resource_name_prefix',
1393 default='tempest',
1394 help="Define the prefix name for the resources created by "
1395 "tempest. Tempest cleanup CLI will use this config option "
1396 "to cleanup only the resources that match the prefix. "
1397 "Make sure this prefix does not match with the resource "
1398 "name you do not want Tempest cleanup CLI to delete."),
Katarina Strenkovaf999b152023-10-10 15:16:15 +00001399 cfg.BoolOpt('record_resources',
1400 default=False,
1401 help="Allows to record all resources created by Tempest. "
1402 "These resources are stored in file resource_list.json, "
1403 "which can be later used for resource deletion by "
1404 "command tempest cleanup. The resource_list.json file "
1405 "will be appended in case of multiple Tempest runs, "
1406 "so the file will contain a list of resources created "
1407 "during all Tempest runs."),
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001408]
1409
Jon Grimm270bd7f2014-08-05 18:11:29 +00001410_opts = [
1411 (auth_group, AuthGroup),
1412 (compute_group, ComputeGroup),
1413 (compute_features_group, ComputeFeaturesGroup),
1414 (identity_group, IdentityGroup),
zhufl071e94c2016-07-12 10:26:34 +08001415 (service_clients_group, ServiceClientsGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001416 (identity_feature_group, IdentityFeatureGroup),
1417 (image_group, ImageGroup),
1418 (image_feature_group, ImageFeaturesGroup),
1419 (network_group, NetworkGroup),
1420 (network_feature_group, NetworkFeaturesGroup),
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001421 (dashboard_group, DashboardGroup),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001422 (validation_group, ValidationGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001423 (volume_group, VolumeGroup),
1424 (volume_feature_group, VolumeFeaturesGroup),
1425 (object_storage_group, ObjectStoreGroup),
1426 (object_storage_feature_group, ObjectStoreFeaturesGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001427 (scenario_group, ScenarioGroup),
1428 (service_available_group, ServiceAvailableGroup),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001429 (enforce_scope_group, EnforceScopeGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001430 (debug_group, DebugGroup),
Lajos Katonaceb88212018-11-30 14:54:12 +01001431 (placement_group, PlacementGroup),
Ilya Shakhat1291bb42017-11-29 18:08:16 +01001432 (profiler_group, ProfilerGroup),
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001433 (None, DefaultGroup)
Jon Grimm270bd7f2014-08-05 18:11:29 +00001434]
1435
Roman Prykhodchenko62b1ed12013-10-16 21:51:47 +03001436
Matthew Treinish43b296a2014-02-28 15:23:00 -05001437def register_opts():
Matthew Treinisha966d0f2015-07-01 17:37:31 -04001438 ext_plugins = plugins.TempestTestPluginManager()
1439 # Register in-tree tempest config options
Jon Grimm270bd7f2014-08-05 18:11:29 +00001440 for g, o in _opts:
Maru Newbyf440c292015-03-31 15:58:47 +00001441 register_opt_group(_CONF, g, o)
Matthew Treinisha966d0f2015-07-01 17:37:31 -04001442 # Call external plugin config option registration
1443 ext_plugins.register_plugin_opts(_CONF)
Jon Grimm270bd7f2014-08-05 18:11:29 +00001444
1445
1446def list_opts():
1447 """Return a list of oslo.config options available.
1448
1449 The purpose of this is to allow tools like the Oslo sample config file
1450 generator to discover the options exposed to users.
1451 """
Matthew Treinish83a19aa2015-07-23 13:06:13 -04001452 ext_plugins = plugins.TempestTestPluginManager()
Chris Hoged7b4fd12015-11-11 10:24:52 -08001453 # Make a shallow copy of the options list that can be
1454 # extended by plugins. Send back the group object
1455 # to allow group help text to be generated.
1456 opt_list = [(g, o) for g, o in _opts]
Matthew Treinish83a19aa2015-07-23 13:06:13 -04001457 opt_list.extend(ext_plugins.get_plugin_options_list())
1458 return opt_list
Matthew Treinish43b296a2014-02-28 15:23:00 -05001459
1460
Ken'ichi Ohmichi3f5c1392018-04-11 14:38:22 -07001461# This should never be called outside of this module
Sean Dague3b9b1f32013-12-20 17:04:54 -05001462class TempestConfigPrivate(object):
Daryl Walleck1465d612011-11-02 02:22:15 -05001463 """Provides OpenStack configuration information."""
1464
David Patersonbe9f9832015-10-15 09:10:45 -07001465 DEFAULT_CONFIG_DIR = os.path.join(os.getcwd(), "etc")
Daryl Walleck1465d612011-11-02 02:22:15 -05001466
Brian Waldon738cd632011-12-12 18:45:09 -05001467 DEFAULT_CONFIG_FILE = "tempest.conf"
1468
Andrea Frittolia96ee212014-08-15 18:34:20 +01001469 def __getattr__(self, attr):
1470 # Handles config options from the default group
Maru Newbyf440c292015-03-31 15:58:47 +00001471 return getattr(_CONF, attr)
Andrea Frittolia96ee212014-08-15 18:34:20 +01001472
Matthew Treinish43b296a2014-02-28 15:23:00 -05001473 def _set_attrs(self):
Andrea Frittoli382a6f12017-03-09 11:52:17 +00001474 # This methods ensures that config options in Tempest as well as
1475 # in Tempest plugins can be accessed via:
1476 # CONF.<normalised_group_name>.<key_name>
1477 # where:
1478 # normalised_group_name = group_name.replace('-', '_')
1479 # Attributes are set at __init__ time *only* for known option groups
Maru Newbyf440c292015-03-31 15:58:47 +00001480 self.auth = _CONF.auth
1481 self.compute = _CONF.compute
1482 self.compute_feature_enabled = _CONF['compute-feature-enabled']
1483 self.identity = _CONF.identity
zhufl071e94c2016-07-12 10:26:34 +08001484 self.service_clients = _CONF['service-clients']
Maru Newbyf440c292015-03-31 15:58:47 +00001485 self.identity_feature_enabled = _CONF['identity-feature-enabled']
1486 self.image = _CONF.image
1487 self.image_feature_enabled = _CONF['image-feature-enabled']
1488 self.network = _CONF.network
1489 self.network_feature_enabled = _CONF['network-feature-enabled']
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001490 self.dashboard = _CONF.dashboard
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001491 self.validation = _CONF.validation
Maru Newbyf440c292015-03-31 15:58:47 +00001492 self.volume = _CONF.volume
1493 self.volume_feature_enabled = _CONF['volume-feature-enabled']
1494 self.object_storage = _CONF['object-storage']
1495 self.object_storage_feature_enabled = _CONF[
Matthew Treinishd5c96022013-10-17 21:51:23 +00001496 'object-storage-feature-enabled']
Maru Newbyf440c292015-03-31 15:58:47 +00001497 self.scenario = _CONF.scenario
1498 self.service_available = _CONF.service_available
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001499 self.enforce_scope = _CONF.enforce_scope
Maru Newbyf440c292015-03-31 15:58:47 +00001500 self.debug = _CONF.debug
Matthew Treinish46008082015-04-14 18:32:47 -04001501 logging.tempest_set_log_file('tempest.log')
Andrea Frittoli382a6f12017-03-09 11:52:17 +00001502 # Setting attributes for plugins
1503 # NOTE(andreaf) Plugins have no access to the TempestConfigPrivate
1504 # instance at discovery time, so they have no way of setting these
1505 # aliases themselves.
1506 ext_plugins = plugins.TempestTestPluginManager()
1507 for group, _ in ext_plugins.get_plugin_options_list():
1508 if isinstance(group, cfg.OptGroup):
1509 # If we have an OptGroup
1510 group_name = group.name
1511 group_dest = group.dest
1512 else:
1513 # If we have a group name as a string
1514 group_name = group
1515 group_dest = group.replace('-', '_')
1516 # NOTE(andreaf) We can set the attribute safely here since in
1517 # case of name conflict we would not have reached this point.
1518 setattr(self, group_dest, _CONF[group_name])
Sean Dague86bd8422013-12-20 09:56:44 -05001519
Joe Gordon28a84ae2014-07-17 15:38:28 +00001520 def __init__(self, parse_conf=True, config_path=None):
Matthew Treinish43b296a2014-02-28 15:23:00 -05001521 """Initialize a configuration from a conf directory and conf file."""
1522 super(TempestConfigPrivate, self).__init__()
1523 config_files = []
1524 failsafe_path = "/etc/tempest/" + self.DEFAULT_CONFIG_FILE
1525
Joe Gordon28a84ae2014-07-17 15:38:28 +00001526 if config_path:
1527 path = config_path
1528 else:
1529 # Environment variables override defaults...
1530 conf_dir = os.environ.get('TEMPEST_CONFIG_DIR',
1531 self.DEFAULT_CONFIG_DIR)
1532 conf_file = os.environ.get('TEMPEST_CONFIG',
1533 self.DEFAULT_CONFIG_FILE)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001534
Joe Gordon28a84ae2014-07-17 15:38:28 +00001535 path = os.path.join(conf_dir, conf_file)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001536
1537 if not os.path.isfile(path):
1538 path = failsafe_path
1539
1540 # only parse the config file if we expect one to exist. This is needed
1541 # to remove an issue with the config file up to date checker.
1542 if parse_conf:
1543 config_files.append(path)
Maru Newbyf440c292015-03-31 15:58:47 +00001544 logging.register_options(_CONF)
Matthew Treinish5440a402014-10-02 14:36:16 -04001545 if os.path.isfile(path):
Maru Newbyf440c292015-03-31 15:58:47 +00001546 _CONF([], project='tempest', default_config_files=config_files)
Matthew Treinish5440a402014-10-02 14:36:16 -04001547 else:
Maru Newbyf440c292015-03-31 15:58:47 +00001548 _CONF([], project='tempest')
Marc Kodererc81c7672015-12-17 12:10:12 +01001549
1550 logging_cfg_path = "%s/logging.conf" % os.path.dirname(path)
Tom Patzige6f7c7d2016-02-17 16:46:11 +01001551 if ((not hasattr(_CONF, 'log_config_append') or
afazekas40fcb9b2019-03-08 11:25:11 +01001552 _CONF.log_config_append is None) and
Marc Kodererc81c7672015-12-17 12:10:12 +01001553 os.path.isfile(logging_cfg_path)):
1554 # if logging conf is in place we need to set log_config_append
1555 _CONF.log_config_append = logging_cfg_path
1556
Maru Newbyf440c292015-03-31 15:58:47 +00001557 logging.setup(_CONF, 'tempest')
Matthew Treinish43b296a2014-02-28 15:23:00 -05001558 LOG = logging.getLogger('tempest')
Jordan Pittier525ec712016-12-07 17:51:26 +01001559 LOG.info("Using tempest config file %s", path)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001560 register_opts()
1561 self._set_attrs()
Masayuki Igawa9ec4cd82014-02-05 15:04:16 +09001562 if parse_conf:
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301563 _CONF.log_opt_values(LOG, logging.DEBUG)
Masayuki Igawa9ec4cd82014-02-05 15:04:16 +09001564
Sean Dague86bd8422013-12-20 09:56:44 -05001565
1566class TempestConfigProxy(object):
1567 _config = None
Joe Gordon28a84ae2014-07-17 15:38:28 +00001568 _path = None
Sean Dague86bd8422013-12-20 09:56:44 -05001569
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001570 _extra_log_defaults = [
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301571 ('paramiko.transport', logging.INFO),
1572 ('requests.packages.urllib3.connectionpool', logging.WARN),
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001573 ]
1574
1575 def _fix_log_levels(self):
1576 """Tweak the oslo log defaults."""
Doug Hellmann583ce2c2015-03-11 14:55:46 +00001577 for name, level in self._extra_log_defaults:
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301578 logging.getLogger(name).logger.setLevel(level)
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001579
Sean Dague86bd8422013-12-20 09:56:44 -05001580 def __getattr__(self, attr):
1581 if not self._config:
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001582 self._fix_log_levels()
Matthew Treinishaa29c7e2015-04-23 16:35:09 -04001583 lock_dir = os.path.join(tempfile.gettempdir(), 'tempest-lock')
1584 lockutils.set_defaults(lock_dir)
Joe Gordon28a84ae2014-07-17 15:38:28 +00001585 self._config = TempestConfigPrivate(config_path=self._path)
Sean Dague86bd8422013-12-20 09:56:44 -05001586
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001587 # Pushing tempest internal service client configuration to the
1588 # service clients register. Doing this in the config module ensures
1589 # that the configuration is available by the time we register the
1590 # service clients.
1591 # NOTE(andreaf) This has to be done at the time the first
1592 # attribute is accessed, to ensure all plugins have been already
1593 # loaded, options registered, and _config is set.
1594 _register_tempest_service_clients()
1595
Andrea Frittoli8b23c792017-03-09 13:17:01 +00001596 # Registering service clients and pushing their configuration to
1597 # the service clients register. Doing this in the config module
1598 # ensures that the configuration is available by the time we
1599 # discover tests from plugins.
1600 plugins.TempestTestPluginManager()._register_service_clients()
1601
Sean Dague86bd8422013-12-20 09:56:44 -05001602 return getattr(self._config, attr)
1603
Joe Gordon28a84ae2014-07-17 15:38:28 +00001604 def set_config_path(self, path):
1605 self._path = path
Masayuki Igawa79159f82018-07-27 15:00:37 +09001606 # FIXME(masayukig): bug#1783751 To pass the config file path to child
1607 # processes, we need to set the environment variables here as a
1608 # workaround.
1609 os.environ['TEMPEST_CONFIG_DIR'] = os.path.dirname(path)
1610 os.environ['TEMPEST_CONFIG'] = os.path.basename(path)
Joe Gordon28a84ae2014-07-17 15:38:28 +00001611
Sean Dague86bd8422013-12-20 09:56:44 -05001612
1613CONF = TempestConfigProxy()
Matthew Treinishca5a9ff2016-04-16 15:04:34 -04001614
1615
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001616def service_client_config(service_client_name=None):
1617 """Return a dict with the parameters to init service clients
1618
1619 Extracts from CONF the settings specific to the service_client_name and
1620 api_version, and formats them as dict ready to be passed to the service
1621 clients __init__:
1622
1623 * `region` (default to identity)
1624 * `catalog_type`
1625 * `endpoint_type`
1626 * `build_timeout` (object-storage and identity default to compute)
1627 * `build_interval` (object-storage and identity default to compute)
1628
1629 The following common settings are always returned, even if
1630 `service_client_name` is None:
1631
1632 * `disable_ssl_certificate_validation`
1633 * `ca_certs`
1634 * `trace_requests`
zhufl071e94c2016-07-12 10:26:34 +08001635 * `http_timeout`
Matthew Treinish74514402016-09-01 11:44:57 -04001636 * `proxy_url`
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001637
1638 The dict returned by this does not fit a few service clients:
1639
1640 * The endpoint type is not returned for identity client, since it takes
1641 three different values for v2 admin, v2 public and v3
1642 * The `ServersClient` from compute accepts an optional
1643 `enable_instance_password` parameter, which is not returned.
1644 * The `VolumesClient` for both v1 and v2 volume accept an optional
1645 `default_volume_size` parameter, which is not returned.
1646 * The `TokenClient` and `V3TokenClient` have a very different
1647 interface, only auth_url is needed for them.
1648
1649 :param service_client_name: str Name of the service. Supported values are
1650 'compute', 'identity', 'image', 'network', 'object-storage', 'volume'
1651 :return: dictionary of __init__ parameters for the service clients
1652 :rtype: dict
1653 """
1654 _parameters = {
1655 'disable_ssl_certificate_validation':
Daniel Melladocad3f3d2016-08-19 14:17:16 +00001656 CONF.identity.disable_ssl_certificate_validation,
1657 'ca_certs': CONF.identity.ca_certificates_file,
zhufl071e94c2016-07-12 10:26:34 +08001658 'trace_requests': CONF.debug.trace_requests,
Matthew Treinish74514402016-09-01 11:44:57 -04001659 'http_timeout': CONF.service_clients.http_timeout,
1660 'proxy_url': CONF.service_clients.proxy_url,
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001661 }
1662
1663 if service_client_name is None:
1664 return _parameters
1665
1666 # Get the group of options first, by normalising the service_group_name
1667 # Services with a '-' in the name have an '_' in the option group name
1668 config_group = service_client_name.replace('-', '_')
1669 # NOTE(andreaf) Check if the config group exists. This allows for this
1670 # helper to be used for settings from registered plugins as well
1671 try:
1672 options = getattr(CONF, config_group)
1673 except cfg.NoSuchOptError:
1674 # Option group not defined
1675 raise exceptions.UnknownServiceClient(services=service_client_name)
1676 # Set endpoint_type
1677 # Identity uses different settings depending on API version, so do not
1678 # return the endpoint at all.
1679 if service_client_name != 'identity':
1680 _parameters['endpoint_type'] = getattr(options, 'endpoint_type')
1681 # Set build_*
1682 # Object storage and identity groups do not have conf settings for
1683 # build_* parameters, and we default to compute in any case
1684 for setting in ['build_timeout', 'build_interval']:
1685 if not hasattr(options, setting) or not getattr(options, setting):
1686 _parameters[setting] = getattr(CONF.compute, setting)
1687 else:
1688 _parameters[setting] = getattr(options, setting)
1689 # Set region
1690 # If a service client does not define region or region is not set
1691 # default to the identity region
1692 if not hasattr(options, 'region') or not getattr(options, 'region'):
1693 _parameters['region'] = CONF.identity.region
1694 else:
1695 _parameters['region'] = getattr(options, 'region')
1696 # Set service
1697 _parameters['service'] = getattr(options, 'catalog_type')
1698 return _parameters
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001699
1700
1701def _register_tempest_service_clients():
1702 # Register tempest own service clients using the same mechanism used
1703 # for external plugins.
1704 # The configuration data is pushed to the registry so that automatic
1705 # configuration of tempest own service clients is possible both for
1706 # tempest as well as for the plugins.
1707 service_clients = clients.tempest_modules()
1708 registry = clients.ClientsRegistry()
1709 all_clients = []
1710 for service_client in service_clients:
1711 module = service_clients[service_client]
1712 configs = service_client.split('.')[0]
1713 service_client_data = dict(
Andrea Frittoli986407d2017-10-11 10:23:17 +00001714 name=service_client.replace('.', '_').replace('-', '_'),
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001715 service_version=service_client,
1716 module_path=module.__name__,
1717 client_names=module.__all__,
1718 **service_client_config(configs)
1719 )
1720 all_clients.append(service_client_data)
1721 # NOTE(andreaf) Internal service clients do not actually belong
1722 # to a plugin, so using '__tempest__' to indicate a virtual plugin
1723 # which holds internal service clients.
1724 registry.register_service_client('__tempest__', all_clients)