blob: 9a7ce15382cf952ae439909aeb341f1ed3b23254 [file] [log] [blame]
Matthew Treinisha970d652015-03-11 15:39:24 -04001.. _tempest-configuration:
2
Matthew Treinishbc1b15b2015-02-20 15:56:07 -05003Tempest Configuration Guide
4===========================
5
Eric Friede0cfc3e2015-12-14 16:10:49 -06006This guide is a starting point for configuring Tempest. It aims to elaborate
Matthew Treinishf640f662015-03-11 15:13:30 -04007on and explain some of the mandatory and common configuration settings and how
8they are used in conjunction. The source of truth on each option is the sample
Matthew Treinishf45ba2e2015-08-24 15:05:01 -04009config file which explains the purpose of each individual option. You can see
10the sample config file here: :ref:`tempest-sampleconf`
Matthew Treinishf640f662015-03-11 15:13:30 -040011
Andrea Frittoli (andreaf)dd250702016-04-29 15:01:22 -050012Test Credentials
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050013----------------
14
Andrea Frittoli (andreaf)dd250702016-04-29 15:01:22 -050015Tempest allows for configuring a set of admin credentials in the ``auth``
16section, via the following parameters:
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050017
Andrea Frittoli (andreaf)dd250702016-04-29 15:01:22 -050018 #. ``admin_username``
19 #. ``admin_password``
20 #. ``admin_project_name``
21 #. ``admin_domain_name``
22
23Admin credentials are not mandatory to run Tempest, but when provided they
24can be used to:
25
26- Run tests for admin APIs
27- Generate test credentials on the fly (see `Dynamic Credentials`_)
28
29Tempest allows for configuring pre-provisioned test credentials as well.
Matthew Treinish40847ac2016-01-04 13:16:03 -050030This can be done using the accounts.yaml file (see
Andrea Frittoli (andreaf)dd250702016-04-29 15:01:22 -050031`Pre-Provisioned Credentials`_). This file is used to specify an arbitrary
32number of users available to run tests with.
33You can specify the location of the file in the ``auth`` section in the
Eric Friede0cfc3e2015-12-14 16:10:49 -060034tempest.conf file. To see the specific format used in the file please refer to
Andrea Frittoli (andreaf)dd250702016-04-29 15:01:22 -050035the accounts.yaml.sample file included in Tempest.
36
Matthew Treinish7909e122015-04-15 15:43:50 -040037Keystone Connection Info
38^^^^^^^^^^^^^^^^^^^^^^^^
Eric Friede0cfc3e2015-12-14 16:10:49 -060039In order for Tempest to be able to talk to your OpenStack deployment you need
Matthew Treinish7909e122015-04-15 15:43:50 -040040to provide it with information about how it communicates with keystone.
Eric Friede0cfc3e2015-12-14 16:10:49 -060041This involves configuring the following options in the ``identity`` section:
Matthew Treinish7909e122015-04-15 15:43:50 -040042
Eric Friede0cfc3e2015-12-14 16:10:49 -060043 #. ``auth_version``
44 #. ``uri``
45 #. ``uri_v3``
Matthew Treinish7909e122015-04-15 15:43:50 -040046
Eric Friede0cfc3e2015-12-14 16:10:49 -060047The ``auth_version`` option is used to tell Tempest whether it should be using
Matthew Treinish7909e122015-04-15 15:43:50 -040048keystone's v2 or v3 api for communicating with keystone. (except for the
Eric Friede0cfc3e2015-12-14 16:10:49 -060049identity api tests which will test a specific version) The two uri options are
50used to tell Tempest the url of the keystone endpoint. The ``uri`` option is
51used for keystone v2 request and ``uri_v3`` is used for keystone v3. You want to
52ensure that which ever version you set for ``auth_version`` has its uri option
53defined.
Matthew Treinish7909e122015-04-15 15:43:50 -040054
55
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050056Credential Provider Mechanisms
57^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
58
Eric Friede0cfc3e2015-12-14 16:10:49 -060059Tempest currently also has three different internal methods for providing
60authentication to tests: dynamic credentials, locking test accounts, and
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050061non-locking test accounts. Depending on which one is in use the configuration
Eric Friede0cfc3e2015-12-14 16:10:49 -060062of Tempest is slightly different.
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050063
Andrea Frittoli (andreaf)17209bb2015-05-22 10:16:57 -070064Dynamic Credentials
65"""""""""""""""""""
66Dynamic Credentials (formerly known as Tenant isolation) was originally created
Eric Friede0cfc3e2015-12-14 16:10:49 -060067to enable running Tempest in parallel. For each test class it creates a unique
68set of user credentials to use for the tests in the class. It can create up to
Sean Dagueed6e5862016-04-04 10:49:13 -040069three sets of username, password, and project names for a primary user,
70an admin user, and an alternate user. To enable and use dynamic credentials you
Eric Friede0cfc3e2015-12-14 16:10:49 -060071only need to configure two things:
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050072
73 #. A set of admin credentials with permissions to create users and
Sean Dagueed6e5862016-04-04 10:49:13 -040074 projects. This is specified in the ``auth`` section with the
75 ``admin_username``, ``admin_project_name``, ``admin_domain_name`` and
Eric Friede0cfc3e2015-12-14 16:10:49 -060076 ``admin_password`` options
77 #. To enable dynamic credentials in the ``auth`` section with the
78 ``use_dynamic_credentials`` option.
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050079
Eric Friede0cfc3e2015-12-14 16:10:49 -060080This is also currently the default credential provider enabled by Tempest, due
81to its common use and ease of configuration.
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050082
Matthew Treinish4fae4722015-04-16 21:03:54 -040083It is worth pointing out that depending on your cloud configuration you might
Andrea Frittoli (andreaf)17209bb2015-05-22 10:16:57 -070084need to assign a role to each of the users created by Tempest's dynamic
Eric Friede0cfc3e2015-12-14 16:10:49 -060085credentials. This can be set using the ``tempest_roles`` option. It takes in a
86list of role names each of which will be assigned to each of the users created
87by dynamic credentials. This option will not have any effect when Tempest is not
Andrea Frittoli (andreaf)17209bb2015-05-22 10:16:57 -070088configured to use dynamic credentials.
Matthew Treinish4fae4722015-04-16 21:03:54 -040089
90
Andrea Frittoli (andreaf)dd250702016-04-29 15:01:22 -050091Pre-Provisioned Credentials
92"""""""""""""""""""""""""""
93
Andrea Frittoli (andreaf)17209bb2015-05-22 10:16:57 -070094For a long time using dynamic credentials was the only method available if you
Eric Friede0cfc3e2015-12-14 16:10:49 -060095wanted to enable parallel execution of Tempest tests. However, this was
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050096insufficient for certain use cases because of the admin credentials requirement
97to create the credential sets on demand. To get around that the accounts.yaml
98file was introduced and with that a new internal credential provider to enable
99using the list of credentials instead of creating them on demand. With locking
100test accounts each test class will reserve a set of credentials from the
101accounts.yaml before executing any of its tests so that each class is isolated
Andrea Frittoli (andreaf)17209bb2015-05-22 10:16:57 -0700102like with dynamic credentials.
Matthew Treinishbc1b15b2015-02-20 15:56:07 -0500103
Matthew Treinishbc1b15b2015-02-20 15:56:07 -0500104To enable and use locking test accounts you need do a few things:
105
Eric Friede0cfc3e2015-12-14 16:10:49 -0600106 #. Create an accounts.yaml file which contains the set of pre-existing
Matthew Treinishbc1b15b2015-02-20 15:56:07 -0500107 credentials to use for testing. To make sure you don't have a credentials
Eric Friede0cfc3e2015-12-14 16:10:49 -0600108 starvation issue when running in parallel make sure you have at least two
109 times the number of worker processes you are using to execute Tempest
110 available in the file. (If running serially the worker count is 1.)
Matthew Treinish0fd69e42015-03-06 00:40:51 -0500111
Eric Friede0cfc3e2015-12-14 16:10:49 -0600112 You can check the accounts.yaml.sample file packaged in Tempest for the yaml
113 format.
114 #. Provide Tempest with the location of your accounts.yaml file with the
115 ``test_accounts_file`` option in the ``auth`` section
Matthew Treinishbc1b15b2015-02-20 15:56:07 -0500116
Eric Friede0cfc3e2015-12-14 16:10:49 -0600117 *NOTE: Be sure to use a full path for the file; otherwise Tempest will
Matthew Treinish84c6d292015-12-16 17:50:57 -0500118 likely not find it.*
119
Eric Friede0cfc3e2015-12-14 16:10:49 -0600120 #. Set ``use_dynamic_credentials = False`` in the ``auth`` group
Fei Long Wang7fee7872015-05-12 11:36:49 +1200121
Matthew Treinish93299852015-04-24 09:58:18 -0400122It is worth pointing out that each set of credentials in the accounts.yaml
Sean Dagueed6e5862016-04-04 10:49:13 -0400123should have a unique project. This is required to provide proper isolation
Matthew Treinish93299852015-04-24 09:58:18 -0400124to the tests using the credentials, and failure to do this will likely cause
125unexpected failures in some tests.
Matthew Treinishbc1b15b2015-02-20 15:56:07 -0500126
Andrea Frittoli (andreaf)dd250702016-04-29 15:01:22 -0500127Pre-Provisioned Credentials are also know as accounts.yaml or accounts file.
Matthew Treinish93299852015-04-24 09:58:18 -0400128
Matthew Treinish7909e122015-04-15 15:43:50 -0400129Compute
130-------
131
132Flavors
133^^^^^^^
Eric Friede0cfc3e2015-12-14 16:10:49 -0600134For Tempest to be able to create servers you need to specify flavors that it
135can use to boot the servers with. There are two options in the Tempest config
Matthew Treinish7909e122015-04-15 15:43:50 -0400136for doing this:
137
Eric Friede0cfc3e2015-12-14 16:10:49 -0600138 #. ``flavor_ref``
139 #. ``flavor_ref_alt``
Matthew Treinish7909e122015-04-15 15:43:50 -0400140
Eric Friede0cfc3e2015-12-14 16:10:49 -0600141Both of these options are in the ``compute`` section of the config file and take
142in the flavor id (not the name) from nova. The ``flavor_ref`` option is what
143will be used for booting almost all of the guests; ``flavor_ref_alt`` is only
144used in tests where two different-sized servers are required (for example, a
145resize test).
Matthew Treinish7909e122015-04-15 15:43:50 -0400146
Eric Friede0cfc3e2015-12-14 16:10:49 -0600147Using a smaller flavor is generally recommended. When larger flavors are used,
Matthew Treinish7909e122015-04-15 15:43:50 -0400148the extra time required to bring up servers will likely affect total run time
149and probably require tweaking timeout values to ensure tests have ample time to
150finish.
151
152Images
153^^^^^^
Eric Friede0cfc3e2015-12-14 16:10:49 -0600154Just like with flavors, Tempest needs to know which images to use for booting
155servers. There are two options in the compute section just like with flavors:
Matthew Treinish7909e122015-04-15 15:43:50 -0400156
Eric Friede0cfc3e2015-12-14 16:10:49 -0600157 #. ``image_ref``
158 #. ``image_ref_alt``
Matthew Treinish7909e122015-04-15 15:43:50 -0400159
Eric Friede0cfc3e2015-12-14 16:10:49 -0600160Both options are expecting an image id (not name) from nova. The ``image_ref``
161option is what will be used for booting the majority of servers in Tempest.
162``image_ref_alt`` is used for tests that require two images such as rebuild. If
163two images are not available you can set both options to the same image id and
Matthew Treinish7909e122015-04-15 15:43:50 -0400164those tests will be skipped.
165
Eric Friede0cfc3e2015-12-14 16:10:49 -0600166There are also options in the ``scenario`` section for images:
Matthew Treinish7909e122015-04-15 15:43:50 -0400167
Eric Friede0cfc3e2015-12-14 16:10:49 -0600168 #. ``img_file``
169 #. ``img_dir``
170 #. ``aki_img_file``
171 #. ``ari_img_file``
172 #. ``ami_img_file``
173 #. ``img_container_format``
174 #. ``img_disk_format``
Matthew Treinish7909e122015-04-15 15:43:50 -0400175
Eric Friede0cfc3e2015-12-14 16:10:49 -0600176However, unlike the other image options, these are used for a very small subset
Matthew Treinish7909e122015-04-15 15:43:50 -0400177of scenario tests which are uploading an image. These options are used to tell
Eric Friede0cfc3e2015-12-14 16:10:49 -0600178Tempest where an image file is located and describe its metadata for when it is
Matthew Treinish7909e122015-04-15 15:43:50 -0400179uploaded.
180
Eric Friede0cfc3e2015-12-14 16:10:49 -0600181The behavior of these options is a bit convoluted (which will likely be fixed in
182future versions). You first need to specify ``img_dir``, which is the directory
183in which Tempest will look for the image files. First it will check if the
184filename set for ``img_file`` could be found in ``img_dir``. If it is found then
185the ``img_container_format`` and ``img_disk_format`` options are used to upload
186that image to glance. However, if it is not found, Tempest will look for the
187three uec image file name options as a fallback. If neither is found, the tests
188requiring an image to upload will fail.
Matthew Treinish7909e122015-04-15 15:43:50 -0400189
190It is worth pointing out that using `cirros`_ is a very good choice for running
Eric Friede0cfc3e2015-12-14 16:10:49 -0600191Tempest. It's what is used for upstream testing, they boot quickly and have a
Matthew Treinish7909e122015-04-15 15:43:50 -0400192small footprint.
193
194.. _cirros: https://launchpad.net/cirros
195
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400196Networking
197----------
198OpenStack has a myriad of different networking configurations possible and
Eric Friede0cfc3e2015-12-14 16:10:49 -0600199depending on which of the two network backends, nova-network or neutron, you are
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400200using things can vary drastically. Due to this complexity Tempest has to provide
Eric Friede0cfc3e2015-12-14 16:10:49 -0600201a certain level of flexibility in its configuration to ensure it will work
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400202against any cloud. This ends up causing a large number of permutations in
203Tempest's config around network configuration.
204
205
206Enabling Remote Access to Created Servers
207^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
208When Tempest creates servers for testing, some tests require being able to
209connect those servers. Depending on the configuration of the cloud, the methods
210for doing this can be different. In certain configurations it is required to
211specify a single network with server create calls. Accordingly, Tempest provides
212a few different methods for providing this information in configuration to try
Eric Friede0cfc3e2015-12-14 16:10:49 -0600213and ensure that regardless of the cloud's configuration it'll still be able to
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400214run. This section covers the different methods of configuring Tempest to provide
215a network when creating servers.
216
lanoux63bb9032016-03-21 03:16:18 -0700217The ``validation`` group gathers all the connection options to remotely access the
218created servers.
219
220To enable remote access to servers, at least the three following options need to be
221set:
222
223* The ``run_validation`` option needs be set to ``true``.
224
225* The ``connect_method`` option. Two connect methods are available: ``fixed`` and
226 ``floating``, the later being set by default.
227
228* The ``auth_method`` option. Currently, only authentication by keypair is
229 available.
230
231
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400232Fixed Network Name
233""""""""""""""""""
234This is the simplest method of specifying how networks should be used. You can
235just specify a single network name/label to use for all server creations. The
Sean Dagueed6e5862016-04-04 10:49:13 -0400236limitation with this is that all projects and users must be able to see
Eric Friede0cfc3e2015-12-14 16:10:49 -0600237that network name/label if they are to perform a network list and be able to use
238it.
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400239
240If no network name is assigned in the config file and none of the below
241alternatives are used, then Tempest will not specify a network on server
242creations, which depending on the cloud configuration might prevent them from
243booting.
244
Eric Friede0cfc3e2015-12-14 16:10:49 -0600245To set a fixed network name simply:
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400246
Eric Friede0cfc3e2015-12-14 16:10:49 -0600247 #. Set the ``fixed_network_name`` option in the ``compute`` group
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400248
249In the case that the configured fixed network name can not be found by a user
250network list call, it will be treated like one was not provided except that a
251warning will be logged stating that it couldn't be found.
252
253
254Accounts File
255"""""""""""""
256If you are using an accounts file to provide credentials for running Tempest
257then you can leverage it to also specify which network should be used with
Sean Dagueed6e5862016-04-04 10:49:13 -0400258server creations on a per project and user pair basis. This provides
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400259the necessary flexibility to work with more intricate networking configurations
260by enabling the user to specify exactly which network to use for which
Sean Dagueed6e5862016-04-04 10:49:13 -0400261projects. You can refer to the accounts.yaml.sample file included in
Eric Friede0cfc3e2015-12-14 16:10:49 -0600262the Tempest repo for the syntax around specifying networks in the file.
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400263
264However, specifying a network is not required when using an accounts file. If
265one is not specified you can use a fixed network name to specify the network to
266use when creating servers just as without an accounts file. However, any network
267specified in the accounts file will take precedence over the fixed network name
268provided. If no network is provided in the accounts file and a fixed network
269name is not set then no network will be included in create server requests.
270
271If a fixed network is provided and the accounts.yaml file also contains networks
272this has the benefit of enabling a couple more tests which require a static
273network to perform operations like server lists with a network filter. If a
274fixed network name is not provided these tests are skipped. Additionally, if a
275fixed network name is provided it will serve as a fallback in case of a
276misconfiguration or a missing network in the accounts file.
277
278
Andrea Frittoli (andreaf)17209bb2015-05-22 10:16:57 -0700279With Dynamic Credentials
280""""""""""""""""""""""""
Eric Friede0cfc3e2015-12-14 16:10:49 -0600281With dynamic credentials enabled and using nova-network, your only option for
lanoux63bb9032016-03-21 03:16:18 -0700282configuration is to either set a fixed network name or not. However, in most
Eric Friede0cfc3e2015-12-14 16:10:49 -0600283cases it shouldn't matter because nova-network should have no problem booting a
284server with multiple networks. If this is not the case for your cloud then using
285an accounts file is recommended because it provides the necessary flexibility to
286describe your configuration. Dynamic credentials is not able to dynamically
287allocate things as necessary if neutron is not enabled.
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400288
Andrea Frittoli (andreaf)17209bb2015-05-22 10:16:57 -0700289With neutron and dynamic credentials enabled there should not be any additional
Matthew Treinish2b7f0482015-04-10 12:49:01 -0400290configuration necessary to enable Tempest to create servers with working
Eric Friede0cfc3e2015-12-14 16:10:49 -0600291networking, assuming you have properly configured the ``network`` section to
292work for your cloud. Tempest will dynamically create the neutron resources
293necessary to enable using servers with that network. Also, just as with the
294accounts file, if you specify a fixed network name while using neutron and
295dynamic credentials it will enable running tests which require a static network
296and it will additionally be used as a fallback for server creation. However,
297unlike accounts.yaml this should never be triggered.
Matthew Treinish3220cad2015-04-15 16:25:48 -0400298
Eric Friede0cfc3e2015-12-14 16:10:49 -0600299However, there is an option ``create_isolated_networks`` to disable dynamic
300credentials's automatic provisioning of network resources. If this option is set
301to False you will have to either rely on there only being a single/default
302network available for the server creation, or use ``fixed_network_name`` to
303inform Tempest which network to use.
Matthew Treinish2219d382015-04-24 10:33:04 -0400304
Matthew Treinishf96ab3a2015-04-15 19:11:31 -0400305Configuring Available Services
306------------------------------
307OpenStack is really a constellation of several different projects which
308are running together to create a cloud. However which projects you're running
309is not set in stone, and which services are running is up to the deployer.
310Tempest however needs to know which services are available so it can figure
311out which tests it is able to run and certain setup steps which differ based
312on the available services.
313
Eric Friede0cfc3e2015-12-14 16:10:49 -0600314The ``service_available`` section of the config file is used to set which
Matthew Treinishf96ab3a2015-04-15 19:11:31 -0400315services are available. It contains a boolean option for each service (except
316for keystone which is a hard requirement) set it to True if the service is
317available or False if it is not.
318
319Service Catalog
320^^^^^^^^^^^^^^^
321Each project which has its own REST API contains an entry in the service
322catalog. Like most things in OpenStack this is also completely configurable.
Eric Friede0cfc3e2015-12-14 16:10:49 -0600323However, for Tempest to be able to figure out which endpoints should get REST
324API calls for each service, it needs to know how that project is defined in the
325service catalog. There are three options for each service section to accomplish
Matthew Treinishf96ab3a2015-04-15 19:11:31 -0400326this:
327
Eric Friede0cfc3e2015-12-14 16:10:49 -0600328 #. ``catalog_type``
329 #. ``endpoint_type``
330 #. ``region``
Matthew Treinishf96ab3a2015-04-15 19:11:31 -0400331
Eric Friede0cfc3e2015-12-14 16:10:49 -0600332Setting ``catalog_type`` and ``endpoint_type`` should normally give Tempest
333enough information to determine which endpoint it should pull from the service
334catalog to use for talking to that particular service. However, if your cloud
335has multiple regions available and you need to specify a particular one to use a
336service you can set the ``region`` option in that service's section.
Matthew Treinishf96ab3a2015-04-15 19:11:31 -0400337
338It should also be noted that the default values for these options are set
Eric Friede0cfc3e2015-12-14 16:10:49 -0600339to what devstack uses (which is a de facto standard for service catalog
340entries). So often nothing actually needs to be set on these options to enable
Matthew Treinishf96ab3a2015-04-15 19:11:31 -0400341communication to a particular service. It is only if you are either not using
Eric Friede0cfc3e2015-12-14 16:10:49 -0600342the same ``catalog_type`` as devstack or you want Tempest to talk to a different
Matthew Treinishf96ab3a2015-04-15 19:11:31 -0400343endpoint type instead of publicURL for a service that these need to be changed.
344
ghanshyam571dfac2015-10-30 11:21:28 +0900345.. note::
346
Eric Friede0cfc3e2015-12-14 16:10:49 -0600347 Tempest does not serve all kinds of fancy URLs in the service catalog. The
348 service catalog should be in a standard format (which is going to be
349 standardized at the keystone level).
350 Tempest expects URLs in the Service catalog in the following format:
Masayuki Igawae63cf0f2016-05-25 10:25:21 +0900351
352 * ``http://example.com:1234/<version-info>``
353
ghanshyam571dfac2015-10-30 11:21:28 +0900354 Examples:
Masayuki Igawae63cf0f2016-05-25 10:25:21 +0900355
356 * Good - ``http://example.com:1234/v2.0``
357 * Wouldn’t work - ``http://example.com:1234/xyz/v2.0/``
358 (adding prefix/suffix around version etc)
Matthew Treinishf96ab3a2015-04-15 19:11:31 -0400359
Eric Friede0cfc3e2015-12-14 16:10:49 -0600360Service Feature Configuration
Matthew Treinish3220cad2015-04-15 16:25:48 -0400361-----------------------------
362
Eric Friede0cfc3e2015-12-14 16:10:49 -0600363OpenStack provides its deployers a myriad of different configuration options to
364enable anyone deploying it to create a cloud tailor-made for any individual use
365case. It provides options for several different backend types, databases,
Matthew Treinish3220cad2015-04-15 16:25:48 -0400366message queues, etc. However, the downside to this configurability is that
367certain operations and features aren't supported depending on the configuration.
368These features may or may not be discoverable from the API so the burden is
Eric Friede0cfc3e2015-12-14 16:10:49 -0600369often on the user to figure out what is supported by the cloud they're talking
370to. Besides the obvious interoperability issues with this it also leaves
371Tempest in an interesting situation trying to figure out which tests are
372expected to work. However, Tempest tests do not rely on dynamic API discovery
373for a feature (assuming one exists). Instead Tempest has to be explicitly
374configured as to which optional features are enabled. This is in order to
375prevent bugs in the discovery mechanisms from masking failures.
Matthew Treinish3220cad2015-04-15 16:25:48 -0400376
377The service feature-enabled config sections are how Tempest addresses the
378optional feature question. Each service that has tests for optional features
379contains one of these sections. The only options in it are boolean options
380with the name of a feature which is used. If it is set to false any test which
381depends on that functionality will be skipped. For a complete list of all these
382options refer to the sample config file.
383
384
385API Extensions
386^^^^^^^^^^^^^^
Eric Friede0cfc3e2015-12-14 16:10:49 -0600387The service feature-enabled sections often contain an ``api-extensions`` option
388(or in the case of swift a ``discoverable_apis`` option). This is used to tell
389Tempest which api extensions (or configurable middleware) is used in your
390deployment. It has two valid config states: either it contains a single value
391``all`` (which is the default) which means that every api extension is assumed
Matthew Treinish3220cad2015-04-15 16:25:48 -0400392to be enabled, or it is set to a list of each individual extension that is
393enabled for that service.