e610492537
QA community default test runner is ostestr, and using run_tempest.sh script is no longer recommended. BP replaces run_tempest.sh script with direct ostestr call passing the appropriate parameters. Implements blueprint: implement-ostestr-refstackclient Change-Id: If4ffed70c8320abb4b4c7bfd1b84ca7892272665 |
||
---|---|---|
doc | ||
refstack_client | ||
.gitignore | ||
.gitreview | ||
.testr.conf | ||
LICENSE | ||
README.rst | ||
refstack-client | ||
requirements.txt | ||
setup_env | ||
setup.cfg | ||
setup.py | ||
tempest-additional-requirements.txt | ||
test-requirements.txt | ||
tox.ini |
refstack-client
refstack-client is a command line utility that allows you to execute Tempest test runs based on configurations you specify. When finished running Tempest it can send the passed test data to a RefStack API server.
Environment setup
We've created an "easy button" for Ubuntu, Centos, RHEL and openSuSe.
Make sure you have
git
installedGet the refstack client:
git clone https://github.com/openstack/refstack-client
Go into the refstack-client directory:
cd refstack-client
Run the "easy button" setup:
./setup_env
Options:
a. -c option allows to specify SHA of commit or branch in Tempest repository which will be installed.
b. -t option allows to specify tag in Tempest repository which will be installed. For example: execute
./setup_env -t tags/3
to install Tempest tag-3.c. By default, Tempest will be installed from commit 8d468c8332b1d0d7176c285de4cedfa589a54a23 (May 7, 2016).
Usage
Prepare a tempest configuration file that is customized to your cloud environment.
Note: Use Tempest Pre-Provisioned credentials to provide user test accounts. :
Go into the refstack-client directory:
cd ~/refstack-client
Source to use the correct Python environment:
source .venv/bin/activate
Validate your setup by running a short test:
./refstack-client test -c <Path of the tempest configuration file to use> -v -- --regex tempest.api.identity.admin.v2.test_roles
or :
./refstack-client test -c <Path of the tempest configuration file to use> -v -- --regex tempest.api.identity.v2.test_token
Run tests.
To run the entire API test set:
./refstack-client test -c <Path of the tempest configuration file to use> -v
To run only those tests specified in a DefCore defined test file:
./refstack-client test -c <Path of the tempest configuration file to use> -v --test-list <Path or URL of test list>
For example:
./refstack-client test -c ~/tempest.conf -v --test-list \ "https://refstack.openstack.org/api/v1/guidelines/2016.01/tests?target=platform&type=required&alias=true&flag=false"
This will run only the test cases required by the 2016.01 guidelines that have not been flagged.
Note:
- Adding the
-v
option will show the Tempest test result output. - Adding the
--upload
option will have your test results be uploaded to the default RefStack API server or the server specified by--url
. - Adding the
--test-list
option will allow you to specify the file path or URL of a test list text file. This test list should contain specific test cases that should be tested. Tests lists passed in using this argument will be normalized with the current Tempest evironment to eliminate any attribute mismatches. - Adding the
--url
option will allow you to change where test results should be uploaded. - Adding the
-r
option with a string will prefix the JSON result file with the given string (e.g.-r my-test
will yield a result file like 'my-test-0.json'). - Adding
--
enables you to pass arbitrary arguments to the ostestr runner. After the first--
, all other subsequent arguments will be passed to the ostestr runner as is. This is mainly used for quick verification of the target test cases. (e.g.-- --regex tempest.api.identity.v2.test_token
)
Use
./refstack-client test --help
for the full list of arguments.- Adding the
Upload your results.
If you previously ran a test with refstack-client without the
--upload
option, you can upload your results to a RefStack API server by using the following command:./refstack-client upload <Path of results file>
The results file is a JSON file generated by refstack-client when a test has completed. This is saved in .tempest/.testrepository. When you use the
upload
command, you can also override the RefStack API server uploaded to with the--url
option.Alternatively, you can use the
upload-subunit
command to upload results using an existing subunit file. This requires that you pass in the Keystone endpoint URL for the cloud that was tested to generate the subunit data:./refstack-client upload-subunit --keystone-endpoint http://some.url:5000/v3 <Path of subunit file>
Note:
- Adding
-i <path-to-private-key>
option will upload test results with a digital signature. For signing, refstack-client uses private RSA keys. The OpenSSH format of RSA keys is supported, so you can just use your SSH key '~/.ssh/id-rsa' or generate a new one withssh-keygen -b 4096
. For now, signed test results can be considered private.
- Adding
List uploaded test set.
You can list previously uploaded data from a RefStack API server by using the following command:
./refstack-client list --url <URL of the RefStack API server>
Tempest Hacking
By default, refstack-client installs Tempest into the
.tempest
directory. If you're interested in working with
Tempest directly for debugging or configuration, you can activate a
working Tempest environment by switching to that directory and using the
installed dependencies.
cd .tempest
source ./.venv/bin/activate
and run tests manually withostestr
.
This will make the entire Tempest environment available for you to
run, including the ostestr
and testr
commands.