Call Gerrit Verify #113
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: Call Gerrit Verify | |
# 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 | |
secrets: | |
GERRIT_SSH_PRIVKEY: | |
description: "SSH Key for the authorized user account" | |
required: true | |
concurrency: | |
# yamllint disable-line rule:line-length | |
group: gerrit-verify-${{ github.workflow }}-${{ github.event.inputs.GERRIT_BRANCH}}-${{ github.event.inputs.GERRIT_CHANGE_ID || github.run_id }} | |
cancel-in-progress: true | |
jobs: | |
prepare: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Clear votes | |
# yamllint disable-line rule:line-length | |
uses: lfit/gerrit-review-action@9627b9a144f2a2cad70707ddfae87c87dce60729 # v0.8 | |
with: | |
host: ${{ vars.GERRIT_SERVER }} | |
username: ${{ vars.GERRIT_SSH_USER }} | |
key: ${{ secrets.GERRIT_SSH_PRIVKEY }} | |
known_hosts: ${{ vars.GERRIT_KNOWN_HOSTS }} | |
gerrit-change-number: ${{ inputs.GERRIT_CHANGE_NUMBER }} | |
gerrit-patchset-number: ${{ inputs.GERRIT_PATCHSET_NUMBER }} | |
vote-type: clear | |
comment-only: true | |
- name: Allow replication | |
run: sleep 10s | |
actionlint: | |
needs: prepare | |
runs-on: ubuntu-latest | |
steps: | |
- name: Gerrit Checkout | |
# yamllint disable-line rule:line-length | |
uses: lfit/checkout-gerrit-change-action@54d751e8bd167bc91f7d665dabe33fae87aaaa63 # v0.9 | |
with: | |
gerrit-refspec: ${{ inputs.GERRIT_REFSPEC }} | |
gerrit-project: ${{ inputs.GERRIT_PROJECT }} | |
gerrit-url: ${{ vars.GERRIT_URL }} | |
delay: "0s" | |
- name: Download actionlint | |
id: get_actionlint | |
# yamllint disable-line rule:line-length | |
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: | |
- name: Gerrit Checkout | |
# yamllint disable-line rule:line-length | |
uses: lfit/checkout-gerrit-change-action@54d751e8bd167bc91f7d665dabe33fae87aaaa63 # v0.9 | |
with: | |
gerrit-refspec: ${{ inputs.GERRIT_REFSPEC }} | |
gerrit-project: ${{ inputs.GERRIT_PROJECT }} | |
gerrit-url: ${{ vars.GERRIT_URL }} | |
delay: "0s" | |
# yamllint disable-line rule:line-length | |
- uses: actions/setup-python@0a5c61591373683505ea898e09a3ea4f39ef2b9c # v5.0.0 | |
with: | |
python-version: "3.11" | |
- name: Run static analysis and format checkers | |
run: pipx run pre-commit run --all-files --show-diff-on-failure | |
checkov-scan: | |
needs: prepare | |
runs-on: ubuntu-latest | |
steps: | |
- name: Gerrit Checkout | |
# yamllint disable-line rule:line-length | |
uses: lfit/checkout-gerrit-change-action@54d751e8bd167bc91f7d665dabe33fae87aaaa63 # v0.9 | |
with: | |
gerrit-refspec: ${{ inputs.GERRIT_REFSPEC }} | |
gerrit-project: ${{ inputs.GERRIT_PROJECT }} | |
gerrit-url: ${{ vars.GERRIT_URL }} | |
delay: "0s" | |
submodules: "true" | |
- name: Checkov GitHub Action | |
uses: bridgecrewio/checkov-action@v12 | |
with: | |
output_format: cli,sarif | |
output_file_path: console,results.sarif | |
vote: | |
if: ${{ always() }} | |
needs: [prepare, actionlint, pre-commit, checkov-scan] | |
runs-on: ubuntu-latest | |
steps: | |
- name: Get conclusion | |
uses: im-open/workflow-conclusion@e4f7c4980600fbe0818173e30931d3550801b992 # v2.2.3 | |
- name: Set vote | |
# yamllint disable-line rule:line-length | |
uses: lfit/gerrit-review-action@9627b9a144f2a2cad70707ddfae87c87dce60729 # v0.8 | |
with: | |
host: ${{ vars.GERRIT_SERVER }} | |
username: ${{ vars.GERRIT_SSH_USER }} | |
key: ${{ secrets.GERRIT_SSH_PRIVKEY }} | |
known_hosts: ${{ vars.GERRIT_KNOWN_HOSTS }} | |
gerrit-change-number: ${{ inputs.GERRIT_CHANGE_NUMBER }} | |
gerrit-patchset-number: ${{ inputs.GERRIT_PATCHSET_NUMBER }} | |
vote-type: ${{ env.WORKFLOW_CONCLUSION }} | |
comment-only: true |