1df940ebdb
By default, Cinder policy will allow a non-admin owner of a volume to retype a volume. That triggers a call from Cinder to Nova to swap the volume in the guest. The Nova swap volume API, however, is admin-only by default. So this test fails with default policy because Cinder gets a 403 response from Nova when trying to swap the volume on the Nova side. This fixes the problem by using the admin client for initiating the retype. Change-Id: I17e6603c588e3efddcf44ca4e7af6e352490e689 Closes-Bug: #1698224 |
||
---|---|---|
.. | ||
README.rst | ||
__init__.py | ||
manager.py | ||
test_aggregates_basic_ops.py | ||
test_encrypted_cinder_volumes.py | ||
test_minimum_basic.py | ||
test_network_advanced_server_ops.py | ||
test_network_basic_ops.py | ||
test_network_v6.py | ||
test_object_storage_basic_ops.py | ||
test_security_groups_basic_ops.py | ||
test_server_advanced_ops.py | ||
test_server_basic_ops.py | ||
test_server_multinode.py | ||
test_shelve_instance.py | ||
test_snapshot_pattern.py | ||
test_stamp_pattern.py | ||
test_volume_boot_pattern.py | ||
test_volume_migrate_attached.py |
README.rst
Tempest Field Guide to Scenario tests
What are these tests?
Scenario tests are "through path" tests of OpenStack function. Complicated setups where one part might depend on completion of a previous part. They ideally involve the integration between multiple OpenStack services to exercise the touch points between them.
Any scenario test should have a real-life use case. An example would be:
- "As operator I want to start with a blank environment":
- upload a glance image
- deploy a vm from it
- ssh to the guest
- create a snapshot of the vm
Why are these tests in tempest?
This is one of tempests core purposes, testing the integration between projects.
Scope of these tests
Scenario tests should always use the Tempest implementation of the OpenStack API, as we want to ensure that bugs aren't hidden by the official clients.
Tests should be tagged with which services they exercise, as determined by which client libraries are used directly by the test.
Example of a good test
While we are looking for interaction of 2 or more services, be specific in your interactions. A giant "this is my data center" smoke test is hard to debug when it goes wrong.
A flow of interactions between glance and nova, like in the introduction, is a good example. Especially if it involves a repeated interaction when a resource is setup, modified, detached, and then reused later again.