blob: d5bb550e227ced2d20bb075c2c76bd01a6330fc6 [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 "
222 "keystone.conf:security_compliance.minimum_password_age.")
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500223]
Jay Pipes3f981df2012-03-27 18:59:44 -0400224
zhufl071e94c2016-07-12 10:26:34 +0800225service_clients_group = cfg.OptGroup(name='service-clients',
226 title="Service Clients Options")
227
228ServiceClientsGroup = [
229 cfg.IntOpt('http_timeout',
230 default=60,
231 help='Timeout in seconds to wait for the http request to '
232 'return'),
Matthew Treinish74514402016-09-01 11:44:57 -0400233 cfg.StrOpt('proxy_url',
234 help='Specify an http proxy to use.')
zhufl071e94c2016-07-12 10:26:34 +0800235]
236
Matthew Treinishd5021a72014-01-09 18:42:51 +0000237identity_feature_group = cfg.OptGroup(name='identity-feature-enabled',
238 title='Enabled Identity Features')
239
240IdentityFeatureGroup = [
241 cfg.BoolOpt('trust',
242 default=True,
243 help='Does the identity service have delegation and '
Matthew Treinishdb2c5972014-01-31 22:18:59 +0000244 'impersonation enabled'),
245 cfg.BoolOpt('api_v2',
Lance Bragstad1fbad232017-09-22 18:58:53 +0000246 default=False,
Lance Bragstad1fbad232017-09-22 18:58:53 +0000247 deprecated_for_removal=True,
Takashi Kajinamic0c90272024-01-20 11:23:09 +0900248 deprecated_reason='The identity v2 API tests were removed '
249 'and this option has no effect',
250 help='Is the v2 identity API enabled'),
Andrea Frittoli1413ba92017-04-21 14:33:23 +0100251 cfg.BoolOpt('api_v2_admin',
252 default=True,
Takashi Kajinamic0c90272024-01-20 11:23:09 +0900253 deprecated_for_removal=True,
254 deprecated_reason='The identity v2 API tests were removed '
255 'and this option has no effect',
256 help="Is the v2 identity admin API available?"),
Matthew Treinishdb2c5972014-01-31 22:18:59 +0000257 cfg.BoolOpt('api_v3',
258 default=True,
Takashi Kajinamic0c90272024-01-20 11:23:09 +0900259 deprecated_for_removal=True,
260 deprecated_reason='Identity v2 API was removed and v3 is '
261 'the only available identity API version '
262 'now',
Matthew Treinishdb2c5972014-01-31 22:18:59 +0000263 help='Is the v3 identity API enabled'),
Jane Zadorozhna121576d2015-06-23 12:57:13 +0300264 cfg.ListOpt('api_extensions',
265 default=['all'],
266 help="A list of enabled identity extensions with a special "
267 "entry all which indicates every extension is enabled. "
268 "Empty list indicates all extensions are disabled. "
zhufld28a2712017-11-07 13:55:18 +0800269 "To get the list of extensions run: "
270 "'openstack extension list --identity'"),
Leticia Wanderley9cafd3d2017-08-04 00:22:34 -0300271 cfg.BoolOpt('domain_specific_drivers',
272 default=False,
273 help='Are domain specific drivers enabled? '
274 'This configuration value should be same as '
275 '[identity]->domain_specific_drivers_enabled '
276 'in keystone.conf.'),
Rodrigo Duarte Sousa2d78e8e2016-09-28 10:38:08 -0300277 cfg.BoolOpt('security_compliance',
278 default=False,
279 help='Does the environment have the security compliance '
Felipe Monteiro6f960782018-03-16 02:08:38 +0000280 'settings enabled?'),
Colleen Murphyd2cbd3a2019-12-17 16:31:14 -0800281 cfg.BoolOpt('access_rules',
Takashi Kajinami73005a12024-01-20 11:56:45 +0900282 default=True,
283 deprecated_for_removal=True,
284 deprecated_reason='Access rules for application credentials '
285 'is a default feature since Train',
Colleen Murphyd2cbd3a2019-12-17 16:31:14 -0800286 help='Does the environment have access rules enabled?'),
Anna Pankiewicza0710662018-07-24 14:56:42 -0500287 cfg.BoolOpt('immutable_user_source',
288 default=False,
289 help='Set to True if the environment has a read-only '
290 'user source. This will skip all tests that attempt to '
291 'create, delete, or modify users. This should not be set '
292 'to True if using dynamic credentials')
Matthew Treinishd5021a72014-01-09 18:42:51 +0000293]
294
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500295compute_group = cfg.OptGroup(name='compute',
296 title='Compute Service Options')
Rohit Karajgie1b050d2011-12-02 16:13:18 -0800297
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500298ComputeGroup = [
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500299 cfg.StrOpt('image_ref',
Matthew Treinishafcb6b42014-05-27 13:50:02 -0400300 help="Valid primary image reference to be used in tests. "
301 "This is a required option"),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500302 cfg.StrOpt('image_ref_alt',
Matthew Treinishafcb6b42014-05-27 13:50:02 -0400303 help="Valid secondary image reference to be used in tests. "
304 "This is a required option, but if only one image is "
305 "available duplicate the value of image_ref above"),
Lee Yarwood7f7c2322019-06-06 10:57:19 +0100306 cfg.StrOpt('certified_image_ref',
307 help="Valid image reference to be used in image certificate "
308 "validation tests when enabled. This image must also "
309 "have the required img_signature_* properties set. "
310 "Additional details available within the following Nova "
311 "documentation: https://docs.openstack.org/nova/latest/"
312 "user/certificate-validation.html"),
313 cfg.ListOpt('certified_image_trusted_certs',
314 help="A list of trusted certificates to be used when the "
315 "image certificate validation compute feature is "
316 "enabled."),
Ken'ichi Ohmichi35772602013-11-14 15:03:27 +0900317 cfg.StrOpt('flavor_ref',
318 default="1",
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500319 help="Valid primary flavor to use in tests."),
Ken'ichi Ohmichi35772602013-11-14 15:03:27 +0900320 cfg.StrOpt('flavor_ref_alt',
321 default="2",
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500322 help='Valid secondary flavor to be used in tests.'),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500323 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -0400324 default=1,
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500325 help="Time in seconds between build status checks."),
326 cfg.IntOpt('build_timeout',
327 default=300,
Hugh Saunders5b139ad2014-12-15 09:08:41 +0000328 help="Timeout in seconds to wait for an instance to build. "
329 "Other services that do not define build_timeout will "
Lucian Petrut1cfe2982015-01-06 13:57:36 +0200330 "inherit this value."),
Attila Fazekas0abbc952013-07-01 19:19:42 +0200331 cfg.IntOpt('ready_wait',
332 default=0,
DennyZhang8912d012013-09-25 18:08:34 -0500333 help="Additional wait time for clean state, when there is "
334 "no OS-EXT-STS extension available"),
Attila Fazekasb0661652013-05-08 13:01:36 +0200335 cfg.StrOpt('fixed_network_name',
Chris Hoge8f1401b2014-11-19 14:00:37 -0800336 help="Name of the fixed network that is visible to all test "
Sean Dagueed6e5862016-04-04 10:49:13 -0400337 "projects. If multiple networks are available for a "
338 "project, this is the network which will be used for "
339 "creating servers if tempest does not create a network or "
zhufl0bad33e2016-10-14 17:21:46 +0800340 "a network is not specified elsewhere. It may be used for "
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000341 "ssh validation only if floating IPs are disabled."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500342 cfg.StrOpt('catalog_type',
343 default='compute',
344 help="Catalog type of the Compute service."),
Arata Notsu8f440392013-09-13 16:14:20 +0900345 cfg.StrOpt('region',
346 default='',
347 help="The compute region name to use. If empty, the value "
348 "of identity.region is used instead. If no such region "
349 "is found in the service catalog, the first found one is "
350 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000351 cfg.StrOpt('endpoint_type',
352 default='publicURL',
353 choices=['public', 'admin', 'internal',
354 'publicURL', 'adminURL', 'internalURL'],
355 help="The endpoint type to use for the compute service."),
Ryan Hsucb2e1252013-09-03 21:44:49 -0700356 cfg.StrOpt('volume_device_name',
357 default='vdb',
358 help="Expected device name when a volume is attached to "
Kevin_Zheng79ec3342017-03-25 17:33:27 +0800359 "an instance. Not all hypervisors guarantee that they "
360 "will respect the user defined device name, tests may "
361 "fail if inappropriate device name is set."),
Ken'ichi Ohmichi39437e22013-10-06 00:21:38 +0900362 cfg.IntOpt('shelved_offload_time',
363 default=0,
364 help='Time in seconds before a shelved instance is eligible '
365 'for removing from a host. -1 never offload, 0 offload '
zhufl917b5552017-11-27 16:07:24 +0800366 'when shelved. This configuration value should be same as '
zhufldc7eeb42018-09-12 11:10:16 +0800367 'nova.conf: DEFAULT.shelved_offload_time, and '
zhufl917b5552017-11-27 16:07:24 +0800368 'some tests will run for as long as the time.'),
Sean Dague782f6772015-11-11 11:26:45 -0500369 cfg.IntOpt('min_compute_nodes',
370 default=1,
371 help=('The minimum number of compute nodes expected. This will '
372 'be utilized by some multinode specific tests to ensure '
373 'that requests match the expected size of the cluster '
ghanshyam29591532016-03-11 17:12:43 +0900374 'you are testing with.')),
Ken'ichi Ohmichi49db4fe2016-08-12 15:26:51 -0700375 cfg.StrOpt('hypervisor_type',
376 default=None,
377 help="Hypervisor type of the test target on heterogeneous "
378 "compute environment. The value can be 'QEMU', 'xen' or "
379 "something."),
Ken'ichi Ohmichi4d237e72015-11-05 06:32:33 +0000380 cfg.StrOpt('min_microversion',
381 default=None,
382 help="Lower version of the test target microversion range. "
383 "The format is 'X.Y', where 'X' and 'Y' are int values. "
384 "Tempest selects tests based on the range between "
385 "min_microversion and max_microversion. "
Ghanshyam395c5b52015-12-04 17:27:16 +0900386 "If both values are not specified, Tempest avoids tests "
387 "which require a microversion. Valid values are string "
ghanshyam8889d2b2017-02-14 02:29:06 +0000388 "with format 'X.Y' or string 'latest'"),
Ken'ichi Ohmichi4d237e72015-11-05 06:32:33 +0000389 cfg.StrOpt('max_microversion',
390 default=None,
391 help="Upper version of the test target microversion range. "
392 "The format is 'X.Y', where 'X' and 'Y' are int values. "
393 "Tempest selects tests based on the range between "
394 "min_microversion and max_microversion. "
Ghanshyam395c5b52015-12-04 17:27:16 +0900395 "If both values are not specified, Tempest avoids tests "
396 "which require a microversion. Valid values are string "
ghanshyam8889d2b2017-02-14 02:29:06 +0000397 "with format 'X.Y' or string 'latest'"),
Marc Koderer979e4942016-12-08 10:07:59 +0100398 cfg.StrOpt('compute_volume_common_az',
399 default=None,
400 help='AZ to be used for Cinder and Nova. Set this parameter '
401 'when the cloud has nova.conf: cinder.cross_az_attach '
402 'set to false. Which means volumes attached to an '
403 'instance must be in the same availability zone in Cinder '
404 'as the instance availability zone in Nova. Set the '
405 'common availability zone in this config which will be '
406 'used to boot an instance as well as creating a volume. '
407 'NOTE: If that AZ is not in Cinder (or '
408 'allow_availability_zone_fallback=False in cinder.conf), '
409 'the volume create request will fail and the instance '
410 'will fail the build request.'),
jskunda5a7ed972023-08-10 22:04:19 +0200411 cfg.StrOpt('migration_source_host',
412 default=None,
413 help="Specify source host for live-migration, cold-migration"
414 " and resize tests. If option is not set tests will use"
415 " host automatically."),
416 cfg.StrOpt('migration_dest_host',
417 default=None,
418 help="Specify destination host for live-migration and cold"
419 " migration. If option is not set tests will use host"
420 " automatically."),
jamepark49d8d6312024-07-23 16:27:27 -0400421 cfg.StrOpt('target_hosts_to_avoid',
422 default='-ironic',
423 help="When aggregating available hypervisors for testing,"
424 " avoid migrating to and booting any test VM on hosts with"
425 " a name that matches the provided pattern"),
ghanshyam29591532016-03-11 17:12:43 +0900426]
427
Lajos Katonaceb88212018-11-30 14:54:12 +0100428placement_group = cfg.OptGroup(name='placement',
429 title='Placement Service Options')
430
431PlacementGroup = [
432 cfg.StrOpt('endpoint_type',
433 default='public',
434 choices=['public', 'admin', 'internal'],
435 help="The endpoint type to use for the placement service."),
436 cfg.StrOpt('catalog_type',
437 default='placement',
438 help="Catalog type of the Placement service."),
439 cfg.StrOpt('region',
Swapnil Chhanikara89eea82020-01-24 17:04:42 +0530440 default='',
Lajos Katonaceb88212018-11-30 14:54:12 +0100441 help="The placement region name to use. If empty, the value "
442 "of [identity]/region is used instead. If no such region "
443 "is found in the service catalog, the first region found "
444 "is used."),
445 cfg.StrOpt('min_microversion',
446 default=None,
447 help="Lower version of the test target microversion range. "
448 "The format is 'X.Y', where 'X' and 'Y' are int values. "
449 "Valid values are string with format 'X.Y' or string "
450 "'latest'"),
451 cfg.StrOpt('max_microversion',
452 default=None,
453 help="Upper 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]
458
459
ghanshyam29591532016-03-11 17:12:43 +0900460compute_features_group = cfg.OptGroup(name='compute-feature-enabled',
461 title="Enabled Compute Service Features")
462
463ComputeFeaturesGroup = [
Matthew Treinishd5c96022013-10-17 21:51:23 +0000464 cfg.BoolOpt('disk_config',
465 default=True,
466 help="If false, skip disk config tests"),
Pavan Kesava Raodeff57e2021-06-09 15:21:37 -0500467 # TODO(pkesav): Make it True by default once wallaby
468 # is oldest supported stable for Tempest.
469 cfg.BoolOpt('hostname_fqdn_sanitization',
470 default=False,
471 help="If false, skip fqdn instance sanitization tests. "
472 "Nova started sanitizing the instance name by replacing "
473 "the '.' with '-' to comply with fqdn hostname. Nova "
474 "changed that in Wallaby cycle, if your cloud is older "
475 "than wallaby then you can keep/make it False."),
Ashish Guptae27a9d62024-06-19 22:36:24 +0530476 cfg.StrOpt('dhcp_domain',
477 default='.novalocal',
478 help="Configure a fully-qualified domain name for instance "
479 "hostnames. The value is suffixed to instance hostname "
480 "from the database to construct the hostname that "
481 "appears in the metadata API. To disable this behavior "
482 "(for example in order to correctly support "
483 "microversion's 2.94 FQDN hostnames), set this to the "
484 "empty string."),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000485 cfg.BoolOpt('change_password',
486 default=False,
487 help="Does the test environment support changing the admin "
488 "password?"),
Adam Gandelmanc6eefb42014-07-15 16:44:08 -0700489 cfg.BoolOpt('console_output',
490 default=True,
491 help="Does the test environment support obtaining instance "
492 "serial console output?"),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000493 cfg.BoolOpt('resize',
494 default=False,
Masayuki Igawad91094d2017-04-12 16:20:09 +0900495 help="Does the test environment support resizing? When you "
496 "enable this feature, 'flavor_ref_alt' should be set and "
497 "it should refer to a larger flavor than 'flavor_ref' "
498 "one."),
Eric Windischb5538072014-03-09 23:47:35 -0400499 cfg.BoolOpt('pause',
500 default=True,
501 help="Does the test environment support pausing?"),
David Shrewsbury25f666f2014-07-22 12:17:59 -0400502 cfg.BoolOpt('shelve',
503 default=True,
504 help="Does the test environment support shelving/unshelving?"),
Alexandre Arents0a9b8232020-07-29 09:52:57 +0000505 cfg.BoolOpt('shelve_migrate',
506 default=False,
507 help="Does the test environment support "
508 "cold migration of unshelved server?"),
Eric Windischaeb7e842014-03-10 01:10:50 -0400509 cfg.BoolOpt('suspend',
510 default=True,
511 help="Does the test environment support suspend/resume?"),
Ludovic Beliveauae314882016-09-15 13:34:14 -0400512 cfg.BoolOpt('cold_migration',
513 default=True,
zhufl0bad33e2016-10-14 17:21:46 +0800514 help="Does the test environment support cold migration?"),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000515 cfg.BoolOpt('live_migration',
Joe Gordon31a139a2014-11-17 16:39:04 -0800516 default=True,
zhufl0bad33e2016-10-14 17:21:46 +0800517 help="Does the test environment support live migration?"),
Sarafraj Singh61e40452016-09-29 13:06:59 -0500518 cfg.BoolOpt('live_migrate_back_and_forth',
519 default=False,
520 help="Does the test environment support live migrating "
521 "VM back and forth between different versions of "
522 "nova-compute?"),
YAMAMOTO Takashi1f62af22015-06-16 03:29:50 +0900523 cfg.BoolOpt('metadata_service',
524 default=True,
525 help="Does the test environment support metadata service? "
526 "Ignored unless validation.run_validation=true."),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000527 cfg.BoolOpt('block_migration_for_live_migration',
528 default=False,
529 help="Does the test environment use block devices for live "
530 "migration"),
zhuflbe052d62019-11-04 10:56:02 +0800531 cfg.BoolOpt('can_migrate_between_any_hosts',
532 default=True,
533 help="Does the test environment support migrating between "
534 "any hosts? In environments with non-homogeneous compute "
535 "nodes you can set this to False so that it will select "
536 "destination host for migrating automatically"),
Ghanshyam Mann41c17572014-02-27 18:52:56 +0900537 cfg.BoolOpt('vnc_console',
538 default=False,
539 help='Enable VNC console. This configuration value should '
zhufldc7eeb42018-09-12 11:10:16 +0800540 'be same as nova.conf: vnc.enabled'),
Ghanshyam70876d02014-03-11 11:40:18 +0900541 cfg.BoolOpt('spice_console',
542 default=False,
Michael Stillfbbf01b2025-02-12 18:05:57 +1100543 help='Enable SPICE console. This configuration value should '
544 'be same as nova.conf: spice.enabled'),
Markus Zoeller69d58b82017-02-17 10:09:22 +0100545 cfg.BoolOpt('serial_console',
546 default=False,
547 help='Enable serial console. This configuration value '
zhufldc7eeb42018-09-12 11:10:16 +0800548 'should be the same as '
549 'nova.conf: serial_console.enabled'),
Adam Gandelman2e37b4f2014-06-18 17:34:21 -0700550 cfg.BoolOpt('rescue',
551 default=True,
552 help='Does the test environment support instance rescue '
Ghanshyam9c2e50d2014-07-22 21:32:05 +0900553 'mode?'),
Lee Yarwoodc0ad55c2019-12-06 13:39:19 +0000554 cfg.BoolOpt('stable_rescue',
555 default=False,
556 help='Does the test environment support stable device '
557 'instance rescue mode?'),
Ghanshyam9c2e50d2014-07-22 21:32:05 +0900558 cfg.BoolOpt('enable_instance_password',
559 default=True,
560 help='Enables returning of the instance password by the '
561 'relevant server API calls such as create, rebuild '
zhufle8a703b2016-09-09 15:23:03 +0800562 'or rescue. This configuration value should be same as '
563 'nova.conf: DEFAULT.enable_instance_password'),
Adam Gandelman7186f7a2014-07-23 09:28:56 -0400564 cfg.BoolOpt('interface_attach',
565 default=True,
566 help='Does the test environment support dynamic network '
Adam Gandelmanfbc95ac2014-06-19 17:33:43 -0700567 'interface attachment?'),
568 cfg.BoolOpt('snapshot',
569 default=True,
570 help='Does the test environment support creating snapshot '
Matthew Treinishdfd7ac02015-02-09 17:47:31 -0500571 'images of running instances?'),
Takeaki Matsumotod7e04b22015-09-04 15:13:38 +0900572 cfg.BoolOpt('personality',
Matt Riedemann0baba702016-07-03 19:24:08 -0400573 default=False,
Takeaki Matsumotod7e04b22015-09-04 15:13:38 +0900574 help='Does the test environment support server personality'),
Matt Riedemann79b3b492015-06-20 14:20:44 -0700575 cfg.BoolOpt('attach_encrypted_volume',
576 default=True,
577 help='Does the test environment support attaching an '
578 'encrypted volume to a running server instance? This may '
579 'depend on the combination of compute_driver in nova and '
580 'the volume_driver(s) in cinder.'),
Alexander Gubanov509e2842015-06-09 15:29:51 +0300581 cfg.BoolOpt('config_drive',
582 default=True,
583 help='Enable special configuration drive with metadata.'),
Artom Lifshitz595ae162018-05-23 10:19:18 -0400584 cfg.ListOpt('scheduler_enabled_filters',
Stephen Finucane88a49e82020-08-26 11:34:58 +0100585 default=[
586 "ComputeFilter",
587 "ComputeCapabilitiesFilter",
588 "ImagePropertiesFilter",
589 "ServerGroupAntiAffinityFilter",
590 "ServerGroupAffinityFilter",
591 ],
Artom Lifshitz595ae162018-05-23 10:19:18 -0400592 help="A list of enabled filters that Nova will accept as "
593 "hints to the scheduler when creating a server. If the "
ghanshyam5817e142016-12-01 11:38:46 +0900594 "default value is overridden in nova.conf by the test "
595 "environment (which means that a different set of "
596 "filters is enabled than what is included in Nova by "
Artom Lifshitz595ae162018-05-23 10:19:18 -0400597 "default), then this option must be configured to "
ghanshyam5817e142016-12-01 11:38:46 +0900598 "contain the same filters that Nova uses in the test "
Artom Lifshitz595ae162018-05-23 10:19:18 -0400599 "environment. A special entry 'all' indicates all "
600 "filters that are included with Nova are enabled. If "
601 "using 'all', be sure to enable all filters in "
602 "nova.conf, as tests can fail in unpredictable ways if "
603 "Nova's and Tempest's enabled filters don't match. "
604 "Empty list indicates all filters are disabled. The "
605 "full list of enabled filters is in nova.conf: "
606 "filter_scheduler.enabled_filters.",
607 deprecated_opts=[cfg.DeprecatedOpt(
608 'scheduler_available_filters',
609 group='compute-feature-enabled')]),
Matt Riedemann342b37c2016-09-21 15:38:12 -0400610 cfg.BoolOpt('swap_volume',
611 default=False,
612 help='Does the test environment support in-place swapping of '
613 'volumes attached to a server instance?'),
melanie witt334f3132017-12-14 21:49:55 +0000614 cfg.BoolOpt('volume_backed_live_migration',
615 default=False,
616 help='Does the test environment support volume-backed live '
617 'migration?'),
Matt Riedemann81fa9b62016-01-14 13:04:38 -0800618 cfg.BoolOpt('volume_multiattach',
619 default=False,
620 help='Does the test environment support attaching a volume to '
621 'more than one instance? This depends on hypervisor and '
622 'volume backend/type and compute API version 2.60.'),
Lee Yarwood56a446d2021-02-15 13:34:35 +0000623 cfg.BoolOpt('ide_bus',
624 default=True,
625 help='Does the test environment support attaching devices '
626 'using an IDE bus to the instance?'),
melanie witt74fa5052021-05-06 22:41:30 +0000627 cfg.BoolOpt('unified_limits',
628 default=False,
629 help='Does the test environment support unified limits?'),
Ghanshyam Mannd60609f2025-06-24 19:54:27 -0700630 cfg.ListOpt('nova_policy_roles',
631 default=['admin', 'member', 'reader'],
632 help='Compute service API policies roles list. List all the '
633 'roles which are used as default in Nova policy rules. '
634 'This config option value is used to run the tests with '
635 'the available roles in Nova. For example, if manager '
636 'role is not present in the nova release then tempest '
637 'will use old defaults role token to call nova APIs'),
Matthew Treinishd5c96022013-10-17 21:51:23 +0000638]
639
640
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500641image_group = cfg.OptGroup(name='image',
642 title="Image Service Options")
Jay Pipesf38eaac2012-06-21 13:37:35 -0400643
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500644ImageGroup = [
Matthew Treinish72ea4422013-02-07 14:42:49 -0500645 cfg.StrOpt('catalog_type',
646 default='image',
Sean Dague83401992013-05-06 17:46:36 -0400647 help='Catalog type of the Image service.'),
Arata Notsu8f440392013-09-13 16:14:20 +0900648 cfg.StrOpt('region',
649 default='',
650 help="The image region name to use. If empty, the value "
651 "of identity.region is used instead. If no such region "
652 "is found in the service catalog, the first found one is "
653 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000654 cfg.StrOpt('endpoint_type',
655 default='publicURL',
656 choices=['public', 'admin', 'internal',
657 'publicURL', 'adminURL', 'internalURL'],
658 help="The endpoint type to use for the image service."),
Dan Smithd4bc9a82021-01-12 17:25:07 -0800659 cfg.StrOpt('alternate_image_endpoint',
660 default=None,
661 help="Alternate endpoint name for cross-worker testing"),
662 cfg.StrOpt('alternate_image_endpoint_type',
663 default='publicURL',
664 choices=['public', 'admin', 'internal',
665 'publicURL', 'adminURL', 'internalURL'],
666 help=("The endpoint type to use for the alternate image "
667 "service.")),
Abhishek Kekane0188f462022-01-18 06:47:28 +0000668 cfg.BoolOpt('image_caching_enabled',
669 default=False,
670 help=("Flag to enable if caching is enabled by image "
Takashi Kajinamic87c6a12024-05-05 01:19:09 +0900671 "service, operator should set this parameter to True "
Abhishek Kekane0188f462022-01-18 06:47:28 +0000672 "if 'image_cache_dir' is set in glance-api.conf")),
Sean Dague83401992013-05-06 17:46:36 -0400673 cfg.StrOpt('http_image',
Abhishek Kekane9eea03c2024-07-04 06:38:42 +0000674 default='http://download.cirros-cloud.net/0.6.2/'
675 'cirros-0.6.2-x86_64-uec.tar.gz',
Lucian Petrut1cfe2982015-01-06 13:57:36 +0200676 help='http accessible image'),
Abhishek Kekane9aa41442024-07-03 06:59:59 +0000677 cfg.StrOpt('http_qcow2_image',
678 default='http://download.cirros-cloud.net/0.6.2/'
679 'cirros-0.6.2-x86_64-disk.img',
680 help='http qcow2 accessible image which will be used '
681 'for image conversion if enabled.'),
Lucian Petrut1cfe2982015-01-06 13:57:36 +0200682 cfg.IntOpt('build_timeout',
683 default=300,
684 help="Timeout in seconds to wait for an image to "
685 "become available."),
686 cfg.IntOpt('build_interval',
687 default=1,
688 help="Time in seconds between image operation status "
Takashi NATSUME12a48512015-08-10 18:33:16 +0900689 "checks."),
690 cfg.ListOpt('container_formats',
Luigi Toscanob73ead02024-07-17 01:00:09 +0200691 default=['bare', 'ami', 'ari', 'aki', 'ovf', 'ova'],
Takashi NATSUME12a48512015-08-10 18:33:16 +0900692 help="A list of image's container formats "
693 "users can specify."),
694 cfg.ListOpt('disk_formats',
Luigi Toscanob73ead02024-07-17 01:00:09 +0200695 default=['qcow2', 'raw', 'ami', 'ari', 'aki', 'vhd', 'vmdk',
Benny Kopilov97c74192017-03-30 09:34:59 +0300696 'vdi', 'iso', 'vhdx'],
Takashi NATSUME12a48512015-08-10 18:33:16 +0900697 help="A list of image's disk formats "
Dan Smith97ef2862024-07-31 12:33:46 -0700698 "users can specify."),
Abhishek Kekane102d7622025-06-02 18:54:48 +0000699 cfg.StrOpt('hashing_algorithm',
700 default='sha512',
701 help=('Hashing algorithm used by glance to calculate image '
702 'hashes. This configuration value should be same as '
703 'glance-api.conf: hashing_algorithm config option.')),
Dan Smith97ef2862024-07-31 12:33:46 -0700704 cfg.StrOpt('images_manifest_file',
705 default=None,
706 help="A path to a manifest.yml generated using the "
707 "os-test-images project"),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500708]
Jay Pipesf38eaac2012-06-21 13:37:35 -0400709
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000710image_feature_group = cfg.OptGroup(name='image-feature-enabled',
711 title='Enabled image service features')
712
713ImageFeaturesGroup = [
714 cfg.BoolOpt('api_v2',
715 default=True,
ghanshyam6b0b8b72017-03-08 04:22:53 +0000716 help="Is the v2 image API enabled",
717 deprecated_for_removal=True,
718 deprecated_reason='Glance v1 APIs are deprecated and v2 APIs '
719 'are current one. In future, Tempest will '
720 'test v2 APIs only so this config option '
721 'will be removed.'),
Abhishek Kekane7cff1302020-07-16 10:30:13 +0000722 cfg.BoolOpt('import_image',
Takashi Kajinami85129462024-04-13 00:13:55 +0900723 default=True,
724 help="Is image import feature enabled",
725 deprecated_for_removal=True,
726 deprecated_reason='Issue with image import in WSGI mode was '
727 'fixed in Victoria, and this feature works '
728 'in any deployment architecture now.'),
Dan Smithe044dad2021-01-15 12:45:16 -0800729 cfg.BoolOpt('os_glance_reserved',
Takashi Kajinami9fcc4a32024-01-24 10:55:20 +0900730 default=True,
731 help="Should we check that os_glance namespace is reserved",
732 deprecated_for_removal=True,
733 deprecated_reason='os_glance namespace is always reserved '
734 'since Wallaby'),
Dan Smith9eaaa5a2022-10-07 09:16:20 -0700735 cfg.BoolOpt('manage_locations',
736 default=False,
737 help=('Is show_multiple_locations enabled in glance. '
738 'Note that at least one http store must be enabled as '
739 'well, because we use that location scheme to test.')),
Dan Smithe8efa4f2024-08-01 06:59:50 -0700740 cfg.BoolOpt('image_conversion',
741 default=False,
742 help=('Is image_conversion enabled in glance.')),
Dan Smith2ba7ed82024-10-01 07:33:09 -0700743 cfg.BoolOpt('image_format_enforcement',
744 default=True,
745 help=('Indicates that image format is enforced by glance, '
746 'such that we should not expect to be able to upload '
747 'bad images for testing other services.')),
Abhishek Kekane102d7622025-06-02 18:54:48 +0000748 cfg.BoolOpt('do_secure_hash',
749 default=True,
750 help=('Is do_secure_hash enabled in glance. '
751 'This configuration value should be same as '
752 'glance-api.conf: do_secure_hash config option.')),
753 cfg.BoolOpt('http_store_enabled',
754 default=False,
755 help=('Is http store is enabled in glance. '
756 'http store needs to be mentioned either in '
757 'glance-api.conf: stores or in enabled_backends '
758 'configuration option.')),
Matthew Treinish2b5287d2013-10-22 17:40:34 +0000759]
Jay Pipesf38eaac2012-06-21 13:37:35 -0400760
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500761network_group = cfg.OptGroup(name='network',
762 title='Network Service Options')
Daryl Walleck587385b2012-03-03 13:00:26 -0600763
Noam Angel3c6b0162018-07-08 17:05:35 +0300764ProfileType = types.Dict(types.List(types.String(), bounds=True))
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500765NetworkGroup = [
766 cfg.StrOpt('catalog_type',
767 default='network',
Mark McClainf2982e82013-07-06 17:48:03 -0400768 help='Catalog type of the Neutron service.'),
Arata Notsu8f440392013-09-13 16:14:20 +0900769 cfg.StrOpt('region',
770 default='',
771 help="The network region name to use. If empty, the value "
772 "of identity.region is used instead. If no such region "
773 "is found in the service catalog, the first found one is "
774 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +0000775 cfg.StrOpt('endpoint_type',
776 default='publicURL',
777 choices=['public', 'admin', 'internal',
778 'publicURL', 'adminURL', 'internalURL'],
779 help="The endpoint type to use for the network service."),
Sean Dagueed6e5862016-04-04 10:49:13 -0400780 cfg.StrOpt('project_network_cidr',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500781 default="10.100.0.0/16",
Sean Dagueed6e5862016-04-04 10:49:13 -0400782 help="The cidr block to allocate project ipv4 subnets from"),
783 cfg.IntOpt('project_network_mask_bits',
Attila Fazekas8ea181b2013-07-13 16:26:14 +0200784 default=28,
Sean Dagueed6e5862016-04-04 10:49:13 -0400785 help="The mask bits for project ipv4 subnets"),
786 cfg.StrOpt('project_network_v6_cidr',
Brian Haley56893552019-09-19 17:50:37 -0400787 default="2001:db8::/48",
Sean Dagueed6e5862016-04-04 10:49:13 -0400788 help="The cidr block to allocate project ipv6 subnets from"),
789 cfg.IntOpt('project_network_v6_mask_bits',
Sergey Shnaidman1f3659a2014-08-27 18:26:42 +0400790 default=64,
Sean Dagueed6e5862016-04-04 10:49:13 -0400791 help="The mask bits for project ipv6 subnets"),
792 cfg.BoolOpt('project_networks_reachable',
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500793 default=False,
Sean Dagueed6e5862016-04-04 10:49:13 -0400794 help="Whether project networks can be reached directly from "
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000795 "the test client. This must be set to True when the "
Matt Riedemann4b0f7e72016-08-08 15:29:26 -0400796 "'fixed' connect_method is selected."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500797 cfg.StrOpt('public_network_id',
798 default="",
799 help="Id of the public network that provides external "
800 "connectivity"),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000801 cfg.StrOpt('floating_network_name',
802 help="Default floating network name. Used to allocate floating "
803 "IPs when neutron is enabled."),
Lukas Piwowarski2385e042020-01-31 12:28:20 +0000804 cfg.StrOpt('subnet_id',
805 default="",
806 help="Subnet id of subnet which is used for allocation of "
807 "floating IPs. Specify when two or more subnets are "
808 "present in network."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500809 cfg.StrOpt('public_router_id',
810 default="",
811 help="Id of the public router that provides external "
Yair Fried1eb27f52014-11-10 15:24:19 +0200812 "connectivity. This should only be used when Neutron's "
813 "'allow_overlapping_ips' is set to 'False' in "
814 "neutron.conf. usually not needed past 'Grizzly' release"),
izikpensod9a01a62014-02-17 20:02:32 +0200815 cfg.IntOpt('build_timeout',
816 default=300,
817 help="Timeout in seconds to wait for network operation to "
818 "complete."),
819 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -0400820 default=1,
izikpensod9a01a62014-02-17 20:02:32 +0200821 help="Time in seconds between network operation status "
822 "checks."),
Itzik Brown2ca01cd2014-12-08 12:58:20 +0200823 cfg.StrOpt('port_vnic_type',
Tom Stappaerts27fd5cb2020-11-26 12:07:47 +0100824 choices=[None, 'normal', 'direct', 'macvtap', 'direct-physical',
825 'baremetal', 'virtio-forwarder'],
Moshe Levie2c2fb12017-08-31 15:18:58 +0300826 help="vnic_type to use when launching instances"
Itzik Brown2ca01cd2014-12-08 12:58:20 +0200827 " with pre-configured ports."
828 " Supported ports are:"
Tom Stappaerts27fd5cb2020-11-26 12:07:47 +0100829 " ['normal', 'direct', 'macvtap', 'direct-physical', "
830 "'baremetal', 'virtio-forwarder']"),
Noam Angel3c6b0162018-07-08 17:05:35 +0300831 cfg.Opt('port_profile',
832 type=ProfileType,
833 default={},
834 help="port profile to use when launching instances"
835 " with pre-configured ports."),
piyush11078648e35d52015-09-24 12:56:43 +0530836 cfg.ListOpt('default_network',
837 default=["1.0.0.0/16", "2.0.0.0/16"],
838 help="List of ip pools"
839 " for subnetpools creation"),
Thiago Paiva66cded22016-08-15 14:55:58 -0300840 cfg.BoolOpt('shared_physical_network',
841 default=False,
842 help="The environment does not support network separation "
843 "between tenants."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -0500844]
Jay Pipes3f981df2012-03-27 18:59:44 -0400845
Matthew Treinishe3d26142013-11-26 19:14:58 +0000846network_feature_group = cfg.OptGroup(name='network-feature-enabled',
847 title='Enabled network service features')
848
849NetworkFeaturesGroup = [
Matthew Treinishe2e33cf2014-03-03 19:28:41 +0000850 cfg.BoolOpt('ipv6',
851 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500852 help="Allow the execution of IPv6 tests."),
Matthew Treinishe3d26142013-11-26 19:14:58 +0000853 cfg.ListOpt('api_extensions',
854 default=['all'],
Alexander Gubanov36e1f9b2015-06-12 18:02:10 +0300855 help="A list of enabled network extensions with a special "
856 "entry all which indicates every extension is enabled. "
857 "Empty list indicates all extensions are disabled. "
Brian Haley3d701092020-11-23 14:03:25 -0500858 "To get the list of extensions run: "
859 "'openstack extension list --network'"),
elajkatf9bb8b82020-11-02 13:41:06 +0100860 cfg.ListOpt('available_features',
861 default=['all'],
862 help="A list of available network features with a special "
863 "entry all that indicates every feature is available. "
Brian Haley3d701092020-11-23 14:03:25 -0500864 "Empty list indicates all features are disabled. "
elajkatf9bb8b82020-11-02 13:41:06 +0100865 "This list can contain features that are not "
Brian Haley3d701092020-11-23 14:03:25 -0500866 "discoverable through the API."),
Sean M. Collinsdd27a4d2014-05-13 10:33:15 -0400867 cfg.BoolOpt('ipv6_subnet_attributes',
868 default=False,
869 help="Allow the execution of IPv6 subnet tests that use "
870 "the extended IPv6 attributes ipv6_ra_mode "
Brian Haley3d701092020-11-23 14:03:25 -0500871 "and ipv6_address_mode."
Mark McClain6e07c0d2014-10-10 11:25:03 -0400872 ),
Itzik Brownbeb30d32015-03-29 09:42:54 +0300873 cfg.BoolOpt('port_admin_state_change',
874 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500875 help="Does the test environment support changing "
876 "port admin state?"),
Matt Riedemann039b2fe2016-09-15 16:12:24 -0400877 cfg.BoolOpt('port_security',
878 default=False,
879 help="Does the test environment support port security?"),
Matthew Treinish3312de32017-05-19 12:08:17 -0400880 cfg.BoolOpt('floating_ips',
881 default=True,
Brian Haley3d701092020-11-23 14:03:25 -0500882 help='Does the test environment support floating_ips?'),
Lajos Katonac87a06b2019-01-04 13:21:48 +0100883 cfg.StrOpt('qos_placement_physnet', default=None,
884 help='Name of the physnet for placement based minimum '
885 'bandwidth allocation.'),
Takashi Kajinami7138e352022-02-03 09:16:34 +0900886 cfg.StrOpt('provider_net_base_segmentation_id', default='3000',
Lajos Katonac87a06b2019-01-04 13:21:48 +0100887 help='Base segmentation ID to create provider networks. '
Balazs Gibizerf294b0d2021-09-29 16:16:44 +0200888 'This value will be increased in case of conflict.'),
889 cfg.BoolOpt('qos_min_bw_and_pps', default=False,
890 help='Does the test environment have minimum bandwidth and '
891 'packet rate inventories configured?'),
Matthew Treinishe3d26142013-11-26 19:14:58 +0000892]
893
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -0600894dashboard_group = cfg.OptGroup(name="dashboard",
895 title="Dashboard options")
896
897DashboardGroup = [
Takashi Kajinami0ed15dc2024-01-24 11:09:53 +0900898 cfg.URIOpt('dashboard_url',
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -0600899 default='http://localhost/',
Takashi Kajinami0ed15dc2024-01-24 11:09:53 +0900900 schemes=['http', 'https'],
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -0600901 help="Where the dashboard can be found"),
902 cfg.BoolOpt('disable_ssl_certificate_validation',
903 default=False,
904 help="Set to True if using self-signed SSL certificates."),
905]
906
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000907validation_group = cfg.OptGroup(name='validation',
908 title='SSH Validation options')
909
910ValidationGroup = [
Matthew Treinishe5cca002015-05-11 15:36:50 -0400911 cfg.BoolOpt('run_validation',
Attila Fazekas489e90f2018-09-12 17:30:01 -0600912 default=True,
Matthew Treinishe5cca002015-05-11 15:36:50 -0400913 help='Enable ssh on created servers and creation of additional'
Attila Fazekas489e90f2018-09-12 17:30:01 -0600914 ' validation resources to enable remote access.'
915 ' In case the guest does not support ssh set it'
916 ' to false'),
Brandon Palmc6cc91d2015-08-19 13:20:21 -0500917 cfg.BoolOpt('security_group',
918 default=True,
919 help='Enable/disable security groups.'),
920 cfg.BoolOpt('security_group_rules',
921 default=True,
922 help='Enable/disable security group rules.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000923 cfg.StrOpt('connect_method',
924 default='floating',
Takashi Kajinamib9f775d2024-01-20 11:17:33 +0900925 choices=[('fixed',
926 'uses the first IP belonging to the fixed network'),
927 ('floating',
928 'creates and uses a floating IP')],
929 help='Default IP type used for validation'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000930 cfg.StrOpt('auth_method',
931 default='keypair',
932 choices=['keypair'],
933 help='Default authentication method to the instance. '
934 'Only ssh via keypair is supported for now. '
ghanshyamade71d22017-02-15 05:36:14 +0000935 'Additional methods will be handled in a separate spec.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000936 cfg.IntOpt('ip_version_for_ssh',
937 default=4,
lanoux283273b2015-12-04 03:01:54 -0800938 help='Default IP version for ssh connections.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000939 cfg.IntOpt('ping_timeout',
940 default=120,
ghanshyam244cf7c2017-02-15 06:39:31 +0000941 help='Timeout in seconds to wait for ping to succeed.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000942 cfg.IntOpt('connect_timeout',
943 default=60,
944 help='Timeout in seconds to wait for the TCP connection to be '
lanoux283273b2015-12-04 03:01:54 -0800945 'successful.'),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +0000946 cfg.IntOpt('ssh_timeout',
947 default=300,
lanoux283273b2015-12-04 03:01:54 -0800948 help='Timeout in seconds to wait for the ssh banner.'),
949 cfg.StrOpt('image_ssh_user',
950 default="root",
ghanshyam244cf7c2017-02-15 06:39:31 +0000951 help="User name used to authenticate to an instance."),
Weronika Sikorac54a9112019-09-18 13:55:07 +0000952 cfg.StrOpt('image_alt_ssh_user',
953 default="root",
954 help="User name used to authenticate to an alt instance."),
lanoux283273b2015-12-04 03:01:54 -0800955 cfg.StrOpt('image_ssh_password',
956 default="password",
Doug Schveninger6a2be432020-04-29 17:42:31 -0500957 help="Password used to authenticate to an instance.",
958 secret=True),
Weronika Sikorac54a9112019-09-18 13:55:07 +0000959 cfg.StrOpt('image_alt_ssh_password',
960 default="password",
961 help="Password used to authenticate to an alt instance.",
962 secret=True),
lanoux283273b2015-12-04 03:01:54 -0800963 cfg.StrOpt('ssh_shell_prologue',
Lucian Petrut6a7472a2019-08-07 12:43:08 +0300964 default="set -eu -o pipefail; PATH=$$PATH:/sbin:/usr/sbin;",
lanoux283273b2015-12-04 03:01:54 -0800965 help="Shell fragments to use before executing a command "
ghanshyamade71d22017-02-15 05:36:14 +0000966 "when sshing to a guest."),
lanoux283273b2015-12-04 03:01:54 -0800967 cfg.IntOpt('ping_size',
968 default=56,
969 help="The packet size for ping packets originating "
ghanshyamade71d22017-02-15 05:36:14 +0000970 "from remote linux hosts"),
lanoux283273b2015-12-04 03:01:54 -0800971 cfg.IntOpt('ping_count',
972 default=1,
973 help="The number of ping packets originating from remote "
ghanshyamade71d22017-02-15 05:36:14 +0000974 "linux hosts"),
lanoux283273b2015-12-04 03:01:54 -0800975 cfg.StrOpt('floating_ip_range',
976 default='10.0.0.0/29',
977 help='Unallocated floating IP range, which will be used to '
978 'test the floating IP bulk feature for CRUD operation. '
979 'This block must not overlap an existing floating IP '
ghanshyamade71d22017-02-15 05:36:14 +0000980 'pool.'),
lanoux283273b2015-12-04 03:01:54 -0800981 cfg.StrOpt('network_for_ssh',
982 default='public',
983 help="Network used for SSH connections. Ignored if "
ghanshyam244cf7c2017-02-15 06:39:31 +0000984 "connect_method=floating."),
Ade Lee6ded0702021-09-04 15:56:34 -0400985 cfg.StrOpt('ssh_key_type',
Martin Kopec75ca0b82022-04-20 17:57:45 +0200986 default='ecdsa',
Takashi Kajinamifb116382024-05-05 01:24:54 +0900987 choices=['ecdsa', 'rsa'],
988 help='Type of key to use for ssh connections.'),
Roman Safronovf2357852023-02-20 15:21:13 +0200989 cfg.FloatOpt('allowed_network_downtime',
990 default=5.0,
991 help="Allowed VM network connection downtime during live "
992 "migration, in seconds. "
993 "When the measured downtime exceeds this value, an "
994 "exception is raised."),
Eduardo Olivaresb530c1f2024-10-03 16:14:09 +0200995 cfg.FloatOpt('allowed_metadata_downtime',
996 default=6.0,
997 help="Allowed VM metadata connection downtime during live "
998 "migration, in seconds. "
999 "When the measured downtime exceeds this value, an "
1000 "exception is raised."),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001001]
1002
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001003volume_group = cfg.OptGroup(name='volume',
1004 title='Block Storage Options')
Daryl Walleck587385b2012-03-03 13:00:26 -06001005
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001006VolumeGroup = [
1007 cfg.IntOpt('build_interval',
Sean Dague82190852014-05-24 07:42:59 -04001008 default=1,
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001009 help='Time in seconds between volume availability checks.'),
1010 cfg.IntOpt('build_timeout',
1011 default=300,
Eric Harney9b1f89c2014-10-14 14:40:19 -04001012 help='Timeout in seconds to wait for a volume to become '
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001013 'available.'),
1014 cfg.StrOpt('catalog_type',
Stephen Finucane1a744c82024-09-24 13:08:46 +01001015 default='block-storage',
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001016 help="Catalog type of the Volume Service"),
Arata Notsu8f440392013-09-13 16:14:20 +09001017 cfg.StrOpt('region',
1018 default='',
1019 help="The volume region name to use. If empty, the value "
1020 "of identity.region is used instead. If no such region "
1021 "is found in the service catalog, the first found one is "
1022 "used."),
JordanP5d29b2c2013-12-18 13:56:03 +00001023 cfg.StrOpt('endpoint_type',
1024 default='publicURL',
1025 choices=['public', 'admin', 'internal',
1026 'publicURL', 'adminURL', 'internalURL'],
1027 help="The endpoint type to use for the volume service."),
Lukáš Piwowarski553d91b2023-09-21 11:14:24 +02001028 cfg.StrOpt('backup_driver',
1029 default='ceph',
1030 choices=['ceph', 'swift', 'nfs', 'glusterfs', 'posix', 'google',
1031 's3'],
1032 help="What kind of backup_driver does cinder use?"
1033 "https://docs.openstack.org/cinder/latest/configuration/"
1034 "block-storage/backup-drivers.html"),
Benny Kopilovaf136a92015-11-10 07:37:23 +02001035 cfg.ListOpt('backend_names',
1036 default=['BACKEND_1', 'BACKEND_2'],
april4be58dc2015-12-29 00:07:22 +08001037 help='A list of backend names separated by comma. '
bkopilov27905cc2016-04-12 14:29:13 +03001038 'The backend name must be declared in cinder.conf'),
Ansuman Bebarta46d540d2021-02-16 18:48:33 +05301039 cfg.StrOpt('volume_type',
1040 default='',
1041 help='Volume type to be used while creating volume.'),
whoami-rajatb04b1022023-02-27 09:41:22 +00001042 cfg.StrOpt('volume_type_multiattach',
1043 default='',
1044 help='Multiattach volume type used while creating multiattach '
1045 'volume.'),
Adam Gandelman827ad332013-06-24 17:04:09 -07001046 cfg.StrOpt('storage_protocol',
1047 default='iSCSI',
1048 help='Backend protocol to target when creating volume types'),
1049 cfg.StrOpt('vendor_name',
1050 default='Open Source',
1051 help='Backend vendor to target when creating volume types'),
Rajat Dhasmanafbd90e92025-01-07 22:53:12 +05301052 cfg.ListOpt('disk_format',
1053 default=['raw', 'qcow2'],
1054 help='Disk format to use when copying a volume to image'),
Jerry Cai9733d0e2014-03-19 15:50:49 +08001055 cfg.IntOpt('volume_size',
1056 default=1,
Takashi Kajinamia06cf362024-01-20 11:44:00 +09001057 min=1,
Jerry Cai9733d0e2014-03-19 15:50:49 +08001058 help='Default size in GB for volumes created by volumes tests'),
Martin Kopec37c4bd32021-06-24 15:46:00 +00001059 cfg.IntOpt('volume_size_extend',
1060 default=1,
Takashi Kajinamia06cf362024-01-20 11:44:00 +09001061 min=1,
Martin Kopec37c4bd32021-06-24 15:46:00 +00001062 help="Size in GB a volume is extended by - if a test "
1063 "extends a volume, the size of the new volume will be "
1064 "volume_size + volume_size_extend."),
jeremy.zhangf4fbf302017-03-22 11:25:53 +08001065 cfg.ListOpt('manage_volume_ref',
1066 default=['source-name', 'volume-%s'],
1067 help="A reference to existing volume for volume manage. "
1068 "It contains two elements, the first is ref type "
1069 "(like 'source-name', 'source-id', etc), the second is "
1070 "volume name template used in storage backend"),
jeremy.zhangebc752b2017-06-14 13:58:37 +08001071 cfg.ListOpt('manage_snapshot_ref',
1072 default=['source-name', '_snapshot-%s'],
1073 help="A reference to existing snapshot for snapshot manage. "
1074 "It contains two elements, the first is ref type "
1075 "(like 'source-name', 'source-id', etc), the second is "
1076 "snapshot name template used in storage backend"),
Andrew Kerrfcb0b682016-04-01 16:01:34 -04001077 cfg.StrOpt('min_microversion',
1078 default=None,
1079 help="Lower version of the test target microversion range. "
1080 "The format is 'X.Y', where 'X' and 'Y' are int values. "
1081 "Tempest selects tests based on the range between "
1082 "min_microversion and max_microversion. "
1083 "If both values are not specified, Tempest avoids tests "
1084 "which require a microversion. Valid values are string "
1085 "with format 'X.Y' or string 'latest'",),
1086 cfg.StrOpt('max_microversion',
1087 default=None,
1088 help="Upper version of the test target microversion range. "
1089 "The format is 'X.Y', where 'X' and 'Y' are int values. "
1090 "Tempest selects tests based on the range between "
1091 "min_microversion and max_microversion. "
1092 "If both values are not specified, Tempest avoids tests "
1093 "which require a microversion. Valid values are string "
1094 "with format 'X.Y' or string 'latest'",),
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001095]
K Jonathan Harkerd6ba4b42012-12-18 13:50:47 -08001096
Matthew Treinishd5c96022013-10-17 21:51:23 +00001097volume_feature_group = cfg.OptGroup(name='volume-feature-enabled',
1098 title='Enabled Cinder Features')
1099
1100VolumeFeaturesGroup = [
1101 cfg.BoolOpt('multi_backend',
1102 default=False,
Matthew Treinishe3d26142013-11-26 19:14:58 +00001103 help="Runs Cinder multi-backend test (requires 2 backends)"),
Giulio Fidente74b08ad2014-01-18 04:02:51 +01001104 cfg.BoolOpt('backup',
1105 default=True,
1106 help='Runs Cinder volumes backup test'),
JordanPbce55532014-03-19 12:10:32 +01001107 cfg.BoolOpt('snapshot',
1108 default=True,
1109 help='Runs Cinder volume snapshot test'),
Takeaki Matsumoto1702aed2015-08-25 08:44:26 +09001110 cfg.BoolOpt('clone',
1111 default=True,
1112 help='Runs Cinder volume clone test'),
Jordan Pittier31256252017-01-11 14:29:49 +01001113 cfg.BoolOpt('manage_snapshot',
1114 default=False,
1115 help='Runs Cinder manage snapshot tests'),
jeremy.zhangf4fbf302017-03-22 11:25:53 +08001116 cfg.BoolOpt('manage_volume',
1117 default=False,
1118 help='Runs Cinder manage volume tests'),
Matthew Treinishe3d26142013-11-26 19:14:58 +00001119 cfg.ListOpt('api_extensions',
1120 default=['all'],
Zhi Kun Liude25c022014-02-14 13:25:19 +08001121 help='A list of enabled volume extensions with a special '
Simeon Monov5d7effe2014-07-16 07:32:38 +03001122 'entry all which indicates every extension is enabled. '
1123 'Empty list indicates all extensions are disabled'),
Matt Riedemann0cc76bf2017-07-05 17:29:31 -04001124 cfg.BoolOpt('extend_attached_volume',
1125 default=False,
1126 help='Does the cloud support extending the size of a volume '
1127 'which is currently attached to a server instance? This '
1128 'depends on the 3.42 volume API microversion and the '
1129 '2.51 compute API microversion. Also, not all volume or '
Lee Yarwood4bd9edb2020-01-31 17:26:25 +00001130 'compute backends support this operation.'),
1131 cfg.BoolOpt('extend_attached_encrypted_volume',
1132 default=False,
1133 help='Does the cloud support extending the size of an '
1134 'encrypted volume which is currently attached to a '
1135 'server instance? This depends on the 3.42 volume API '
1136 'microversion and the 2.51 compute API microversion. '
1137 'Also, not all volume or compute backends support this '
Jake Yip2ba26af2023-05-05 20:37:10 +10001138 'operation.'),
1139 cfg.BoolOpt('extend_volume_with_snapshot',
1140 default=True,
1141 help='Does the cloud support extending the size of a volume '
1142 'which has snapshot? Some drivers do not support this '
jskundad7445982023-10-18 13:49:02 +02001143 'operation.'),
1144 cfg.StrOpt('volume_types_for_data_volume',
1145 default=None,
1146 help='Volume types used for data volumes. Multiple volume '
1147 'types can be assigned.'),
Maxim Sava4bd81f82024-06-25 11:17:16 +03001148 cfg.BoolOpt('enable_volume_image_dep_tests',
Maxim Savacd0f4bc2024-11-03 09:17:38 +02001149 deprecated_name='volume_image_dep_tests',
Maxim Sava1be8cab2024-03-26 14:23:22 +02001150 default=True,
Christian Berendt045252f2024-12-17 11:52:26 +01001151 help='Run tests for dependencies between images, volumes '
Maxim Sava1be8cab2024-03-26 14:23:22 +02001152 'and instance snapshots')
Matthew Treinishd5c96022013-10-17 21:51:23 +00001153]
1154
Daryl Walleck587385b2012-03-03 13:00:26 -06001155
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001156object_storage_group = cfg.OptGroup(name='object-storage',
1157 title='Object Storage Service Options')
Attila Fazekasa23f5002012-10-23 19:32:45 +02001158
DennyZhang1e71b612013-09-26 12:35:40 -05001159ObjectStoreGroup = [
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001160 cfg.StrOpt('catalog_type',
1161 default='object-store',
1162 help="Catalog type of the Object-Storage service."),
Arata Notsu8f440392013-09-13 16:14:20 +09001163 cfg.StrOpt('region',
1164 default='',
1165 help="The object-storage region name to use. If empty, the "
1166 "value of identity.region is used instead. If no such "
1167 "region is found in the service catalog, the first found "
1168 "one is used."),
JordanP5d29b2c2013-12-18 13:56:03 +00001169 cfg.StrOpt('endpoint_type',
1170 default='publicURL',
1171 choices=['public', 'admin', 'internal',
1172 'publicURL', 'adminURL', 'internalURL'],
1173 help="The endpoint type to use for the object-store service."),
Matthew Treinishf319a732013-10-24 21:39:24 +00001174 cfg.IntOpt('container_sync_timeout',
Daisuke Morita1ac3ee02014-08-25 12:59:18 +09001175 default=600,
Fabien Boucher2178d312013-12-31 15:38:57 +01001176 help="Number of seconds to time on waiting for a container "
nayna-patelb4989b32013-01-09 06:25:13 +00001177 "to container synchronization complete."),
Matthew Treinishf319a732013-10-24 21:39:24 +00001178 cfg.IntOpt('container_sync_interval',
nayna-patelb4989b32013-01-09 06:25:13 +00001179 default=5,
Fabien Boucher2178d312013-12-31 15:38:57 +01001180 help="Number of seconds to wait while looping to check the "
nayna-patelb4989b32013-01-09 06:25:13 +00001181 "status of a container to container synchronization"),
Matthew Treinish3fdb80c2013-08-15 11:13:19 -04001182 cfg.StrOpt('operator_role',
Martin Kopec99d4dae2020-05-27 10:33:17 +00001183 default='member',
Matthew Treinish3fdb80c2013-08-15 11:13:19 -04001184 help="Role to add to users created for swift tests to "
1185 "enable creating containers"),
Matthew Treinish998c91d2014-03-01 12:39:49 -05001186 cfg.StrOpt('reseller_admin_role',
1187 default='ResellerAdmin',
1188 help="User role that has reseller admin"),
Daisuke Morita1ac3ee02014-08-25 12:59:18 +09001189 cfg.StrOpt('realm_name',
1190 default='realm1',
1191 help="Name of sync realm. A sync realm is a set of clusters "
1192 "that have agreed to allow container syncing with each "
1193 "other. Set the same realm name as Swift's "
1194 "container-sync-realms.conf"),
1195 cfg.StrOpt('cluster_name',
1196 default='name1',
1197 help="One name of cluster which is set in the realm whose name "
1198 "is set in 'realm_name' item in this file. Set the "
1199 "same cluster name as Swift's container-sync-realms.conf"),
Bas de Bruijnec9f9a032022-07-19 11:16:02 -03001200 cfg.IntOpt('build_timeout',
1201 default=10,
1202 help="Timeout in seconds to wait for objects to create."),
Matthew Treinish39e48ef2012-12-21 13:36:15 -05001203]
Attila Fazekasa23f5002012-10-23 19:32:45 +02001204
Matthew Treinishd5c96022013-10-17 21:51:23 +00001205object_storage_feature_group = cfg.OptGroup(
1206 name='object-storage-feature-enabled',
1207 title='Enabled object-storage features')
1208
1209ObjectStoreFeaturesGroup = [
Matthew Treinish20345382013-12-13 17:04:23 +00001210 cfg.ListOpt('discoverable_apis',
1211 default=['all'],
1212 help="A list of the enabled optional discoverable apis. "
1213 "A single entry, all, indicates that all of these "
1214 "features are expected to be enabled"),
Daisuke Morita20a183f2014-08-25 14:43:36 +09001215 cfg.BoolOpt('container_sync',
1216 default=True,
1217 help="Execute (old style) container-sync tests"),
1218 cfg.BoolOpt('object_versioning',
1219 default=True,
1220 help="Execute object-versioning tests"),
1221 cfg.BoolOpt('discoverability',
1222 default=True,
1223 help="Execute discoverability tests"),
Giulio Fidente95758b12022-07-14 15:14:24 +02001224 cfg.StrOpt('tempurl_digest_hashlib',
1225 default='sha256',
1226 help="Hashing algorithm to use for the temp_url tests. "
1227 "Needs to be supported both by Swift and the "
1228 "hashlib module, for example sha1 or sha256"),
Matthew Treinishd5c96022013-10-17 21:51:23 +00001229]
1230
Luigi Toscano14d172d2015-01-23 16:37:47 +01001231
Masayuki Igawa73d9f3a2013-05-24 10:30:01 +09001232scenario_group = cfg.OptGroup(name='scenario', title='Scenario Test Options')
1233
1234ScenarioGroup = [
Alessandro Pilottib7c1daa2014-08-16 14:24:13 +03001235 cfg.StrOpt('img_file', deprecated_name='qcow2_img_file',
Martin Kopec02af6a42020-03-03 12:39:12 +00001236 default='/opt/stack/new/devstack/files/images'
1237 '/cirros-0.3.1-x86_64-disk.img',
1238 help='Image full path.'),
Alessandro Pilottib7c1daa2014-08-16 14:24:13 +03001239 cfg.StrOpt('img_disk_format',
1240 default='qcow2',
1241 help='Image disk format'),
1242 cfg.StrOpt('img_container_format',
1243 default='bare',
1244 help='Image container format'),
Evgeny Antyshev7ba0d5f2015-04-28 13:18:07 +00001245 cfg.DictOpt('img_properties', help='Glance image properties. '
1246 'Use for custom images which require them'),
Yair Fried413bf2d2014-11-19 17:07:11 +02001247 cfg.StrOpt('dhcp_client',
1248 default='udhcpc',
Slawek Kaplonski49163f92023-01-20 12:20:35 +01001249 choices=["udhcpc", "dhclient", "dhcpcd", ""],
Rajesh Tailora85bdb42024-04-02 12:01:53 +05301250 help='DHCP client used by images to renew DHCP lease. '
Yair Fried413bf2d2014-11-19 17:07:11 +02001251 'If left empty, update operation will be skipped. '
Slawek Kaplonski49163f92023-01-20 12:20:35 +01001252 'Supported clients: "udhcpc", "dhclient", "dhcpcd"'),
Claudiu Belu33c3e602014-08-28 16:38:01 +03001253 cfg.StrOpt('protocol',
1254 default='icmp',
1255 choices=('icmp', 'tcp', 'udp'),
1256 help='The protocol used in security groups tests to check '
Martin Kopec9086dca2024-03-20 13:18:57 +01001257 'connectivity.'),
1258 cfg.StrOpt('target_dir',
1259 default='/tmp',
1260 help='Directory in which to write the timestamp file.'),
Masayuki Igawa73d9f3a2013-05-24 10:30:01 +09001261]
1262
1263
Matthew Treinish4c412922013-07-16 15:27:42 -04001264service_available_group = cfg.OptGroup(name="service_available",
1265 title="Available OpenStack Services")
1266
1267ServiceAvailableGroup = [
1268 cfg.BoolOpt('cinder',
1269 default=True,
1270 help="Whether or not cinder is expected to be available"),
Matthew Treinishfaa340d2013-07-19 16:26:21 -04001271 cfg.BoolOpt('neutron',
Takashi Kajinamia4f57d32024-05-05 01:00:52 +09001272 default=True,
Matthew Treinishfaa340d2013-07-19 16:26:21 -04001273 help="Whether or not neutron is expected to be available"),
Matthew Treinish853ae442013-07-19 16:36:07 -04001274 cfg.BoolOpt('glance',
1275 default=True,
1276 help="Whether or not glance is expected to be available"),
Matthew Treinish61e332b2013-07-19 16:42:31 -04001277 cfg.BoolOpt('swift',
1278 default=True,
1279 help="Whether or not swift is expected to be available"),
Matthew Treinish6b41e242013-07-19 16:49:28 -04001280 cfg.BoolOpt('nova',
1281 default=True,
1282 help="Whether or not nova is expected to be available"),
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001283 cfg.BoolOpt('horizon',
1284 default=True,
1285 help="Whether or not horizon is expected to be available"),
Matthew Treinish4c412922013-07-16 15:27:42 -04001286]
1287
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001288enforce_scope_group = cfg.OptGroup(name="enforce_scope",
1289 title="OpenStack Services with "
1290 "enforce scope")
1291
1292
1293EnforceScopeGroup = [
1294 cfg.BoolOpt('nova',
1295 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001296 help='Does the compute service API policies enforce scope and '
1297 'new defaults? This configuration value should be '
1298 'enabled when nova.conf: [oslo_policy]. '
1299 'enforce_new_defaults and nova.conf: [oslo_policy]. '
1300 'enforce_scope options are enabled in nova conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001301 cfg.BoolOpt('neutron',
1302 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001303 help='Does the network service API policies enforce scope and '
1304 'new defaults? This configuration value should be '
1305 'enabled when neutron.conf: [oslo_policy]. '
1306 'enforce_new_defaults and neutron.conf: [oslo_policy]. '
1307 'enforce_scope options are enabled in neutron conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001308 cfg.BoolOpt('glance',
1309 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001310 help='Does the Image service API policies enforce scope and '
1311 'new defaults? This configuration value should be '
1312 'enabled when glance.conf: [oslo_policy]. '
1313 'enforce_new_defaults and glance.conf: [oslo_policy]. '
1314 'enforce_scope options are enabled in glance conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001315 cfg.BoolOpt('cinder',
1316 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001317 help='Does the Volume service API policies enforce scope and '
1318 'new defaults? This configuration value should be '
1319 'enabled when cinder.conf: [oslo_policy]. '
1320 'enforce_new_defaults and cinder.conf: [oslo_policy]. '
1321 'enforce_scope options are enabled in cinder conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001322 cfg.BoolOpt('keystone',
1323 default=False,
Ghanshyam Mann0fe96632022-10-15 20:18:58 -05001324 help='Does the Identity service API policies enforce scope '
1325 'and new defaults? This configuration value should be '
1326 'enabled when keystone.conf: [oslo_policy]. '
1327 'enforce_new_defaults and keystone.conf: [oslo_policy]. '
1328 'enforce_scope options are enabled in keystone conf.'),
Ghanshyam Mannb6521a82022-11-30 14:31:30 -06001329 cfg.BoolOpt('placement',
1330 default=False,
1331 help='Does the placement service API policies enforce scope '
1332 'and new defaults? This configuration value should be '
1333 'enabled when placement.conf: [oslo_policy]. '
1334 'enforce_new_defaults and nova.conf: [oslo_policy]. '
1335 'enforce_scope options are enabled in placement conf.'),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001336]
1337
Attila Fazekasaeeeefd2013-08-06 17:01:56 +02001338debug_group = cfg.OptGroup(name="debug",
1339 title="Debug System")
1340
1341DebugGroup = [
Sean Daguec522c092014-03-24 10:43:22 -04001342 cfg.StrOpt('trace_requests',
1343 default='',
1344 help="""A regex to determine which requests should be traced.
1345
1346This is a regex to match the caller for rest client requests to be able to
1347selectively trace calls out of specific classes and methods. It largely
1348exists for test development, and is not expected to be used in a real deploy
1349of tempest. This will be matched against the discovered ClassName:method
1350in the test environment.
1351
1352Expected values for this field are:
1353
1354 * ClassName:test_method_name - traces one test_method
1355 * ClassName:setUp(Class) - traces specific setup functions
1356 * ClassName:tearDown(Class) - traces specific teardown functions
1357 * ClassName:_run_cleanups - traces the cleanup functions
1358
1359If nothing is specified, this feature is not enabled. To trace everything
1360specify .* as the regex.
1361""")
Attila Fazekasaeeeefd2013-08-06 17:01:56 +02001362]
1363
Ilya Shakhat1291bb42017-11-29 18:08:16 +01001364
1365profiler_group = cfg.OptGroup(name="profiler",
1366 title="OpenStack Profiler")
1367
1368ProfilerGroup = [
1369 cfg.StrOpt('key',
1370 help="The secret key to enable OpenStack Profiler. The value "
1371 "should match the one configured in OpenStack services "
1372 "under `[profiler]/hmac_keys` property. The default empty "
1373 "value keeps profiling disabled"),
1374]
1375
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001376DefaultGroup = [
Martin Kopecae155b72017-06-26 09:41:21 +00001377 cfg.BoolOpt('pause_teardown',
1378 default=False,
1379 help="""Whether to pause a test in global teardown.
1380
1381The best use case is investigating used resources of one test.
1382A test can be run as follows:
Michael Johnsonafe134a2024-11-06 00:05:58 +00001383$ stestr run --pdb TEST_ID
Martin Kopecae155b72017-06-26 09:41:21 +00001384or
Michael Johnsonafe134a2024-11-06 00:05:58 +00001385$ python -m testtools.run TEST_ID"""),
Luigi Dino Tamagnone17053d62023-10-03 14:05:25 +00001386 cfg.StrOpt('resource_name_prefix',
1387 default='tempest',
1388 help="Define the prefix name for the resources created by "
1389 "tempest. Tempest cleanup CLI will use this config option "
1390 "to cleanup only the resources that match the prefix. "
1391 "Make sure this prefix does not match with the resource "
1392 "name you do not want Tempest cleanup CLI to delete."),
Katarina Strenkovaf999b152023-10-10 15:16:15 +00001393 cfg.BoolOpt('record_resources',
1394 default=False,
1395 help="Allows to record all resources created by Tempest. "
1396 "These resources are stored in file resource_list.json, "
1397 "which can be later used for resource deletion by "
1398 "command tempest cleanup. The resource_list.json file "
1399 "will be appended in case of multiple Tempest runs, "
1400 "so the file will contain a list of resources created "
1401 "during all Tempest runs."),
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001402]
1403
Jon Grimm270bd7f2014-08-05 18:11:29 +00001404_opts = [
1405 (auth_group, AuthGroup),
1406 (compute_group, ComputeGroup),
1407 (compute_features_group, ComputeFeaturesGroup),
1408 (identity_group, IdentityGroup),
zhufl071e94c2016-07-12 10:26:34 +08001409 (service_clients_group, ServiceClientsGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001410 (identity_feature_group, IdentityFeatureGroup),
1411 (image_group, ImageGroup),
1412 (image_feature_group, ImageFeaturesGroup),
1413 (network_group, NetworkGroup),
1414 (network_feature_group, NetworkFeaturesGroup),
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001415 (dashboard_group, DashboardGroup),
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001416 (validation_group, ValidationGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001417 (volume_group, VolumeGroup),
1418 (volume_feature_group, VolumeFeaturesGroup),
1419 (object_storage_group, ObjectStoreGroup),
1420 (object_storage_feature_group, ObjectStoreFeaturesGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001421 (scenario_group, ScenarioGroup),
1422 (service_available_group, ServiceAvailableGroup),
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001423 (enforce_scope_group, EnforceScopeGroup),
Jon Grimm270bd7f2014-08-05 18:11:29 +00001424 (debug_group, DebugGroup),
Lajos Katonaceb88212018-11-30 14:54:12 +01001425 (placement_group, PlacementGroup),
Ilya Shakhat1291bb42017-11-29 18:08:16 +01001426 (profiler_group, ProfilerGroup),
Andrea Frittoli (andreaf)8def7ca2015-05-13 14:24:19 +01001427 (None, DefaultGroup)
Jon Grimm270bd7f2014-08-05 18:11:29 +00001428]
1429
Roman Prykhodchenko62b1ed12013-10-16 21:51:47 +03001430
Matthew Treinish43b296a2014-02-28 15:23:00 -05001431def register_opts():
Matthew Treinisha966d0f2015-07-01 17:37:31 -04001432 ext_plugins = plugins.TempestTestPluginManager()
1433 # Register in-tree tempest config options
Jon Grimm270bd7f2014-08-05 18:11:29 +00001434 for g, o in _opts:
Maru Newbyf440c292015-03-31 15:58:47 +00001435 register_opt_group(_CONF, g, o)
Matthew Treinisha966d0f2015-07-01 17:37:31 -04001436 # Call external plugin config option registration
1437 ext_plugins.register_plugin_opts(_CONF)
Jon Grimm270bd7f2014-08-05 18:11:29 +00001438
1439
1440def list_opts():
1441 """Return a list of oslo.config options available.
1442
1443 The purpose of this is to allow tools like the Oslo sample config file
1444 generator to discover the options exposed to users.
1445 """
Matthew Treinish83a19aa2015-07-23 13:06:13 -04001446 ext_plugins = plugins.TempestTestPluginManager()
Chris Hoged7b4fd12015-11-11 10:24:52 -08001447 # Make a shallow copy of the options list that can be
1448 # extended by plugins. Send back the group object
1449 # to allow group help text to be generated.
1450 opt_list = [(g, o) for g, o in _opts]
Matthew Treinish83a19aa2015-07-23 13:06:13 -04001451 opt_list.extend(ext_plugins.get_plugin_options_list())
1452 return opt_list
Matthew Treinish43b296a2014-02-28 15:23:00 -05001453
1454
Ken'ichi Ohmichi3f5c1392018-04-11 14:38:22 -07001455# This should never be called outside of this module
Sean Dague3b9b1f32013-12-20 17:04:54 -05001456class TempestConfigPrivate(object):
Daryl Walleck1465d612011-11-02 02:22:15 -05001457 """Provides OpenStack configuration information."""
1458
David Patersonbe9f9832015-10-15 09:10:45 -07001459 DEFAULT_CONFIG_DIR = os.path.join(os.getcwd(), "etc")
Daryl Walleck1465d612011-11-02 02:22:15 -05001460
Brian Waldon738cd632011-12-12 18:45:09 -05001461 DEFAULT_CONFIG_FILE = "tempest.conf"
1462
Andrea Frittolia96ee212014-08-15 18:34:20 +01001463 def __getattr__(self, attr):
1464 # Handles config options from the default group
Maru Newbyf440c292015-03-31 15:58:47 +00001465 return getattr(_CONF, attr)
Andrea Frittolia96ee212014-08-15 18:34:20 +01001466
Matthew Treinish43b296a2014-02-28 15:23:00 -05001467 def _set_attrs(self):
Andrea Frittoli382a6f12017-03-09 11:52:17 +00001468 # This methods ensures that config options in Tempest as well as
1469 # in Tempest plugins can be accessed via:
1470 # CONF.<normalised_group_name>.<key_name>
1471 # where:
1472 # normalised_group_name = group_name.replace('-', '_')
1473 # Attributes are set at __init__ time *only* for known option groups
Maru Newbyf440c292015-03-31 15:58:47 +00001474 self.auth = _CONF.auth
1475 self.compute = _CONF.compute
1476 self.compute_feature_enabled = _CONF['compute-feature-enabled']
1477 self.identity = _CONF.identity
zhufl071e94c2016-07-12 10:26:34 +08001478 self.service_clients = _CONF['service-clients']
Maru Newbyf440c292015-03-31 15:58:47 +00001479 self.identity_feature_enabled = _CONF['identity-feature-enabled']
1480 self.image = _CONF.image
1481 self.image_feature_enabled = _CONF['image-feature-enabled']
1482 self.network = _CONF.network
1483 self.network_feature_enabled = _CONF['network-feature-enabled']
Ghanshyam Manneb3c7e32021-01-20 15:27:16 -06001484 self.dashboard = _CONF.dashboard
Joseph Lanoux2f81cc12015-01-12 16:01:20 +00001485 self.validation = _CONF.validation
Maru Newbyf440c292015-03-31 15:58:47 +00001486 self.volume = _CONF.volume
1487 self.volume_feature_enabled = _CONF['volume-feature-enabled']
1488 self.object_storage = _CONF['object-storage']
1489 self.object_storage_feature_enabled = _CONF[
Matthew Treinishd5c96022013-10-17 21:51:23 +00001490 'object-storage-feature-enabled']
Maru Newbyf440c292015-03-31 15:58:47 +00001491 self.scenario = _CONF.scenario
1492 self.service_available = _CONF.service_available
Ghanshyam Mann6fb55c82021-02-02 17:14:21 -06001493 self.enforce_scope = _CONF.enforce_scope
Maru Newbyf440c292015-03-31 15:58:47 +00001494 self.debug = _CONF.debug
Matthew Treinish46008082015-04-14 18:32:47 -04001495 logging.tempest_set_log_file('tempest.log')
Andrea Frittoli382a6f12017-03-09 11:52:17 +00001496 # Setting attributes for plugins
1497 # NOTE(andreaf) Plugins have no access to the TempestConfigPrivate
1498 # instance at discovery time, so they have no way of setting these
1499 # aliases themselves.
1500 ext_plugins = plugins.TempestTestPluginManager()
1501 for group, _ in ext_plugins.get_plugin_options_list():
1502 if isinstance(group, cfg.OptGroup):
1503 # If we have an OptGroup
1504 group_name = group.name
1505 group_dest = group.dest
1506 else:
1507 # If we have a group name as a string
1508 group_name = group
1509 group_dest = group.replace('-', '_')
1510 # NOTE(andreaf) We can set the attribute safely here since in
1511 # case of name conflict we would not have reached this point.
1512 setattr(self, group_dest, _CONF[group_name])
Sean Dague86bd8422013-12-20 09:56:44 -05001513
Joe Gordon28a84ae2014-07-17 15:38:28 +00001514 def __init__(self, parse_conf=True, config_path=None):
Matthew Treinish43b296a2014-02-28 15:23:00 -05001515 """Initialize a configuration from a conf directory and conf file."""
1516 super(TempestConfigPrivate, self).__init__()
1517 config_files = []
1518 failsafe_path = "/etc/tempest/" + self.DEFAULT_CONFIG_FILE
1519
Joe Gordon28a84ae2014-07-17 15:38:28 +00001520 if config_path:
1521 path = config_path
1522 else:
1523 # Environment variables override defaults...
1524 conf_dir = os.environ.get('TEMPEST_CONFIG_DIR',
1525 self.DEFAULT_CONFIG_DIR)
1526 conf_file = os.environ.get('TEMPEST_CONFIG',
1527 self.DEFAULT_CONFIG_FILE)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001528
Joe Gordon28a84ae2014-07-17 15:38:28 +00001529 path = os.path.join(conf_dir, conf_file)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001530
1531 if not os.path.isfile(path):
1532 path = failsafe_path
1533
1534 # only parse the config file if we expect one to exist. This is needed
1535 # to remove an issue with the config file up to date checker.
1536 if parse_conf:
1537 config_files.append(path)
Maru Newbyf440c292015-03-31 15:58:47 +00001538 logging.register_options(_CONF)
Matthew Treinish5440a402014-10-02 14:36:16 -04001539 if os.path.isfile(path):
Maru Newbyf440c292015-03-31 15:58:47 +00001540 _CONF([], project='tempest', default_config_files=config_files)
Matthew Treinish5440a402014-10-02 14:36:16 -04001541 else:
Maru Newbyf440c292015-03-31 15:58:47 +00001542 _CONF([], project='tempest')
Marc Kodererc81c7672015-12-17 12:10:12 +01001543
1544 logging_cfg_path = "%s/logging.conf" % os.path.dirname(path)
Tom Patzige6f7c7d2016-02-17 16:46:11 +01001545 if ((not hasattr(_CONF, 'log_config_append') or
afazekas40fcb9b2019-03-08 11:25:11 +01001546 _CONF.log_config_append is None) and
Marc Kodererc81c7672015-12-17 12:10:12 +01001547 os.path.isfile(logging_cfg_path)):
1548 # if logging conf is in place we need to set log_config_append
1549 _CONF.log_config_append = logging_cfg_path
1550
Maru Newbyf440c292015-03-31 15:58:47 +00001551 logging.setup(_CONF, 'tempest')
Matthew Treinish43b296a2014-02-28 15:23:00 -05001552 LOG = logging.getLogger('tempest')
Jordan Pittier525ec712016-12-07 17:51:26 +01001553 LOG.info("Using tempest config file %s", path)
Matthew Treinish43b296a2014-02-28 15:23:00 -05001554 register_opts()
1555 self._set_attrs()
Masayuki Igawa9ec4cd82014-02-05 15:04:16 +09001556 if parse_conf:
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301557 _CONF.log_opt_values(LOG, logging.DEBUG)
Masayuki Igawa9ec4cd82014-02-05 15:04:16 +09001558
Sean Dague86bd8422013-12-20 09:56:44 -05001559
1560class TempestConfigProxy(object):
1561 _config = None
Joe Gordon28a84ae2014-07-17 15:38:28 +00001562 _path = None
Sean Dague86bd8422013-12-20 09:56:44 -05001563
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001564 _extra_log_defaults = [
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301565 ('paramiko.transport', logging.INFO),
1566 ('requests.packages.urllib3.connectionpool', logging.WARN),
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001567 ]
1568
1569 def _fix_log_levels(self):
1570 """Tweak the oslo log defaults."""
Doug Hellmann583ce2c2015-03-11 14:55:46 +00001571 for name, level in self._extra_log_defaults:
Anusha Raminenif3eb9472017-01-13 08:54:01 +05301572 logging.getLogger(name).logger.setLevel(level)
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001573
Sean Dague86bd8422013-12-20 09:56:44 -05001574 def __getattr__(self, attr):
1575 if not self._config:
Sean Daguedb6ac6c2014-06-06 16:52:44 -04001576 self._fix_log_levels()
Matthew Treinishaa29c7e2015-04-23 16:35:09 -04001577 lock_dir = os.path.join(tempfile.gettempdir(), 'tempest-lock')
1578 lockutils.set_defaults(lock_dir)
Joe Gordon28a84ae2014-07-17 15:38:28 +00001579 self._config = TempestConfigPrivate(config_path=self._path)
Sean Dague86bd8422013-12-20 09:56:44 -05001580
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001581 # Pushing tempest internal service client configuration to the
1582 # service clients register. Doing this in the config module ensures
1583 # that the configuration is available by the time we register the
1584 # service clients.
1585 # NOTE(andreaf) This has to be done at the time the first
1586 # attribute is accessed, to ensure all plugins have been already
1587 # loaded, options registered, and _config is set.
1588 _register_tempest_service_clients()
1589
Andrea Frittoli8b23c792017-03-09 13:17:01 +00001590 # Registering service clients and pushing their configuration to
1591 # the service clients register. Doing this in the config module
1592 # ensures that the configuration is available by the time we
1593 # discover tests from plugins.
1594 plugins.TempestTestPluginManager()._register_service_clients()
1595
Sean Dague86bd8422013-12-20 09:56:44 -05001596 return getattr(self._config, attr)
1597
Joe Gordon28a84ae2014-07-17 15:38:28 +00001598 def set_config_path(self, path):
1599 self._path = path
Masayuki Igawa79159f82018-07-27 15:00:37 +09001600 # FIXME(masayukig): bug#1783751 To pass the config file path to child
1601 # processes, we need to set the environment variables here as a
1602 # workaround.
1603 os.environ['TEMPEST_CONFIG_DIR'] = os.path.dirname(path)
1604 os.environ['TEMPEST_CONFIG'] = os.path.basename(path)
Joe Gordon28a84ae2014-07-17 15:38:28 +00001605
Sean Dague86bd8422013-12-20 09:56:44 -05001606
1607CONF = TempestConfigProxy()
Matthew Treinishca5a9ff2016-04-16 15:04:34 -04001608
1609
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001610def service_client_config(service_client_name=None):
1611 """Return a dict with the parameters to init service clients
1612
1613 Extracts from CONF the settings specific to the service_client_name and
1614 api_version, and formats them as dict ready to be passed to the service
1615 clients __init__:
1616
1617 * `region` (default to identity)
1618 * `catalog_type`
1619 * `endpoint_type`
1620 * `build_timeout` (object-storage and identity default to compute)
1621 * `build_interval` (object-storage and identity default to compute)
1622
1623 The following common settings are always returned, even if
1624 `service_client_name` is None:
1625
1626 * `disable_ssl_certificate_validation`
1627 * `ca_certs`
1628 * `trace_requests`
zhufl071e94c2016-07-12 10:26:34 +08001629 * `http_timeout`
Matthew Treinish74514402016-09-01 11:44:57 -04001630 * `proxy_url`
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001631
1632 The dict returned by this does not fit a few service clients:
1633
1634 * The endpoint type is not returned for identity client, since it takes
1635 three different values for v2 admin, v2 public and v3
1636 * The `ServersClient` from compute accepts an optional
1637 `enable_instance_password` parameter, which is not returned.
1638 * The `VolumesClient` for both v1 and v2 volume accept an optional
1639 `default_volume_size` parameter, which is not returned.
1640 * The `TokenClient` and `V3TokenClient` have a very different
1641 interface, only auth_url is needed for them.
1642
1643 :param service_client_name: str Name of the service. Supported values are
1644 'compute', 'identity', 'image', 'network', 'object-storage', 'volume'
1645 :return: dictionary of __init__ parameters for the service clients
1646 :rtype: dict
1647 """
1648 _parameters = {
1649 'disable_ssl_certificate_validation':
Daniel Melladocad3f3d2016-08-19 14:17:16 +00001650 CONF.identity.disable_ssl_certificate_validation,
1651 'ca_certs': CONF.identity.ca_certificates_file,
zhufl071e94c2016-07-12 10:26:34 +08001652 'trace_requests': CONF.debug.trace_requests,
Matthew Treinish74514402016-09-01 11:44:57 -04001653 'http_timeout': CONF.service_clients.http_timeout,
1654 'proxy_url': CONF.service_clients.proxy_url,
Andrea Frittoli (andreaf)de5fb0c2016-06-13 12:15:00 +01001655 }
1656
1657 if service_client_name is None:
1658 return _parameters
1659
1660 # Get the group of options first, by normalising the service_group_name
1661 # Services with a '-' in the name have an '_' in the option group name
1662 config_group = service_client_name.replace('-', '_')
1663 # NOTE(andreaf) Check if the config group exists. This allows for this
1664 # helper to be used for settings from registered plugins as well
1665 try:
1666 options = getattr(CONF, config_group)
1667 except cfg.NoSuchOptError:
1668 # Option group not defined
1669 raise exceptions.UnknownServiceClient(services=service_client_name)
1670 # Set endpoint_type
1671 # Identity uses different settings depending on API version, so do not
1672 # return the endpoint at all.
1673 if service_client_name != 'identity':
1674 _parameters['endpoint_type'] = getattr(options, 'endpoint_type')
1675 # Set build_*
1676 # Object storage and identity groups do not have conf settings for
1677 # build_* parameters, and we default to compute in any case
1678 for setting in ['build_timeout', 'build_interval']:
1679 if not hasattr(options, setting) or not getattr(options, setting):
1680 _parameters[setting] = getattr(CONF.compute, setting)
1681 else:
1682 _parameters[setting] = getattr(options, setting)
1683 # Set region
1684 # If a service client does not define region or region is not set
1685 # default to the identity region
1686 if not hasattr(options, 'region') or not getattr(options, 'region'):
1687 _parameters['region'] = CONF.identity.region
1688 else:
1689 _parameters['region'] = getattr(options, 'region')
1690 # Set service
1691 _parameters['service'] = getattr(options, 'catalog_type')
1692 return _parameters
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001693
1694
1695def _register_tempest_service_clients():
1696 # Register tempest own service clients using the same mechanism used
1697 # for external plugins.
1698 # The configuration data is pushed to the registry so that automatic
1699 # configuration of tempest own service clients is possible both for
1700 # tempest as well as for the plugins.
1701 service_clients = clients.tempest_modules()
1702 registry = clients.ClientsRegistry()
1703 all_clients = []
1704 for service_client in service_clients:
1705 module = service_clients[service_client]
1706 configs = service_client.split('.')[0]
1707 service_client_data = dict(
Andrea Frittoli986407d2017-10-11 10:23:17 +00001708 name=service_client.replace('.', '_').replace('-', '_'),
Andrea Frittoli (andreaf)8420abe2016-07-27 11:47:43 +01001709 service_version=service_client,
1710 module_path=module.__name__,
1711 client_names=module.__all__,
1712 **service_client_config(configs)
1713 )
1714 all_clients.append(service_client_data)
1715 # NOTE(andreaf) Internal service clients do not actually belong
1716 # to a plugin, so using '__tempest__' to indicate a virtual plugin
1717 # which holds internal service clients.
1718 registry.register_service_client('__tempest__', all_clients)