# Maintainer Documentation ## See CONTRIBUTING.md for more tasks [CONTRIBUTING.md](./CONTRIBUTING.md) contains more instructions that could apply to contributors and not just maintainers (e.g. update ansible-core version). ## CI GCP Project Configuration To enable running integration tests, a test GCP project must be provided. There is a Google-maintained CI project, `ansible-gcp-ci`, that is used for this purpose. For any questions or modification to this project, please contact a maintainer who is employed by Google. ## Reviewing PRs ### Merging PRs Since running the full set of integration tests requires the usage of GCP credentials which are stored as a secret, maintainers must verify that tests pass the integration test run that runs on push to the master branch after accepting a change. ## Release Process ### Overview The process is as follows: 1. Update the version of the collection. 1. Update the changelog. 2. Create a GitHub release to tag the repo and begin the publishing process. ### Steps #### Update Collection Version Modify the [galaxy.yaml](./galaxy.yml) file to the desired collection version: ```yaml version: {NEW_VERSION} ``` Ansible collection versions [must follow SEMVER](https://docs.ansible.com/ansible/devel/dev_guide/developing_collections_distributing.html#collection-versions). Alpha / beta releases are optional. #### Update the changelog Providing a valid [CHANGELOG.rst](./CHANGELOG.rst) is required for a certifiable collection release. Use the [antsibull-changelog](https://github.com/ansible-community/antsibull-changelog) tool to generate the changelog: ```sh pip install antsibull-changelog antsibull-changelog release ``` This will remove all the changelog fragments from ./changelogs/fragments and merge them into CHANGELOG.rst. ### Tag a release The release process is mostly automated, relying on GitHub releases and the following workflows: - [publish to Ansible Galaxy](./.github/workflows/pythonpublish.yml). - [publish to Automation Hub](./.github/workflows/automationhub.yml).