name: Go mod tidy check on: workflow_dispatch: push: branches: - main - "release/**" paths: - "**.go" - "**/go.mod" - "**/go.sum" pull_request: paths: - "**.go" - "**/go.mod" - "**/go.sum" jobs: gotidycheck: name: Go mod tidy check runs-on: ubuntu-22.04 steps: - name: Checkout uses: actions/checkout@93ea575cb5d8a053eaa0ac8fa3b40d7e05a33cc8 # tag=v3.1.0 with: ref: ${{ github.head_ref }} token: ${{ secrets.TIDY_RENOVATE_PUSH }} - name: Setup Go environment uses: actions/setup-go@d0a58c1c4d2b25278816e339b944508c875f3613 # v3.4.0 with: go-version: "1.19.4" - name: Get Go submodules id: submods shell: bash run: | mods=$(go list -f '{{.Dir}}' -m | xargs) echo "Found mods: $mods" echo "submods=${mods}" >> "$GITHUB_OUTPUT" - name: Go tidy check id: tidycheck uses: katexochen/go-tidy-check@45731e0013a976d5d616d79007c7ba52de6ce542 # tag=v1.0.2 with: modules: ${{ steps.submods.outputs.submods }} # The following steps are only executed if the previous tidy check failed # and the action runs on an renovat branche. In this case, we tidy all # modules again and commit the changes, so the user doesn't need to do it. - name: Tidy modules on renovate branches if: ${{ failure() && (steps.tidycheck.conclusion == 'failure') && startsWith(github.head_ref, 'renovate/') }} shell: bash run: | mods="${{ steps.submods.outputs.submods }}" for mod in $mods; do (cd $mod; go mod tidy) done - name: Push changes if: ${{ failure() && (steps.tidycheck.conclusion == 'failure') && startsWith(github.head_ref, 'renovate/') }} shell: bash run: | git config --global user.name "renovate[bot]" git config --global user.email "29139614+renovate[bot]@users.noreply.github.com" git commit -am "[bot] Tidy all modules" git push