mirror of
https://github.com/ansible-collections/hetzner.hcloud.git
synced 2026-02-04 08:01:49 +00:00
SUMMARY Use the new testing framework for the load_balancer_service integration tests. Depends on #545 |
||
|---|---|---|
| .. | ||
| common | ||
| targets | ||
| cloud-config-hcloud.ini.in | ||
| README.md | ||
| requirements.txt | ||
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.ymlfile to set up resources needed during the tests. - Use a
tasks/cleanup.ymlfile to teardown resources from thetasts/prepare.ymltasks and the resources generated by the tests. - Use a
tasks/test.ymlfile to defines your tests. - You may explode the tests into multiple
tasks/test-*.ymlfiles and import them in thetasks/test.ymlfile. - The
tasks/cleanup.ymlfile cannot use variables present in thetasks/prepare.ymlfile 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_serverortest_floating_ip) and MUST be created and cleaned in thetasks/prepare.ymlandtasks/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_serverorCreate test_floating_ip) - In
tasks/cleanup.yml, tasks names MUST start with:Cleanup test_<resource>(e.g.Cleanup test_serverorCleanup 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
resultvariable name unless it is required in a future test, in that case it MUST use the<resource>variable name as prefix.