blob: f772aa3adca6e89ca8c9b927b13a1e65eb1e5a15 [file] [log] [blame]
Matthew Treinishbc1b15b2015-02-20 15:56:07 -05001Tempest Configuration Guide
2===========================
3
4Auth/Credentials
5----------------
6
7Tempest currently has 2 different ways in configuration to provide credentials
8to use when running tempest. One is a traditional set of configuration options
9in the tempest.conf file. These options are in the identity section and let you
10specify a regular user, a global admin user, and a alternate user set of
11credentials. (which consist of a username, password, and project/tenant name)
12These options should be clearly labelled in the sample config file in the
13identity section.
14
15The other method to provide credentials is using the accounts.yaml file. This
16file is used to specify an arbitrary number of users available to run tests
17with. You can specify the location of the file in the
18auth section in the tempest.conf file. To see the specific format used in
19the file please refer to the accounts.yaml.sample file included in tempest.
20Currently users that are specified in the accounts.yaml file are assumed to
21have the same set of roles which can be used for executing all the tests you
22are running. This will be addressed in the future, but is a current limitation.
23Eventually the config options for providing credentials to tempest will be
24deprecated and removed in favor of the accounts.yaml file.
25
26Credential Provider Mechanisms
27^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
28
29Tempest currently also has 3 different internal methods for providing
30authentication to tests. Tenant isolation, locking test accounts, and
31non-locking test accounts. Depending on which one is in use the configuration
32of tempest is slightly different.
33
34Tenant Isolation
35""""""""""""""""
36Tenant isolation was originally create to enable running tempest in parallel.
37For each test class it creates a unique set of user credentials to use for the
38tests in the class. It can create up to 3 sets of username, password, and
39tenant/project names for a primary user, an admin user, and an alternate user.
40To enable and use tenant isolation you only need to configure 2 things:
41
42 #. A set of admin credentials with permissions to create users and
43 tenants/projects. This is specified in the identity section with the
44 admin_username, admin_tenant_name, and admin_password options
45 #. To enable tenant_isolation in the auth section with the
46 allow_tenant_isolation option.
47
Matthew Treinish0fd69e42015-03-06 00:40:51 -050048This is also the currently the default credential provider enabled by tempest,
49due to it's common use and ease of configuration.
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050050
51Locking Test Accounts
52"""""""""""""""""""""
53For a long time using tenant isolation was the only method available if you
54wanted to enable parallel execution of tempest tests. However this was
55insufficient for certain use cases because of the admin credentials requirement
56to create the credential sets on demand. To get around that the accounts.yaml
57file was introduced and with that a new internal credential provider to enable
58using the list of credentials instead of creating them on demand. With locking
59test accounts each test class will reserve a set of credentials from the
60accounts.yaml before executing any of its tests so that each class is isolated
61like in tenant isolation.
62
Matthew Treinish0fd69e42015-03-06 00:40:51 -050063Currently, this mechanism has some limitations, mostly around networking. The
64locking test accounts provider will only work with a single flat network as
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050065the default for each tenant/project. If another network configuration is used
66in your cloud you might face unexpected failures.
67
68To enable and use locking test accounts you need do a few things:
69
70 #. Enable the locking test account provider with the
71 locking_credentials_provider option in the auth section
72 #. Create a accounts.yaml file which contains the set of pre-existing
73 credentials to use for testing. To make sure you don't have a credentials
74 starvation issue when running in parallel make sure you have at least 2
75 times the number of parallel workers you are using to execute tempest
76 available in the file.
Matthew Treinish0fd69e42015-03-06 00:40:51 -050077
78 You can check the sample file packaged in tempest for the yaml format
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050079 #. Provide tempest with the location of you accounts.yaml file with the
80 test_accounts_file option in the auth section
81
82
83Non-locking test accounts
84"""""""""""""""""""""""""
85When tempest was refactored to allow for locking test accounts, the original
86non-tenant isolated case was converted to support the new accounts.yaml file.
87This mechanism is the non-locking test accounts provider. It only makes sense
88to use it if parallel execution isn't needed. If the role restrictions were too
89limiting with the locking accounts provider and tenant isolation is not wanted
90then you can use the non-locking test accounts credential provider without the
Matthew Treinish0fd69e42015-03-06 00:40:51 -050091accounts.yaml file.
Matthew Treinishbc1b15b2015-02-20 15:56:07 -050092
93To use the non-locking test accounts provider you have 2 ways to configure it.
94First you can specify the sets of credentials in the configuration file like
95detailed above with following 9 options in the identity section:
96
97 #. username
98 #. password
99 #. tenant_name
100 #. admin_username
101 #. admin_password
102 #. admin_tenant_name
103 #. alt_username
104 #. alt_password
105 #. alt_tenant_name
106
Matthew Treinish0fd69e42015-03-06 00:40:51 -0500107The only restriction with using the traditional config options for credentials
108is that if a test requires specific roles on accounts these tests can not be
109run. This is because the config options do not give sufficient flexibility to
110describe the roles assigned to a user for running the tests.
Matthew Treinishbc1b15b2015-02-20 15:56:07 -0500111
112You also can use the accounts.yaml file to specify the credentials used for
113testing. This will just allocate them serially so you only need to provide
114a pair of credentials. Do note that all the restrictions associated with
Matthew Treinish0fd69e42015-03-06 00:40:51 -0500115locking test accounts applies to using the accounts.yaml file this way too,
116except since you can't run in parallel only 2 of each type of credential is
117required to run. However, the limitation on tests which require specific roles
118does not apply here.
119
Matthew Treinishbc1b15b2015-02-20 15:56:07 -0500120The procedure for doing this is very similar to with the locking accounts
121provider just don't set the locking_credentials_provider to true and you
122only should need a single pair of credentials.