Skip to content

Merge pull request #50 from elisasre/txtfmt #39

Merge pull request #50 from elisasre/txtfmt

Merge pull request #50 from elisasre/txtfmt #39

Workflow file for this run

name: Main
on:
push:
branches:
- main
jobs:
test-go:
runs-on: elisa-normal
timeout-minutes: 15
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 1
- name: Setup Go and Mage
uses: elisa-actions/setup-go-and-mage@v1
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to Quay
uses: docker/login-action@v3
with:
registry: quay.io
username: ${{ secrets.QUAY_USERNAME }}
password: ${{ secrets.QUAY_TOKEN }}
- uses: actions/setup-node@v4
with:
node-version: latest
- name: Verify dependencies
run: |
go mod tidy
git diff --exit-code -- go.mod go.sum || (echo "Deps are not up to date: run 'go mod tidy' before commit" && exit 1)
- run: mage go:lint
working-directory: ./godemo
- run: mage go:tidy
working-directory: ./godemo
- run: mage go:tidyAndVerify
working-directory: ./godemo
- run: mage go:vulnCheck
continue-on-error: true
working-directory: ./godemo
- run: mage go:licenses
working-directory: ./godemo
- run: mage go:unitTest
working-directory: ./godemo
- run: mage go:integrationTest
working-directory: ./godemo
- run: mage go:coverProfile
working-directory: ./godemo
- run: mage go:build
working-directory: ./godemo
- run: mage go:crossBuild
working-directory: ./godemo
- run: mage docker:build
working-directory: ./godemo
- run: mage docker:push
working-directory: ./godemo
env:
DOCKER_IMAGE_TAGS: sha-${{ github.sha }}
- run: mage docs:openAPI
working-directory: ./godemo
- run: |
if ($(mage yaml:lint)) ; then
echo "mage yaml:lint should have failed!"
exit 1
fi
working-directory: ./godemo
- run: mage yaml:fmt
working-directory: ./godemo
- run: mage yaml:lint
working-directory: ./godemo
- run: mage npm:test
working-directory: ./godemo
- run: mage npm:cleanBuild
working-directory: ./godemo
- run: mage npm:lint
working-directory: ./godemo
- run: test -x godemo/target/bin/linux/amd64/godemo
- run: test -f godemo/target/bin/linux/amd64/godemo.sha256
- run: test -x godemo/target/bin/darwin/amd64/godemo
- run: test -f godemo/target/bin/linux/amd64/godemo.sha256
- run: test -x godemo/target/bin/darwin/arm64/godemo
- run: test -f godemo/target/bin/linux/amd64/godemo.sha256
- run: test -x godemo/target/bin/windows/amd64/godemo
- run: test -f godemo/target/bin/windows/amd64/godemo.sha256
- run: test -f godemo/target/tests/bin/linux/amd64/godemo
- run: test -d godemo/target/tests/cover/unit/
- run: test -d godemo/target/tests/cover/int/
- run: test -f godemo/target/tests/cover/combined/cover.txt
- name: Validate merge coverage
working-directory: ./godemo
run: go tool cover -func target/tests/cover/combined/cover.txt | grep LoadSpec | grep '100.0%'
- run: docker images | grep 'quay.io/elisaoyj/sre-godemo'
- name: Notify failure
if: failure()
env:
MATTERMOST_WEBHOOK_URL: ${{ secrets.MATTERMOST_WEBHOOK_URL }}
MATTERMOST_TEXT: "${{ github.repository }} PR build. Please check [here](${{ github.event.pull_request.html_url }}/checks)."
run: |
send-to-mattermost
release-drafter:
runs-on: elisa-normal
timeout-minutes: 5
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 1
- uses: elisa-actions/release-drafter@v5
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
disable-releaser: false
disable-autolabeler: true
- name: Notify failure
if: failure()
env:
MATTERMOST_WEBHOOK_URL: ${{ secrets.MATTERMOST_WEBHOOK_URL }}
MATTERMOST_TEXT: "${{ github.repository }} [${{ github.event.ref }}](${{ github.event.repository.html_url }}/tree/${{ github.event.ref }}) release failed."
run: |
send-to-mattermost