blob: 44dcbe43849e395256824d1570ca0714b03958f1 [file] [log] [blame]
Mike Tureka7cb4be2016-01-18 19:35:29 +00001# Copyright 2015 NEC Corporation
2# 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
16from oslo_config import cfg
17
18from tempest import config # noqa
19
20
Dmitry Tantsurb609cea2017-12-12 08:06:44 +010021ironic_service_option = cfg.BoolOpt('ironic',
22 default=False,
23 help='Whether or not ironic is expected '
24 'to be available')
Jim Rollenhagen1c11bdf2016-11-29 16:57:30 -050025
John L. Villalovos25be1172017-12-13 16:08:34 -080026inspector_service_option = cfg.BoolOpt("ironic_inspector",
27 default=False,
Dmitry Tantsurb609cea2017-12-12 08:06:44 +010028 help="Whether or not ironic-inspector "
29 "is expected to be available")
Jim Rollenhagen1c11bdf2016-11-29 16:57:30 -050030
Mike Tureka7cb4be2016-01-18 19:35:29 +000031baremetal_group = cfg.OptGroup(name='baremetal',
32 title='Baremetal provisioning service options',
33 help='When enabling baremetal tests, Nova '
34 'must be configured to use the Ironic '
35 'driver. The following parameters for the '
36 '[compute] section must be disabled: '
37 'console_output, interface_attach, '
38 'live_migration, pause, rescue, resize, '
39 'shelve, snapshot, and suspend')
40
Anton Arefiev6dc82792016-08-03 11:50:49 +030041baremetal_introspection_group = cfg.OptGroup(
42 name="baremetal_introspection",
43 title="Baremetal introspection service options",
44 help="When enabling baremetal introspection tests,"
45 "Ironic must be configured.")
46
Vasyl Saienkof46b9fa2017-02-23 13:06:56 -050047baremetal_features_group = cfg.OptGroup(
48 name='baremetal_feature_enabled',
49 title="Enabled Baremetal Service Features")
50
Mike Tureka7cb4be2016-01-18 19:35:29 +000051BaremetalGroup = [
Thiago Paivaa7760932016-08-15 15:23:30 -030052 cfg.StrOpt('catalog_type',
53 default='baremetal',
54 help="Catalog type of the baremetal provisioning service"),
55 cfg.StrOpt('driver',
Iury Gregory Melo Ferreira4569ada2020-03-09 16:52:09 +010056 default='fake-hardware',
Dmitry Tantsur893b1a92018-04-26 16:12:45 +020057 help="Driver name to use for API tests"),
Thiago Paivaa7760932016-08-15 15:23:30 -030058 cfg.StrOpt('endpoint_type',
59 default='publicURL',
60 choices=['public', 'admin', 'internal',
61 'publicURL', 'adminURL', 'internalURL'],
62 help="The endpoint type to use for the baremetal provisioning"
63 " service"),
Mike Tureka7cb4be2016-01-18 19:35:29 +000064 cfg.IntOpt('deploywait_timeout',
65 default=15,
66 help="Timeout for Ironic node to reach the "
67 "wait-callback state after powering on."),
Thiago Paivaa7760932016-08-15 15:23:30 -030068 cfg.IntOpt('active_timeout',
69 default=300,
70 help="Timeout for Ironic node to completely provision"),
71 cfg.IntOpt('association_timeout',
72 default=30,
73 help="Timeout for association of Nova instance and Ironic "
74 "node"),
75 cfg.IntOpt('power_timeout',
76 default=60,
77 help="Timeout for Ironic power transitions."),
78 cfg.IntOpt('unprovision_timeout',
79 default=300,
80 help="Timeout for unprovisioning an Ironic node. "
81 "Takes longer since Kilo as Ironic performs an extra "
82 "step in Node cleaning."),
Dao Cong Tien4108a352018-01-26 09:38:46 +070083 cfg.IntOpt('rescue_timeout',
84 default=300,
85 help="Timeout for rescuing an Ironic node."),
86 cfg.IntOpt('unrescue_timeout',
87 default=300,
88 help="Timeout for unrescuing an Ironic node."),
Yuiko Takadaff785002015-12-17 15:56:42 +090089 cfg.StrOpt('min_microversion',
Yuiko Takadaff785002015-12-17 15:56:42 +090090 help="Lower version of the test target microversion range. "
91 "The format is 'X.Y', where 'X' and 'Y' are int values. "
92 "Tempest selects tests based on the range between "
93 "min_microversion and max_microversion. "
94 "If both values are None, Tempest avoids tests which "
95 "require a microversion."),
96 cfg.StrOpt('max_microversion',
97 default='latest',
98 help="Upper version of the test target microversion range. "
99 "The format is 'X.Y', where 'X' and 'Y' are int values. "
100 "Tempest selects tests based on the range between "
101 "min_microversion and max_microversion. "
102 "If both values are None, Tempest avoids tests which "
103 "require a microversion."),
Yuriy Yekovenkoeb612d92016-01-18 17:49:47 +0200104 cfg.BoolOpt('use_provision_network',
105 default=False,
Vasyl Saienko4ddbeec2017-01-20 16:26:04 +0000106 help="Whether the Ironic/Neutron tenant isolation is enabled"),
107 cfg.StrOpt('whole_disk_image_ref',
108 help="UUID of the wholedisk image to use in the tests."),
Vasyl Saienkof46b9fa2017-02-23 13:06:56 -0500109 cfg.StrOpt('whole_disk_image_url',
110 help="An http link to the wholedisk image to use in the "
111 "tests."),
112 cfg.StrOpt('whole_disk_image_checksum',
113 help="An MD5 checksum of the image."),
Vasyl Saienko4ddbeec2017-01-20 16:26:04 +0000114 cfg.StrOpt('partition_image_ref',
115 help="UUID of the partitioned image to use in the tests."),
Julia Kregerff9f8742020-06-17 13:47:34 -0700116 cfg.StrOpt('ramdisk_iso_image_ref',
117 help=("UUID (or url) of an ISO image for the ramdisk boot "
118 "tests.")),
Vasyl Saienko4ddbeec2017-01-20 16:26:04 +0000119 cfg.ListOpt('enabled_drivers',
120 default=['fake', 'pxe_ipmitool', 'agent_ipmitool'],
121 help="List of Ironic enabled drivers."),
122 cfg.ListOpt('enabled_hardware_types',
123 default=['ipmi'],
124 help="List of Ironic enabled hardware types."),
Yolanda Roblaeef49ea2018-05-15 12:54:58 +0200125 cfg.ListOpt('enabled_bios_interfaces',
126 default=['fake'],
127 help="List of Ironic enabled bios interfaces."),
Pavlo Shchelokovskyy12e62752017-12-21 16:11:28 +0000128 cfg.ListOpt('enabled_deploy_interfaces',
129 default=['iscsi', 'direct'],
130 help="List of Ironic enabled deploy interfaces."),
Dao Cong Tien4108a352018-01-26 09:38:46 +0700131 cfg.ListOpt('enabled_rescue_interfaces',
132 default=['no-rescue'],
133 help="List of Ironic enabled rescue interfaces."),
ankitbf770e52018-01-19 07:39:01 +0000134 cfg.ListOpt('enabled_boot_interfaces',
135 default=['fake', 'pxe'],
136 help="List of Ironic enabled boot interfaces."),
Dmitry Tantsur65abaca2019-08-07 11:07:48 +0200137 cfg.ListOpt('enabled_raid_interfaces',
138 default=['no-raid', 'agent'],
139 help="List of Ironic enabled RAID interfaces."),
Dao Cong Tiend6ce6672017-12-18 19:04:48 +0700140 cfg.StrOpt('default_rescue_interface',
141 help="Ironic default rescue interface."),
Vasyl Saienko4ddbeec2017-01-20 16:26:04 +0000142 cfg.IntOpt('adjusted_root_disk_size_gb',
143 min=0,
144 help="Ironic adjusted disk size to use in the standalone tests "
145 "as instance_info/root_gb value."),
Sam Bettsf31abcc2018-02-06 17:34:08 +0000146 cfg.IntOpt('available_nodes', min=0, default=None,
147 help="The number of baremetal hosts available to use for "
Julia Kregercd85f202019-08-26 14:48:17 -0400148 "the tests."),
149 cfg.BoolOpt('partition_netboot',
150 default=True,
151 help="Treat partition images as netbooted as opposed to "
152 "attempting to populate a boot loader. IF cirros is "
153 "being used, this option should be set to True as "
154 "it lacks the needed components to make it locally "
155 "from a partition image."),
Mike Tureka7cb4be2016-01-18 19:35:29 +0000156]
Vasyl Saienkof46b9fa2017-02-23 13:06:56 -0500157
158BaremetalFeaturesGroup = [
159 cfg.BoolOpt('ipxe_enabled',
160 default=True,
161 help="Defines if IPXE is enabled"),
Dmitry Tantsur52ca0092019-07-23 15:09:09 +0200162 cfg.BoolOpt('adoption',
163 # Defaults to False since it's a destructive operation AND it
164 # requires the plugin to be able to read ipmi_password.
165 default=False,
166 help="Defines if adoption is enabled"),
Dmitry Tantsur65abaca2019-08-07 11:07:48 +0200167 cfg.BoolOpt('software_raid',
168 default=False,
169 help="Defines if software RAID is enabled (available "
170 "starting with Train). Requires at least two disks "
171 "on testing nodes."),
Vasyl Saienkof46b9fa2017-02-23 13:06:56 -0500172]
Dmitry Tantsurb609cea2017-12-12 08:06:44 +0100173
Anton Arefiev6dc82792016-08-03 11:50:49 +0300174BaremetalIntrospectionGroup = [
175 cfg.StrOpt('catalog_type',
176 default='baremetal-introspection',
177 help="Catalog type of the baremetal provisioning service"),
178 cfg.StrOpt('endpoint_type',
179 default='publicURL',
180 choices=['public', 'admin', 'internal',
181 'publicURL', 'adminURL', 'internalURL'],
182 help="The endpoint type to use for the baremetal introspection"
183 " service"),
184 cfg.IntOpt('introspection_sleep',
185 default=30,
186 help="Introspection sleep before check status"),
187 cfg.IntOpt('introspection_timeout',
188 default=600,
189 help="Introspection time out"),
Dmitry Tantsurdeab6ec2019-10-18 17:29:52 +0200190 cfg.IntOpt('introspection_start_timeout',
191 default=90,
192 help="Timeout to start introspection"),
Anton Arefiev6dc82792016-08-03 11:50:49 +0300193 cfg.IntOpt('hypervisor_update_sleep',
194 default=60,
195 help="Time to wait until nova becomes aware of "
196 "bare metal instances"),
197 cfg.IntOpt('hypervisor_update_timeout',
198 default=300,
199 help="Time out for wait until nova becomes aware of "
200 "bare metal instances"),
201 # NOTE(aarefiev): status_check_period default is 60s, but checking
202 # node state takes some time(API call), so races appear here,
203 # 80s would be enough to make one more check.
204 cfg.IntOpt('ironic_sync_timeout',
205 default=80,
206 help="Time it might take for Ironic--Inspector "
207 "sync to happen"),
Anton Arefiev6b003562016-09-13 12:17:29 +0300208 cfg.IntOpt('discovery_timeout',
209 default=300,
210 help="Time to wait until new node would enrolled in "
211 "ironic"),
212 cfg.BoolOpt('auto_discovery_feature',
213 default=False,
214 help="Is the auto-discovery feature enabled. Enroll hook "
215 "should be specified in node_not_found_hook - processing "
216 "section of inspector.conf"),
Dmitry Tantsur39579c62018-03-28 12:46:48 +0200217 cfg.StrOpt('auto_discovery_default_driver',
218 # TODO(dtantsur): change to fake-hardware when Queens is no
219 # longer supported.
220 default='fake',
221 help="The driver expected to be set on newly discovered nodes. "
222 "Only has effect with auto_discovery_feature is True."),
Dmitry Tantsur0812cc72019-03-14 10:56:45 +0100223 cfg.StrOpt('auto_discovery_target_driver',
224 help="The driver to set on the newly discovered nodes. "
225 "Only has effect with auto_discovery_feature is True."),
Dongcan Ye2d992ed2019-05-10 01:55:29 +0000226 cfg.StrOpt('data_store',
Dongcan Ye2d992ed2019-05-10 01:55:29 +0000227 help="The storage backend for storing introspection data."),
Anton Arefiev6dc82792016-08-03 11:50:49 +0300228]