mirror of
https://github.com/ansible-collections/hetzner.hcloud
synced 2024-11-14 08:17:09 +00:00
8b24cf2522
##### SUMMARY - Implement the new testing framework (prepare.yml/cleanup.yml #239) - Fix some uncovered test scenarios (related to #298). - Structure all the *_info tests using the following structure: ``` gather all [gather all with custom options...] gather all in check mode gather with id gather with name gather with labels [gather with custom option...] ```
2 KiB
2 KiB
Integration tests
This document provides information to work with the integration tests.
Guidelines
A set of guidelines to follow when writing integrations tests.
Prepare and cleanup
The integration tests use a small testing framework that helps to set up and teardown any resources needed or generated by the tests. This small testing framework is located in the tests/integration/common
directory. The files within the common
directory are then duplicated and kept in sync in all the integration tests targets (tests/integration/targets/hcloud_*
).
- Use a
tasks/prepare.yml
file to set up resources needed during the tests. - Use a
tasks/cleanup.yml
file to teardown resources from thetasts/prepare.yml
tasks and the resources generated by the tests. - Use a
tasks/test.yml
file to defines your tests. - You may explode the tests into multiple
tasks/test-*.yml
files and import them in thetasks/test.yml
file. - The
tasks/cleanup.yml
file cannot use variables present in thetasks/prepare.yml
file because cleanup should also run before the prepare tasks.
Naming convention
The integration tests handle a lot of different variables, names, identifier. To reduce this complexity, make sure to use the following naming conventions:
- Any test resources MUST be registered using the
test_<resource>
variable name (e.g.test_server
ortest_floating_ip
) and MUST be created and cleaned in thetasks/prepare.yml
andtasks/cleanup.yml
. The scope of this variable is the entire target. - In
tasks/prepare.yml
, tasks names MUST start with:Create test_<resource>
(e.g.Create test_server
orCreate test_floating_ip
) - In
tasks/cleanup.yml
, tasks names MUST start with:Cleanup test_<resource>
(e.g.Cleanup test_server
orCleanup test_floating_ip
) - Any fact starting with
_
is scoped to the current file and MUST NOT be used outside of it. - Any test result MUST be registered using the
result
variable name unless it is required in a future test, in that case it MUST use the<resource>
variable name as prefix.