Skip to content

Commit

Permalink
fix: add unit test coverage
Browse files Browse the repository at this point in the history
Signed-off-by: Shubharanshu Mahapatra <[email protected]>
  • Loading branch information
Shubhranshu153 committed Nov 1, 2024
1 parent 9c72ad1 commit 5aa4773
Show file tree
Hide file tree
Showing 5 changed files with 70 additions and 1 deletion.
2 changes: 2 additions & 0 deletions .github/workflows/ci-docs.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ on:
- '!.github/workflows/e2e-macos.yaml'
- '!.github/workflows/e2e-windows.yaml'
- '!.github/workflows/e2e-linux.yaml'
- '!.github/workflows/ci.yaml'
pull_request:
branches:
- main
Expand All @@ -39,6 +40,7 @@ on:
- '!.github/workflows/e2e-macos.yaml'
- '!.github/workflows/e2e-windows.yaml'
- '!.github/workflows/e2e-linux.yaml'
- '!.github/workflows/ci.yaml'

jobs:
git-secrets:
Expand Down
1 change: 1 addition & 0 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,7 @@ jobs:
go-version-file: go.mod
cache: false
- run: make test-unit

# It's recommended to run golangci-lint in a job separate from other jobs (go test, etc) because different jobs run in parallel.
go-linter:
name: lint
Expand Down
1 change: 1 addition & 0 deletions .github/workflows/e2e-linux.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ jobs:
- name: Check repo out manually
if: ${{ (startsWith(inputs.os, 'amazon') && inputs.version == '2' ) }}
run: |
echo Hello
git clone https://github.com/${GITHUB_REPOSITORY}.git .
if [ "$GITHUB_EVENT_NAME" == "pull_request" ]; then
git config --add remote.origin.fetch "+refs/heads/*:refs/remotes/origin/*"
Expand Down
4 changes: 3 additions & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -251,9 +251,11 @@ check-licenses:
GOBIN=$(GOBIN) go install github.com/google/go-licenses
$(GOBIN)/go-licenses check --ignore golang.org/x,github.com/runfinch/finch --ignore github.com/multiformats/go-base36 --allowed_licenses Apache-2.0,BSD-2-Clause,BSD-3-Clause,ISC,MIT --include_tests ./...

COVERAGE_THRESH = 67
.PHONY: test-unit
test-unit:
go test $(shell go list ./... | grep -v e2e | grep -v benchmark | grep -v mocks) -shuffle on
go test -cover -coverprofile=coverage.out $(shell go list ./... | grep -v e2e | grep -v benchmark | grep -v mocks) -shuffle on
go run coverage/coverage.go $(COVERAGE_THRESH)

# test-e2e assumes the VM instance doesn't exist, please make sure to remove it before running.
#
Expand Down
63 changes: 63 additions & 0 deletions coverage/coverage.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
package main

import (
"bufio"
"fmt"
"math"
"os"
"os/exec"
"strconv"
"strings"
)

func main() {

Check failure on line 13 in coverage/coverage.go

View workflow job for this annotation

GitHub Actions / lint

unnecessary leading newline (whitespace)

threshold := 100.0
if len(os.Args) > 1 {
argThreshold, err := strconv.ParseFloat(os.Args[1], 64)
if err != nil {
fmt.Fprintln(os.Stderr, "Invalid threshold value. Please provide a number.")
os.Exit(1)
}
threshold = argThreshold
}

cmd := exec.Command("go", "tool", "cover", "-func=coverage.out")
output, err := cmd.Output()
if err != nil {
fmt.Fprintln(os.Stderr, "Error executing coverage command:", err)
os.Exit(1)
}

var coverage float64
scanner := bufio.NewScanner(strings.NewReader(string(output)))
for scanner.Scan() {
line := scanner.Text()
if strings.Contains(line, "total:") {
parts := strings.Fields(line)
if len(parts) > 2 {
coverageStr := strings.TrimSuffix(parts[2], "%")
coverage, err = strconv.ParseFloat(coverageStr, 64)
if err != nil {
fmt.Fprintln(os.Stderr, "Error parsing coverage:", err)
os.Exit(1)
}
coverage = math.Round(coverage)
fmt.Printf("Total Coverage: %.0f%%\n", coverage)
break
}
}
}

if err := scanner.Err(); err != nil {
fmt.Fprintln(os.Stderr, "Error reading coverage output:", err)
os.Exit(1)
}

if coverage < threshold {
fmt.Fprintf(os.Stderr, "Coverage %.0f%% is below the %.0f%% threshold\n", coverage, threshold)
os.Exit(1)
} else {

Check failure on line 60 in coverage/coverage.go

View workflow job for this annotation

GitHub Actions / lint

superfluous-else: if block ends with call to os.Exit function, so drop this else and outdent its block (revive)
fmt.Printf("Coverage %.0f%% meets the %.0f%% threshold\n", coverage, threshold)
}
}

0 comments on commit 5aa4773

Please sign in to comment.