No description
Find a file
Jonas L 8a6157e8b2
feat: vendor hcloud python dependency (#244)
* chore: ignore venv directories

* chore: ignore integration test generated inventory

* feat: vendor hcloud package

* import https://github.com/hetznercloud/hcloud-python

* use vendored hcloud in modules

* update integration test requirements

* make vendor script self contained

* chore: add  check-hcloud-vendor pre-commit hook

* pin hcloud version to v.1.24.0

* move vendored __version__.py file to _version.py

* update comment about galaxy-importer filename lint
2023-07-11 11:15:08 +02:00
.azure-pipelines feat: drop support for ansible-core 2.12 (#240) 2023-07-05 09:11:47 +02:00
.github/workflows chore: add antsibull-changelog lint pre-commit hook (#247) 2023-07-04 09:30:37 +02:00
changelogs feat: vendor hcloud python dependency (#244) 2023-07-11 11:15:08 +02:00
meta feat: remove deprecated facts modules (#251) 2023-07-05 09:32:03 +02:00
plugins feat: vendor hcloud python dependency (#244) 2023-07-11 11:15:08 +02:00
scripts feat: vendor hcloud python dependency (#244) 2023-07-11 11:15:08 +02:00
tests feat: vendor hcloud python dependency (#244) 2023-07-11 11:15:08 +02:00
.gitignore feat: vendor hcloud python dependency (#244) 2023-07-11 11:15:08 +02:00
.gitlab-ci.yml feat: drop support for ansible-core 2.12 (#240) 2023-07-05 09:11:47 +02:00
.pre-commit-config.yaml feat: vendor hcloud python dependency (#244) 2023-07-11 11:15:08 +02:00
CHANGELOG.rst chore: prepare v1.15.0 (#248) 2023-07-04 15:41:21 +02:00
COPYING refactor: prefer true/false over yes/no (#226) 2023-06-21 10:49:54 +02:00
galaxy.yml chore: prepare v1.15.0 (#248) 2023-07-04 15:41:21 +02:00
Makefile feat: vendor hcloud python dependency (#244) 2023-07-11 11:15:08 +02:00
pyproject.toml chore: setup pre-commit (#234) 2023-06-27 11:50:13 +02:00
README.md docs: add more details to release process (#249) 2023-07-04 11:52:16 +02:00

Build Status Codecov

Ansible Collection: hetzner.hcloud

Ansible Hetzner Cloud Collection for controlling your Hetzner Cloud Resources.

Python version compatibility

This collection depends on the hcloud library. Due to the hcloud Python Support Policy this collection requires Python 3.7 or greater.

Release notes

See here.

Documentation

The documentation for all modules are available through ansible-doc.

Sample: ansible-doc hetzner.hcloud.hcloud_server shows the documentation for the hcloud_server module.

For all modules that were part of Ansible directly (before Ansible 2.11) we also have the documentation published in the Ansible documentation: https://docs.ansible.com/ansible/latest/collections/hetzner/hcloud/

Development

Requirements

You should place the collection (clone the repository) into the Ansible collection path. Normally this is ~/.ansible/collections/ansible_collections/<namespace>/<collection, so for our collection it would be: ~/.ansible/collections/ansible_collections/hetzner/hcloud.

git clone git@github.com:ansible-collections/hetzner.hcloud.git ~/.ansible/collections/ansible_collections/hetzner/hcloud

After this you just need ansible installed.

Testing

Testing is done via ansible-test. Make sure to have a cloud-config-hcloud.ini file in tests/integration which contains the hcloud API token:

[default]
hcloud_api_token=<token>

After this you should be able to use ansible-test integration to perform the integration tests for a specific module. Sample:

ansible-test integration --color --local  -vvv hcloud_server // Executed all integration tests for hcloud_server module

Releasing a new version

  1. Make sure your local main branch is in a clean state and is up to date.
  2. Define a new version:
    export HCLOUD_VERSION=1.15.0
    
  3. Create a release branch:
    git checkout -b "release-$HCLOUD_VERSION"
    
  4. Generate the changelog for the new version, it should remove all fragments and change the changelogs/changelog.yaml and CHANGELOG.rst:
    antsibull-changelog release --version "$HCLOUD_VERSION"
    git add changelogs/changelog.yaml changelogs/fragments CHANGELOG.rst
    
  5. Update the version in the ansible galaxy metadata file:
    sed -i "s/^version: .*/version: $HCLOUD_VERSION/" galaxy.yml
    git add galaxy.yml
    
  6. Commit the changes:
    git commit -m "chore: prepare v$HCLOUD_VERSION"
    
  7. Push the changes to Github, open a Pull Request and follow the process to get the PR merged into main.
  8. Once the PR is merged, tag the release through the Github UI, after this the Github Actions will run and publish the collection to Ansible Galaxy.