Gerrit Verify for Ansible roles #21
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
--- | |
name: Gerrit Verify for Ansible roles | |
# yamllint disable-line rule:truthy | |
on: | |
workflow_dispatch: | |
inputs: | |
GERRIT_BRANCH: | |
description: "Branch that change is against" | |
required: true | |
type: string | |
GERRIT_CHANGE_ID: | |
description: "The ID for the change" | |
required: true | |
type: string | |
GERRIT_CHANGE_NUMBER: | |
description: "The Gerrit number" | |
required: true | |
type: string | |
GERRIT_CHANGE_URL: | |
description: "URL to the change" | |
required: true | |
type: string | |
GERRIT_EVENT_TYPE: | |
description: "Type of Gerrit event" | |
required: true | |
type: string | |
GERRIT_PATCHSET_NUMBER: | |
description: "The patch number for the change" | |
required: true | |
type: string | |
GERRIT_PATCHSET_REVISION: | |
description: "The revision sha" | |
required: true | |
type: string | |
GERRIT_PROJECT: | |
description: "Project in Gerrit" | |
required: true | |
type: string | |
GERRIT_REFSPEC: | |
description: "Gerrit refspec of change" | |
required: true | |
type: string | |
concurrency: | |
group: ${{ github.event.inputs.GERRIT_CHANGE_ID || github.run_id }} | |
cancel-in-progress: true | |
jobs: | |
prepare: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Clear votes | |
uses: lfit/[email protected] | |
with: | |
host: ${{ vars.LFIT_GERRIT_SERVER }} | |
username: ${{ vars.LFIT_GERRIT_SSH_USER }} | |
key: ${{ secrets.LFIT_GERRIT_SSH_PRIVKEY_NP }} | |
known_hosts: ${{ vars.LFIT_GERRIT_KNOWN_HOSTS }} | |
gerrit-change-number: ${{ inputs.GERRIT_CHANGE_NUMBER }} | |
gerrit-patchset-number: ${{ inputs.GERRIT_PATCHSET_NUMBER }} | |
vote-type: clear | |
- name: Allow replication | |
run: sleep 10s | |
actionlint: | |
needs: prepare | |
runs-on: ubuntu-latest | |
steps: | |
- uses: lfit/[email protected] | |
with: | |
gerrit-refspec: ${{ inputs.GERRIT_REFSPEC }} | |
delay: "0s" | |
- name: Download actionlint | |
id: get_actionlint | |
run: bash <(curl https://raw.githubusercontent.com/rhysd/actionlint/main/scripts/download-actionlint.bash) | |
shell: bash | |
- name: Check workflow files | |
run: ${{ steps.get_actionlint.outputs.executable }} -color | |
shell: bash | |
# run pre-commit tox env separately to get use of more parallel processing | |
pre-commit: | |
needs: prepare | |
runs-on: ubuntu-latest | |
steps: | |
- uses: lfit/[email protected] | |
with: | |
gerrit-refspec: ${{ inputs.GERRIT_REFSPEC }} | |
delay: "0s" | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: "3.8" | |
- name: Run static analysis and format checkers | |
run: pipx run pre-commit run --all-files --show-diff-on-failure | |
molecule-run: | |
needs: prepare | |
name: Molecule | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
distro: | |
- centos7 | |
- centos8 | |
- ubuntu1804 | |
- ubuntu2004 | |
- ubuntu2204 | |
fail-fast: false | |
steps: | |
- name: Gerrit Checkout | |
# yamllint disable-line rule:line-length | |
uses: lfit/checkout-gerrit-change-action@70360ca2f8bee3e6a15224d8a03f8e017b1ac91f # v0.4 | |
with: | |
gerrit-refspec: ${{ inputs.GERRIT_REFSPEC }} | |
delay: "0s" | |
- name: Install test dependencies. | |
run: | | |
python -m pip install --upgrade pip | |
pip3 install ansible ansible-lint molecule-plugins[docker] docker | |
- name: Run Molecule tests. | |
run: molecule test | |
working-directory: ${{env.working-directory}} | |
env: | |
PY_COLORS: "1" | |
ANSIBLE_FORCE_COLOR: "1" | |
MOLECULE_DISTRO: ${{ matrix.distro }} | |
vote: | |
if: ${{ always() }} | |
needs: | |
[ | |
prepare, | |
actionlint, | |
pre-commit, | |
molecule-run, | |
] | |
runs-on: ubuntu-latest | |
steps: | |
- uses: technote-space/workflow-conclusion-action@v3 | |
- name: Set vote | |
uses: lfit/[email protected] | |
with: | |
host: ${{ vars.LFIT_GERRIT_SERVER }} | |
username: ${{ vars.LFIT_GERRIT_SSH_USER }} | |
key: ${{ secrets.LFIT_GERRIT_SSH_PRIVKEY_NP }} | |
known_hosts: ${{ vars.LFIT_GERRIT_KNOWN_HOSTS }} | |
gerrit-change-number: ${{ inputs.GERRIT_CHANGE_NUMBER }} | |
gerrit-patchset-number: ${{ inputs.GERRIT_PATCHSET_NUMBER }} | |
vote-type: ${{ env.WORKFLOW_CONCLUSION }} |