Skip to content

Commit

Permalink
CI: Use latest actions and reusable workflows
Browse files Browse the repository at this point in the history
Update defined actions to the latest frozen version and move our
pre-commit validation to the Release Engineering reusable linting
workflow.

Issue: RELENG-5356
Signed-off-by: Andrew Grimberg <[email protected]>
Change-Id: Idfc6a234040bafa4c1dc6608d008cfc71c0cdfa1
  • Loading branch information
tykeal committed May 29, 2024
1 parent 2c5ba22 commit 1b89e5d
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 32 deletions.
2 changes: 1 addition & 1 deletion .editorconfig
Original file line number Diff line number Diff line change
Expand Up @@ -25,5 +25,5 @@ indent_size = 4
max_line_length = 80

[*.yaml]
indent_size = 4
indent_size = 2

63 changes: 37 additions & 26 deletions .github/workflows/gerrit-verify.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -43,15 +43,17 @@ on:
type: string

concurrency:
group: ${{ github.event.inputs.GERRIT_CHANGE_ID || github.run_id }}
# yamllint disable-line rule:line-length
group: ${{ github.workflow }}-${{ github.event.inputs.GERRIT_BRANCH}}-${{ github.event.inputs.GERRIT_CHANGE_ID || github.run_id }}
cancel-in-progress: true

jobs:
clear-vote:
runs-on: ubuntu-latest
steps:
- name: Clear votes
uses: lfit/[email protected]
# yamllint disable-line rule:line-length
uses: lfit/gerrit-review-action@9627b9a144f2a2cad70707ddfae87c87dce60729 # v0.8
with:
host: ${{ vars.LFIT_GERRIT_SERVER }}
username: ${{ vars.LFIT_GERRIT_SSH_USER }}
Expand All @@ -62,6 +64,21 @@ jobs:
vote-type: clear


lint:
needs: clear-vote
# yamllint disable-line rule:line-length
uses: lfit/releng-reusable-workflows/.github/workflows/compose-repo-linting.yaml@main
with:
GERRIT_BRANCH: ${{ inputs.GERRIT_BRANCH }}
GERRIT_CHANGE_ID: ${{ inputs.GERRIT_CHANGE_ID }}
GERRIT_CHANGE_NUMBER: ${{ inputs.GERRIT_CHANGE_NUMBER }}
GERRIT_CHANGE_URL: ${{ inputs.GERRIT_CHANGE_URL }}
GERRIT_EVENT_TYPE: ${{ inputs.GERRIT_EVENT_TYPE }}
GERRIT_PATCHSET_NUMBER: ${{ inputs.GERRIT_PATCHSET_NUMBER }}
GERRIT_PATCHSET_REVISION: ${{ inputs.GERRIT_PATCHSET_REVISION }}
GERRIT_PROJECT: ${{ inputs.GERRIT_PROJECT }}
GERRIT_REFSPEC: ${{ inputs.GERRIT_REFSPEC }}

prepare:
needs: clear-vote
runs-on: ubuntu-latest
Expand All @@ -81,7 +98,7 @@ jobs:
pipx run tox -e clean,build
- name: Record the path of wheel distribution
id: wheel-distribution
run: echo "path=$(ls dist/*.whl)" >> $GITHUB_OUTPUT
run: echo "path=$(ls dist/*.whl)" >> "$GITHUB_OUTPUT"
- name: Store the distribution files for use in other stages
# `tests` and `publish` will use the same pre-built distributions,
# so we make sure to release the exact same package that was tested
Expand All @@ -91,21 +108,6 @@ jobs:
path: dist/
retention-days: 1

pre-commit:
needs: clear-vote
runs-on: ubuntu-latest
steps:
- name: Checkout change
uses: lfit/[email protected]
with:
gerrit-refspec: ${{ inputs.GERRIT_REFSPEC }}
- name: Configure Python
uses: actions/setup-python@v5
with:
python-version: '3.8'
- name: Run static analysis and format checkers
run: pipx run pre-commit run --all-files --show-diff-on-failure

test:
needs: prepare
runs-on: ubuntu-latest
Expand All @@ -116,9 +118,12 @@ jobs:
- "3.9"
steps:
- name: Checkout change
uses: lfit/[email protected]
# 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: Configure Python
uses: actions/setup-python@v5
Expand All @@ -144,11 +149,13 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Checkout change
uses: lfit/[email protected]
# 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"
fetch-depth: "0"
- name: Configure Python
uses: actions/setup-python@v5
id: setup-python
Expand All @@ -164,11 +171,13 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Checkout change
uses: lfit/[email protected]
# 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"
fetch-depth: "0"
- name: Configure Python
uses: actions/setup-python@v5
id: setup-python
Expand All @@ -183,11 +192,13 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Checkout change
uses: lfit/[email protected]
# 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"
fetch-depth: "0"
- name: Configure Python
uses: actions/setup-python@v5
id: setup-python
Expand All @@ -199,7 +210,7 @@ jobs:
vote:
if: ${{ always() }}
needs: [prepare, pre-commit, test, docs, docs-linkcheck, license]
needs: [prepare, test, docs, docs-linkcheck, license, lint]
runs-on: ubuntu-latest
steps:
- name: Get workflow conclusion
Expand Down
8 changes: 4 additions & 4 deletions .github/workflows/release.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -20,18 +20,18 @@ jobs:
pipx run tox -e clean,build
- name: Configure TWINE
run: |
echo "TWINE_USERNAME=__token__" >> $GITHUB_ENV
echo "TWINE_PASSWORD=${{ secrets.PYPI_API_TOKEN }}" >> $GITHUB_ENV
echo "TWINE_USERNAME=__token__" >> "$GITHUB_ENV"
echo "TWINE_PASSWORD=${{ secrets.PYPI_API_TOKEN }}" >> "$GITHUB_ENV"
- name: Publish to PyPI
run: >-
pipx run tox -e publish -- --repository pypi
- name: Get tag
id: tag
uses: devops-actions/[email protected]
- name: Convert tag
run: >-
run: |
VER=$(echo "${{ steps.tag.outputs.tag }}" | tr . -)
echo "ANCHOR=${VER}" >> $GITHUB_ENV
echo "ANCHOR=${VER}" >> "$GITHUB_ENV"
- name: Generate reno report
run: |
# fetch last 30 changes
Expand Down
7 changes: 6 additions & 1 deletion .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ repos:
- repo: https://github.com/ambv/black
rev: 24.4.2
hooks:
- id: black
- id: black

- repo: https://github.com/PyCQA/isort
rev: 5.13.2
Expand All @@ -43,3 +43,8 @@ repos:
- types-requests
- types-six
- types-PyYAML

- repo: https://github.com/rhysd/actionlint
rev: ea8102762106cdca9c88829f1295b39a544706f3 # frozen: v1.6.26
hooks:
- id: actionlint

0 comments on commit 1b89e5d

Please sign in to comment.