From 8a795a15baa459dfc971e089095087ef42da7be5 Mon Sep 17 00:00:00 2001 From: Ciara Stacke Date: Thu, 22 Feb 2024 08:58:25 +0000 Subject: [PATCH 1/3] Add pipeline with unit-tests --- .github/workflows/ci.yml | 69 ++++++++++++++++++++++++++++++++++++++++ .gitignore | 1 + Makefile | 1 + 3 files changed, 71 insertions(+) create mode 100644 .github/workflows/ci.yml diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 0000000..5c9dc97 --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,69 @@ +name: Continuous Integration + +on: + push: + branches: + - main + - release-* + tags: + - "v[0-9]+.[0-9]+.[0-9]+*" + pull_request: + +defaults: + run: + shell: bash + +concurrency: + group: ${{ github.ref_name }}-ci + cancel-in-progress: true + +permissions: + contents: read + +jobs: + vars: + name: Checks and variables + runs-on: ubuntu-22.04 + outputs: + go_path: ${{ steps.vars.outputs.go_path }} + steps: + - name: Checkout Repository + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + + - name: Setup Golang Environment + uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 + with: + go-version: stable + + - name: Output Variables + id: vars + run: echo "go_path=$(go env GOPATH)" >> $GITHUB_OUTPUT + + - name: Check if go.mod and go.sum are up to date + run: go mod tidy && git diff --exit-code -- go.mod go.sum + + - name: Check if generated go files are up to date + run: make generate && git diff --exit-code + + unit-tests: + name: Unit Tests + runs-on: ubuntu-22.04 + needs: vars + steps: + - name: Checkout Repository + uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 + + - name: Setup Golang Environment + uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 + with: + go-version: stable + + - name: Run Tests + run: make unit-test + + - name: Upload Coverage Report + uses: actions/upload-artifact@5d5d22a31266ced268874388b861e4b58bb5c2f3 # v4.3.1 + with: + name: cover-${{ github.run_id }}.html + path: ${{ github.workspace }}/cover.html + if: always() diff --git a/.gitignore b/.gitignore index 5afe091..5da5d5c 100644 --- a/.gitignore +++ b/.gitignore @@ -7,6 +7,7 @@ # Output of the go coverage tool cmd-cover.out +cmd-cover.html # Vim *.swp diff --git a/Makefile b/Makefile index 51886c3..66bae1b 100644 --- a/Makefile +++ b/Makefile @@ -8,6 +8,7 @@ help: Makefile ## Display this help .PHONY: unit-test unit-test: go test ./... -race -coverprofile cmd-cover.out + go tool cover -html=cmd-cover.out -o cmd-cover.html .PHONY: clean-go-cache clean-go-cache: ## Clean go cache From 236cc0a72b7dda1b7d3f0c1673ac2e2ccd71af5e Mon Sep 17 00:00:00 2001 From: Ciara Stacke Date: Thu, 22 Feb 2024 09:19:05 +0000 Subject: [PATCH 2/3] Fix typo --- .github/workflows/ci.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 5c9dc97..c76c9e7 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -65,5 +65,5 @@ jobs: uses: actions/upload-artifact@5d5d22a31266ced268874388b861e4b58bb5c2f3 # v4.3.1 with: name: cover-${{ github.run_id }}.html - path: ${{ github.workspace }}/cover.html + path: ${{ github.workspace }}/cmd-cover.html if: always() From 82aeb44d78d80af67a9cd8f6565746e9f5c0d869 Mon Sep 17 00:00:00 2001 From: Ciara Stacke Date: Fri, 23 Feb 2024 09:13:32 +0000 Subject: [PATCH 3/3] Remove release branches from rules --- .github/workflows/ci.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index c76c9e7..68d0f08 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -4,7 +4,6 @@ on: push: branches: - main - - release-* tags: - "v[0-9]+.[0-9]+.[0-9]+*" pull_request: