namespace packages #104
Workflow file for this run
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: Pull Request | |
on: | |
pull_request: | |
types: | |
- opened | |
- synchronize | |
- reopened | |
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 | |
# backwards compatibility check | |
- run: mage ensure | |
working-directory: ./godemo | |
# backwards compatibility check | |
- run: mage ensureInSync | |
working-directory: ./godemo | |
- run: mage tidy | |
working-directory: ./godemo | |
- run: mage tidyAndVerifyNoChanges | |
working-directory: ./godemo | |
- run: mage go:vulnCheck | |
continue-on-error: true | |
working-directory: ./godemo | |
- run: mage go:licenses | |
working-directory: ./godemo | |
- run: mage unittest | |
working-directory: ./godemo | |
- run: mage integrationtest | |
working-directory: ./godemo | |
- run: mage mergecoverprofiles | |
working-directory: ./godemo | |
- run: mage build | |
working-directory: ./godemo | |
- run: mage buildforlinux | |
working-directory: ./godemo | |
- run: mage buildformac | |
working-directory: ./godemo | |
- run: mage buildforarmmac | |
working-directory: ./godemo | |
- run: mage buildforwindows | |
working-directory: ./godemo | |
- run: mage docker:build | |
working-directory: ./godemo | |
- run: mage docker:push | |
working-directory: ./godemo | |
env: | |
DOCKER_IMAGE_TAGS: sha-${{ github.event.pull_request.head.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/reports/unit-test-coverage.out | |
- run: test -f godemo/target/reports/integration-test-coverage.out | |
- run: test -f godemo/target/reports/merged-test-coverage.out | |
- name: Validate merge coverage | |
working-directory: ./godemo | |
run: go tool cover -func target/reports/merged-test-coverage.out | grep LoadSpec | grep '100.0%' | |
- run: docker images | grep 'quay.io/elisaoyj/sre-godemo' | |
- name: Notify failure | |
if: github.event.pull_request.draft == false && 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 |