Matthew Treinish | a970d65 | 2015-03-11 15:39:24 -0400 | [diff] [blame] | 1 | .. _tempest-configuration: |
| 2 | |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 3 | Tempest Configuration Guide |
| 4 | =========================== |
| 5 | |
Matthew Treinish | f640f66 | 2015-03-11 15:13:30 -0400 | [diff] [blame] | 6 | This guide is a starting point for configuring tempest. It aims to elaborate |
| 7 | on and explain some of the mandatory and common configuration settings and how |
| 8 | they are used in conjunction. The source of truth on each option is the sample |
Matthew Treinish | f45ba2e | 2015-08-24 15:05:01 -0400 | [diff] [blame] | 9 | config file which explains the purpose of each individual option. You can see |
| 10 | the sample config file here: :ref:`tempest-sampleconf` |
Matthew Treinish | f640f66 | 2015-03-11 15:13:30 -0400 | [diff] [blame] | 11 | |
| 12 | Lock Path |
| 13 | --------- |
| 14 | |
| 15 | There are some tests and operations inside of tempest that need to be |
| 16 | externally locked when running in parallel to prevent them from running at |
| 17 | the same time. This is a mandatory step for configuring tempest and is still |
| 18 | needed even when running serially. All that is needed to do this is: |
| 19 | |
| 20 | #. Set the lock_path option in the oslo_concurrency group |
| 21 | |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 22 | Auth/Credentials |
| 23 | ---------------- |
| 24 | |
| 25 | Tempest currently has 2 different ways in configuration to provide credentials |
| 26 | to use when running tempest. One is a traditional set of configuration options |
| 27 | in the tempest.conf file. These options are in the identity section and let you |
Toru Tanami | 32f4518 | 2015-08-20 05:24:50 +0000 | [diff] [blame] | 28 | specify a regular user, a global admin user, and an alternate user set of |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 29 | credentials. (which consist of a username, password, and project/tenant name) |
| 30 | These options should be clearly labelled in the sample config file in the |
| 31 | identity section. |
| 32 | |
| 33 | The other method to provide credentials is using the accounts.yaml file. This |
| 34 | file is used to specify an arbitrary number of users available to run tests |
| 35 | with. You can specify the location of the file in the |
| 36 | auth section in the tempest.conf file. To see the specific format used in |
| 37 | the file please refer to the accounts.yaml.sample file included in tempest. |
| 38 | Currently users that are specified in the accounts.yaml file are assumed to |
| 39 | have the same set of roles which can be used for executing all the tests you |
| 40 | are running. This will be addressed in the future, but is a current limitation. |
| 41 | Eventually the config options for providing credentials to tempest will be |
| 42 | deprecated and removed in favor of the accounts.yaml file. |
| 43 | |
Matthew Treinish | 7909e12 | 2015-04-15 15:43:50 -0400 | [diff] [blame] | 44 | Keystone Connection Info |
| 45 | ^^^^^^^^^^^^^^^^^^^^^^^^ |
| 46 | In order for tempest to be able to talk to your OpenStack deployment you need |
| 47 | to provide it with information about how it communicates with keystone. |
| 48 | This involves configuring the following options in the identity section: |
| 49 | |
| 50 | #. auth_version |
| 51 | #. uri |
| 52 | #. uri_v3 |
| 53 | |
| 54 | The *auth_version* option is used to tell tempest whether it should be using |
| 55 | keystone's v2 or v3 api for communicating with keystone. (except for the |
| 56 | identity api tests which will test a specific version) The 2 uri options are |
| 57 | used to tell tempest the url of the keystone endpoint. The *uri* option is used |
| 58 | for keystone v2 request and *uri_v3* is used for keystone v3. You want to ensure |
| 59 | that which ever version you set for *auth_version* has its uri option defined. |
| 60 | |
| 61 | |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 62 | Credential Provider Mechanisms |
| 63 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 64 | |
| 65 | Tempest currently also has 3 different internal methods for providing |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 66 | authentication to tests. Dynamic credentials, locking test accounts, and |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 67 | non-locking test accounts. Depending on which one is in use the configuration |
| 68 | of tempest is slightly different. |
| 69 | |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 70 | Dynamic Credentials |
| 71 | """"""""""""""""""" |
| 72 | Dynamic Credentials (formerly known as Tenant isolation) was originally created |
| 73 | to enable running tempest in parallel. |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 74 | For each test class it creates a unique set of user credentials to use for the |
| 75 | tests in the class. It can create up to 3 sets of username, password, and |
| 76 | tenant/project names for a primary user, an admin user, and an alternate user. |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 77 | To enable and use dynamic credentials you only need to configure 2 things: |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 78 | |
| 79 | #. A set of admin credentials with permissions to create users and |
Matthew Treinish | 16cf1e5 | 2015-08-11 10:39:23 -0400 | [diff] [blame] | 80 | tenants/projects. This is specified in the auth section with the |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 81 | admin_username, admin_tenant_name, admin_domain_name and admin_password |
Matthew Treinish | 16cf1e5 | 2015-08-11 10:39:23 -0400 | [diff] [blame] | 82 | options |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 83 | #. To enable dynamic_creds in the auth section with the |
| 84 | use_dynamic_credentials option. |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 85 | |
Matthew Treinish | 0fd69e4 | 2015-03-06 00:40:51 -0500 | [diff] [blame] | 86 | This is also the currently the default credential provider enabled by tempest, |
| 87 | due to it's common use and ease of configuration. |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 88 | |
Matthew Treinish | 4fae472 | 2015-04-16 21:03:54 -0400 | [diff] [blame] | 89 | It is worth pointing out that depending on your cloud configuration you might |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 90 | need to assign a role to each of the users created by Tempest's dynamic |
| 91 | credentials. |
Matthew Treinish | 4fae472 | 2015-04-16 21:03:54 -0400 | [diff] [blame] | 92 | This can be set using the *tempest_roles* option. It takes in a list of role |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 93 | names each of which will be assigned to each of the users created by dynamic |
| 94 | credentials. This option will not have any effect when set and tempest is not |
| 95 | configured to use dynamic credentials. |
Matthew Treinish | 4fae472 | 2015-04-16 21:03:54 -0400 | [diff] [blame] | 96 | |
| 97 | |
Matthew Treinish | 9329985 | 2015-04-24 09:58:18 -0400 | [diff] [blame] | 98 | Locking Test Accounts (aka accounts.yaml or accounts file) |
| 99 | """""""""""""""""""""""""""""""""""""""""""""""""""""""""" |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 100 | For a long time using dynamic credentials was the only method available if you |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 101 | wanted to enable parallel execution of tempest tests. However this was |
| 102 | insufficient for certain use cases because of the admin credentials requirement |
| 103 | to create the credential sets on demand. To get around that the accounts.yaml |
| 104 | file was introduced and with that a new internal credential provider to enable |
| 105 | using the list of credentials instead of creating them on demand. With locking |
| 106 | test accounts each test class will reserve a set of credentials from the |
| 107 | accounts.yaml before executing any of its tests so that each class is isolated |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 108 | like with dynamic credentials. |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 109 | |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 110 | To enable and use locking test accounts you need do a few things: |
| 111 | |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 112 | #. Create a accounts.yaml file which contains the set of pre-existing |
| 113 | credentials to use for testing. To make sure you don't have a credentials |
| 114 | starvation issue when running in parallel make sure you have at least 2 |
Matthew Treinish | fc7cd8f | 2015-03-30 11:51:55 -0400 | [diff] [blame] | 115 | times the number of worker processes you are using to execute tempest |
| 116 | available in the file. (if running serially the worker count is 1) |
Matthew Treinish | 0fd69e4 | 2015-03-06 00:40:51 -0500 | [diff] [blame] | 117 | |
| 118 | You can check the sample file packaged in tempest for the yaml format |
liuchenhong | aa4aa69 | 2015-06-10 12:18:42 +0800 | [diff] [blame] | 119 | #. Provide tempest with the location of your accounts.yaml file with the |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 120 | test_accounts_file option in the auth section |
| 121 | |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 122 | #. Set use_dynamic_credentials = False in the auth group |
Fei Long Wang | 7fee787 | 2015-05-12 11:36:49 +1200 | [diff] [blame] | 123 | |
Matthew Treinish | 9329985 | 2015-04-24 09:58:18 -0400 | [diff] [blame] | 124 | It is worth pointing out that each set of credentials in the accounts.yaml |
| 125 | should have a unique tenant. This is required to provide proper isolation |
| 126 | to the tests using the credentials, and failure to do this will likely cause |
| 127 | unexpected failures in some tests. |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 128 | |
Matthew Treinish | 9329985 | 2015-04-24 09:58:18 -0400 | [diff] [blame] | 129 | |
| 130 | Non-locking test accounts (aka credentials config options) |
| 131 | """""""""""""""""""""""""""""""""""""""""""""""""""""""""" |
Matthew Treinish | 16cf1e5 | 2015-08-11 10:39:23 -0400 | [diff] [blame] | 132 | **Starting in the Liberty release this mechanism was deprecated and will be |
| 133 | removed in a future release** |
| 134 | |
Matthew Treinish | 5709213 | 2015-04-21 14:21:35 -0400 | [diff] [blame] | 135 | When Tempest was refactored to allow for locking test accounts, the original |
| 136 | non-tenant isolated case was converted to internally work similarly to the |
| 137 | accounts.yaml file. This mechanism was then called the non-locking test accounts |
| 138 | provider. To use the non-locking test accounts provider you can specify the sets |
| 139 | of credentials in the configuration file like detailed above with following 9 |
| 140 | options in the identity section: |
Matthew Treinish | bc1b15b | 2015-02-20 15:56:07 -0500 | [diff] [blame] | 141 | |
| 142 | #. username |
| 143 | #. password |
| 144 | #. tenant_name |
| 145 | #. admin_username |
| 146 | #. admin_password |
| 147 | #. admin_tenant_name |
| 148 | #. alt_username |
| 149 | #. alt_password |
| 150 | #. alt_tenant_name |
| 151 | |
Atsushi SAKAI | 0a183b8 | 2015-07-28 21:52:17 +0900 | [diff] [blame] | 152 | And in the auth section: |
Fei Long Wang | 7fee787 | 2015-05-12 11:36:49 +1200 | [diff] [blame] | 153 | |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 154 | #. use_dynamic_credentials = False |
Fei Long Wang | 7fee787 | 2015-05-12 11:36:49 +1200 | [diff] [blame] | 155 | #. comment out 'test_accounts_file' or keep it as empty |
| 156 | |
Matthew Treinish | 5709213 | 2015-04-21 14:21:35 -0400 | [diff] [blame] | 157 | It only makes sense to use it if parallel execution isn't needed, since tempest |
| 158 | won't be able to properly isolate tests using this. Additionally, using the |
| 159 | traditional config options for credentials is not able to provide credentials to |
| 160 | tests which requires specific roles on accounts. This is because the config |
| 161 | options do not give sufficient flexibility to describe the roles assigned to a |
| 162 | user for running the tests. There are additional limitations with regard to |
| 163 | network configuration when using this credential provider mechanism, see the |
| 164 | `Networking`_ section below. |
Matthew Treinish | 2b7f048 | 2015-04-10 12:49:01 -0400 | [diff] [blame] | 165 | |
Matthew Treinish | 7909e12 | 2015-04-15 15:43:50 -0400 | [diff] [blame] | 166 | Compute |
| 167 | ------- |
| 168 | |
| 169 | Flavors |
| 170 | ^^^^^^^ |
| 171 | For tempest to be able to create servers you need to specify flavors that it |
| 172 | can use to boot the servers with. There are 2 options in the tempest config |
| 173 | for doing this: |
| 174 | |
| 175 | #. flavor_ref |
| 176 | #. flavor_ref_alt |
| 177 | |
| 178 | Both of these options are in the compute section of the config file and take |
| 179 | in the flavor id (not the name) from nova. The *flavor_ref* option is what will |
| 180 | be used for booting almost all of the guests, *flavor_ref_alt* is only used in |
| 181 | tests where 2 different sized servers are required. (for example a resize test) |
| 182 | |
| 183 | Using a smaller flavor is generally recommended, when larger flavors are used |
| 184 | the extra time required to bring up servers will likely affect total run time |
| 185 | and probably require tweaking timeout values to ensure tests have ample time to |
| 186 | finish. |
| 187 | |
| 188 | Images |
| 189 | ^^^^^^ |
| 190 | Just like with flavors, tempest needs to know which images to use for booting |
| 191 | servers. There are 2 options in the compute section just like with flavors: |
| 192 | |
| 193 | #. image_ref |
| 194 | #. image_ref_alt |
| 195 | |
| 196 | Both options are expecting an image id (not name) from nova. The *image_ref* |
Brandon Palm | 304bfdd | 2015-08-18 10:57:21 -0500 | [diff] [blame] | 197 | option is what will be used for booting the majority of servers in tempest. |
Matthew Treinish | 7909e12 | 2015-04-15 15:43:50 -0400 | [diff] [blame] | 198 | *image_ref_alt* is used for tests that require 2 images such as rebuild. If 2 |
| 199 | images are not available you can set both options to the same image_ref and |
| 200 | those tests will be skipped. |
| 201 | |
| 202 | There are also options in the scenario section for images: |
| 203 | |
| 204 | #. img_file |
| 205 | #. img_dir |
| 206 | #. aki_img_file |
| 207 | #. ari_img_file |
| 208 | #. ami_img_file |
| 209 | #. img_container_format |
| 210 | #. img_disk_format |
| 211 | |
| 212 | however unlike the other image options these are used for a very small subset |
| 213 | of scenario tests which are uploading an image. These options are used to tell |
| 214 | tempest where an image file is located and describe it's metadata for when it's |
| 215 | uploaded. |
| 216 | |
| 217 | The behavior of these options is a bit convoluted (which will likely be fixed |
| 218 | in future versions). You first need to specify *img_dir*, which is the directory |
| 219 | tempest will look for the image files in. First it will check if the filename |
| 220 | set for *img_file* could be found in *img_dir*. If it is found then the |
| 221 | *img_container_format* and *img_disk_format* options are used to upload that |
| 222 | image to glance. However if it's not found tempest will look for the 3 uec image |
| 223 | file name options as a fallback. If neither is found the tests requiring an |
| 224 | image to upload will fail. |
| 225 | |
| 226 | It is worth pointing out that using `cirros`_ is a very good choice for running |
| 227 | tempest. It's what is used for upstream testing, they boot quickly and have a |
| 228 | small footprint. |
| 229 | |
| 230 | .. _cirros: https://launchpad.net/cirros |
| 231 | |
Matthew Treinish | 2b7f048 | 2015-04-10 12:49:01 -0400 | [diff] [blame] | 232 | Networking |
| 233 | ---------- |
| 234 | OpenStack has a myriad of different networking configurations possible and |
| 235 | depending on which of the 2 network backends, nova-network or neutron, you are |
| 236 | using things can vary drastically. Due to this complexity Tempest has to provide |
| 237 | a certain level of flexibility in it's configuration to ensure it will work |
| 238 | against any cloud. This ends up causing a large number of permutations in |
| 239 | Tempest's config around network configuration. |
| 240 | |
| 241 | |
| 242 | Enabling Remote Access to Created Servers |
| 243 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 244 | When Tempest creates servers for testing, some tests require being able to |
| 245 | connect those servers. Depending on the configuration of the cloud, the methods |
| 246 | for doing this can be different. In certain configurations it is required to |
| 247 | specify a single network with server create calls. Accordingly, Tempest provides |
| 248 | a few different methods for providing this information in configuration to try |
| 249 | and ensure that regardless of the clouds configuration it'll still be able to |
| 250 | run. This section covers the different methods of configuring Tempest to provide |
| 251 | a network when creating servers. |
| 252 | |
| 253 | Fixed Network Name |
| 254 | """""""""""""""""" |
| 255 | This is the simplest method of specifying how networks should be used. You can |
| 256 | just specify a single network name/label to use for all server creations. The |
| 257 | limitation with this is that all tenants/projects and users must be able to see |
| 258 | that network name/label if they were to perform a network list and be able to |
| 259 | use it. |
| 260 | |
| 261 | If no network name is assigned in the config file and none of the below |
| 262 | alternatives are used, then Tempest will not specify a network on server |
| 263 | creations, which depending on the cloud configuration might prevent them from |
| 264 | booting. |
| 265 | |
| 266 | To set a fixed network name simply do: |
| 267 | |
| 268 | #. Set the fixed_network_name option in the compute group |
| 269 | |
| 270 | In the case that the configured fixed network name can not be found by a user |
| 271 | network list call, it will be treated like one was not provided except that a |
| 272 | warning will be logged stating that it couldn't be found. |
| 273 | |
| 274 | |
| 275 | Accounts File |
| 276 | """"""""""""" |
| 277 | If you are using an accounts file to provide credentials for running Tempest |
| 278 | then you can leverage it to also specify which network should be used with |
| 279 | server creations on a per tenant/project and user pair basis. This provides |
| 280 | the necessary flexibility to work with more intricate networking configurations |
| 281 | by enabling the user to specify exactly which network to use for which |
| 282 | tenants/projects. You can refer to the accounts.yaml sample file included in |
| 283 | the tempest repo for the syntax around specifying networks in the file. |
| 284 | |
| 285 | However, specifying a network is not required when using an accounts file. If |
| 286 | one is not specified you can use a fixed network name to specify the network to |
| 287 | use when creating servers just as without an accounts file. However, any network |
| 288 | specified in the accounts file will take precedence over the fixed network name |
| 289 | provided. If no network is provided in the accounts file and a fixed network |
| 290 | name is not set then no network will be included in create server requests. |
| 291 | |
| 292 | If a fixed network is provided and the accounts.yaml file also contains networks |
| 293 | this has the benefit of enabling a couple more tests which require a static |
| 294 | network to perform operations like server lists with a network filter. If a |
| 295 | fixed network name is not provided these tests are skipped. Additionally, if a |
| 296 | fixed network name is provided it will serve as a fallback in case of a |
| 297 | misconfiguration or a missing network in the accounts file. |
| 298 | |
| 299 | |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 300 | With Dynamic Credentials |
| 301 | """""""""""""""""""""""" |
| 302 | With dynamic credentials enabled and using nova-network then nothing changes. |
| 303 | Your only option for configuration is to either set a fixed network name or not. |
Matthew Treinish | 2b7f048 | 2015-04-10 12:49:01 -0400 | [diff] [blame] | 304 | However, in most cases it shouldn't matter because nova-network should have no |
| 305 | problem booting a server with multiple networks. If this is not the case for |
| 306 | your cloud then using an accounts file is recommended because it provides the |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 307 | necessary flexibility to describe your configuration. Dynamic credentials is not |
Matthew Treinish | 2b7f048 | 2015-04-10 12:49:01 -0400 | [diff] [blame] | 308 | able to dynamically allocate things as necessary if neutron is not enabled. |
| 309 | |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 310 | With neutron and dynamic credentials enabled there should not be any additional |
Matthew Treinish | 2b7f048 | 2015-04-10 12:49:01 -0400 | [diff] [blame] | 311 | configuration necessary to enable Tempest to create servers with working |
| 312 | networking, assuming you have properly configured the network section to work |
| 313 | for your cloud. Tempest will dynamically create the neutron resources necessary |
| 314 | to enable using servers with that network. Also, just as with the accounts |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 315 | file, if you specify a fixed network name while using neutron and dynamic |
| 316 | credentials it will enable running tests which require a static network and it |
Matthew Treinish | 2b7f048 | 2015-04-10 12:49:01 -0400 | [diff] [blame] | 317 | will additionally be used as a fallback for server creation. However, unlike |
| 318 | accounts.yaml this should never be triggered. |
Matthew Treinish | 3220cad | 2015-04-15 16:25:48 -0400 | [diff] [blame] | 319 | |
Andrea Frittoli (andreaf) | 17209bb | 2015-05-22 10:16:57 -0700 | [diff] [blame] | 320 | However, there is an option *create_isolated_networks* to disable dynamic |
| 321 | credentials's automatic provisioning of network resources. If this option is |
Matthew Treinish | 2219d38 | 2015-04-24 10:33:04 -0400 | [diff] [blame] | 322 | used you will have to either rely on there only being a single/default network |
| 323 | available for the server creation, or use *fixed_network_name* to inform |
| 324 | Tempest which network to use. |
| 325 | |
Matthew Treinish | f96ab3a | 2015-04-15 19:11:31 -0400 | [diff] [blame] | 326 | Configuring Available Services |
| 327 | ------------------------------ |
| 328 | OpenStack is really a constellation of several different projects which |
| 329 | are running together to create a cloud. However which projects you're running |
| 330 | is not set in stone, and which services are running is up to the deployer. |
| 331 | Tempest however needs to know which services are available so it can figure |
| 332 | out which tests it is able to run and certain setup steps which differ based |
| 333 | on the available services. |
| 334 | |
| 335 | The *service_available* section of the config file is used to set which |
| 336 | services are available. It contains a boolean option for each service (except |
| 337 | for keystone which is a hard requirement) set it to True if the service is |
| 338 | available or False if it is not. |
| 339 | |
| 340 | Service Catalog |
| 341 | ^^^^^^^^^^^^^^^ |
| 342 | Each project which has its own REST API contains an entry in the service |
| 343 | catalog. Like most things in OpenStack this is also completely configurable. |
| 344 | However, for tempest to be able to figure out the endpoints to send REST API |
| 345 | calls for each service to it needs to know how that project is defined in the |
| 346 | service catalog. There are 3 options for each service section to accomplish |
| 347 | this: |
| 348 | |
| 349 | #. catalog_type |
| 350 | #. endpoint_type |
| 351 | #. region |
| 352 | |
| 353 | Setting *catalog_type* and *endpoint_type* should normally give Tempest enough |
| 354 | information to determine which endpoint it should pull from the service |
| 355 | catalog to use for talking to that particular service. However, if you're cloud |
| 356 | has multiple regions available and you need to specify a particular one to use |
| 357 | a service you can set the *region* option in that service's section. |
| 358 | |
| 359 | It should also be noted that the default values for these options are set |
| 360 | to what devstack uses. (which is a de facto standard for service catalog |
| 361 | entries) So often nothing actually needs to be set on these options to enable |
| 362 | communication to a particular service. It is only if you are either not using |
| 363 | the same *catalog_type* as devstack or you want Tempest to talk to a different |
| 364 | endpoint type instead of publicURL for a service that these need to be changed. |
| 365 | |
| 366 | |
Matthew Treinish | 3220cad | 2015-04-15 16:25:48 -0400 | [diff] [blame] | 367 | Service feature configuration |
| 368 | ----------------------------- |
| 369 | |
| 370 | OpenStack provides its deployers a myriad of different configuration options |
| 371 | to enable anyone deploying it to create a cloud tailor-made for any individual |
| 372 | use case. It provides options for several different backend type, databases, |
| 373 | message queues, etc. However, the downside to this configurability is that |
| 374 | certain operations and features aren't supported depending on the configuration. |
| 375 | These features may or may not be discoverable from the API so the burden is |
| 376 | often on the user to figure out what the cloud they're talking to supports. |
| 377 | Besides the obvious interoperability issues with this it also leaves Tempest |
| 378 | in an interesting situation trying to figure out which tests are expected to |
| 379 | work. However, Tempest tests do not rely on dynamic api discovery for a feature |
| 380 | (assuming one exists). Instead Tempest has to be explicitly configured as to |
| 381 | which optional features are enabled. This is in order to prevent bugs in the |
| 382 | discovery mechanisms from masking failures. |
| 383 | |
| 384 | The service feature-enabled config sections are how Tempest addresses the |
| 385 | optional feature question. Each service that has tests for optional features |
| 386 | contains one of these sections. The only options in it are boolean options |
| 387 | with the name of a feature which is used. If it is set to false any test which |
| 388 | depends on that functionality will be skipped. For a complete list of all these |
| 389 | options refer to the sample config file. |
| 390 | |
| 391 | |
| 392 | API Extensions |
| 393 | ^^^^^^^^^^^^^^ |
| 394 | The service feature-enabled sections often contain an *api-extensions* option |
| 395 | (or in the case of swift a *discoverable_apis* option) this is used to tell |
| 396 | tempest which api extensions (or configurable middleware) is used in your |
| 397 | deployment. It has 2 valid config states, either it contains a single value |
| 398 | "all" (which is the default) which means that every api extension is assumed |
| 399 | to be enabled, or it is set to a list of each individual extension that is |
| 400 | enabled for that service. |