From 25b15af811f89f63060f5f0ba0e390d0bfac008a Mon Sep 17 00:00:00 2001 From: "Mikhail f. Shiryaev" Date: Thu, 29 Jul 2021 10:22:40 +0200 Subject: [PATCH 1/6] Replace deprecated get with install command See https://golang.org/doc/go-get-install-deprecation --- Makefile | 16 ++++++++-------- README.md | 2 +- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/Makefile b/Makefile index e35747d..1cf7474 100644 --- a/Makefile +++ b/Makefile @@ -42,18 +42,18 @@ install-dependencies: install-tools: # generation - go get golang.org/x/tools/cmd/stringer + go install golang.org/x/tools/cmd/stringer # linting - go get golang.org/x/lint/golint/... - go get github.com/kisielk/errcheck/... - go get honnef.co/go/tools/... + go install golang.org/x/lint/golint/... + go install github.com/kisielk/errcheck/... + go install honnef.co/go/tools/... # code coverage - go get golang.org/x/tools/cmd/cover - go get github.com/onsi/ginkgo/ginkgo/... - go get github.com/modocache/gover/... - go get github.com/mattn/goveralls/... + go install golang.org/x/tools/cmd/cover + go install github.com/onsi/ginkgo/ginkgo/... + go install github.com/modocache/gover/... + go install github.com/mattn/goveralls/... .PHONY: install-tools lint: diff --git a/README.md b/README.md index b5873a1..19c8ea0 100644 --- a/README.md +++ b/README.md @@ -67,7 +67,7 @@ Mutation testing is also especially interesting for comparing automatically gene go-mutesting includes a binary which is go-getable. ```bash -go get -t -v github.com/zimmski/go-mutesting/... +go install github.com/zimmski/go-mutesting/cmd/go-mutesting@latest ``` The binary's help can be invoked by executing the binary without arguments or with the `--help` argument. From dffbbc6f4f3c8e2d54b0b2e465d4c741bf612222 Mon Sep 17 00:00:00 2001 From: "Mikhail f. Shiryaev" Date: Thu, 29 Jul 2021 10:29:41 +0200 Subject: [PATCH 2/6] Use `go get` for dependencies fetch --- Makefile | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/Makefile b/Makefile index 1cf7474..7bb9aed 100644 --- a/Makefile +++ b/Makefile @@ -36,8 +36,7 @@ install: .PHONY: install install-dependencies: - go mod vendor - go test -i -v $(PKG)/... + go get .PHONY: install-dependencies install-tools: From 92ccfba8a83613af9ff8c74639bef5f7ea666440 Mon Sep 17 00:00:00 2001 From: "Mikhail f. Shiryaev" Date: Thu, 29 Jul 2021 10:52:03 +0200 Subject: [PATCH 3/6] Fix golint, it does not support ${PKG}/... --- scripts/lint.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/scripts/lint.sh b/scripts/lint.sh index 26c27ff..95d4fe6 100755 --- a/scripts/lint.sh +++ b/scripts/lint.sh @@ -16,7 +16,7 @@ OUT=$(go vet -all=true $ROOT_DIR 2>&1 | grep --invert-match -E "(Checking file|\ if [ -n "$OUT" ]; then echo "$OUT"; PROBLEM=1; fi echo "golint:" -OUT=$(golint $PKG/... 2>&1 | grep --invert-match -E "(/(example|vendor))") +OUT=$(golint ./... 2>&1 | grep --invert-match -E "(^(example|vendor))") if [ -n "$OUT" ]; then echo "$OUT"; PROBLEM=1; fi echo "staticcheck:" From 26e70c11b405427481d8ef12bacf3fa3830dddb9 Mon Sep 17 00:00:00 2001 From: "Mikhail f. Shiryaev" Date: Thu, 29 Jul 2021 11:06:33 +0200 Subject: [PATCH 4/6] Add github actions --- .github/workflows/tests.yml | 61 +++++++++++++++++++++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100644 .github/workflows/tests.yml diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml new file mode 100644 index 0000000..981dce2 --- /dev/null +++ b/.github/workflows/tests.yml @@ -0,0 +1,61 @@ +name: Tests + +on: + push: + branches: [ master ] + pull_request: + branches: [ master ] + +jobs: + + tests: + name: Test code + runs-on: ${{ matrix.os }} + strategy: + matrix: + go: + - ^1.14 + - ^1.15 + - ^1.16 + - ^1 + os: + - ubuntu-latest + - macos-latest + steps: + + - name: Set up Go + uses: actions/setup-go@v2 + with: + go-version: ${{ matrix.go }} + + - name: Check out code + uses: actions/checkout@v2 + + - name: Checkout to the latest tag + run: | + # Fetch all tags + git fetch --depth=1 --tags + # Get the latest tag + VERS=$(git tag -l | sort -Vr | head -n1) + # Fetch everything to the latest tag + git fetch --shallow-since=$(git log $VERS -1 --format=%at) + if: ${{ github.event_name == 'push' }} # only when built from master + + - name: Install dependencies + run: | + make install-dependencies + make install-tools + make install + + - name: Linting + run: make lint + + - name: Testing + run: | + make test-verbose-with-coverage + gover + + - name: Coverage + run: goveralls -coverprofile=gover.coverprofile -service=github + env: + COVERALLS_TOKEN: ${{ secrets.GITHUB_TOKEN }} From ed8264cc6c7569047df6fb99c5608f5b2302e0ac Mon Sep 17 00:00:00 2001 From: "Mikhail f. Shiryaev" Date: Thu, 29 Jul 2021 11:20:20 +0200 Subject: [PATCH 5/6] Fix shellcheck warnings --- scripts/lint.sh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/scripts/lint.sh b/scripts/lint.sh index 95d4fe6..5b767a2 100755 --- a/scripts/lint.sh +++ b/scripts/lint.sh @@ -4,15 +4,15 @@ if [ -z ${PKG+x} ]; then echo "PKG is not set"; exit 1; fi if [ -z ${ROOT_DIR+x} ]; then echo "ROOT_DIR is not set"; exit 1; fi echo "gofmt:" -OUT=$(gofmt -l -s $ROOT_DIR 2>&1 | grep --invert-match -E "(/(example|vendor))") +OUT=$(gofmt -l -s "$ROOT_DIR" 2>&1 | grep --invert-match -E "(/(example|vendor))") if [ -n "$OUT" ]; then echo "$OUT"; PROBLEM=1; fi echo "errcheck:" -OUT=$(errcheck $PKG/... 2>&1 | grep --invert-match -E "(/(example|vendor))") +OUT=$(errcheck "$PKG/..." 2>&1 | grep --invert-match -E "(/(example|vendor))") if [ -n "$OUT" ]; then echo "$OUT"; PROBLEM=1; fi echo "go vet:" -OUT=$(go vet -all=true $ROOT_DIR 2>&1 | grep --invert-match -E "(Checking file|\%p of wrong type|can't check non-constant format|/example|/vendor)") +OUT=$(go vet -all=true "$ROOT_DIR" 2>&1 | grep --invert-match -E "(Checking file|\%p of wrong type|can't check non-constant format|/example|/vendor)") if [ -n "$OUT" ]; then echo "$OUT"; PROBLEM=1; fi echo "golint:" @@ -20,7 +20,7 @@ OUT=$(golint ./... 2>&1 | grep --invert-match -E "(^(example|vendor))") if [ -n "$OUT" ]; then echo "$OUT"; PROBLEM=1; fi echo "staticcheck:" -OUT=$(staticcheck $PKG/... 2>&1 | grep --invert-match -E "((example|vendor)/)") +OUT=$(staticcheck "$PKG/..." 2>&1 | grep --invert-match -E "((example|vendor)/)") if [ -n "$OUT" ]; then echo "$OUT"; PROBLEM=1; fi if [ -n "$PROBLEM" ]; then exit 1; fi From 001ac9b6c7e45faee4010e04af81981f03d0b9f0 Mon Sep 17 00:00:00 2001 From: "Mikhail f. Shiryaev" Date: Thu, 29 Jul 2021 11:21:02 +0200 Subject: [PATCH 6/6] Remove travis-ci configuration --- .travis.yml | 24 ------------------------ 1 file changed, 24 deletions(-) delete mode 100644 .travis.yml diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index 3a77dcf..0000000 --- a/.travis.yml +++ /dev/null @@ -1,24 +0,0 @@ -language: go - -os: - - linux - - osx - -go: - - 1.11.x - - 1.12.x - -env: - global: - - GO111MODULE: "on" - -install: - - make install-dependencies - - make install-tools - - make install - -script: - - make lint - - make test-verbose-with-coverage - - gover - - if [ "$TRAVIS_SECURE_ENV_VARS" = "true" ]; then goveralls -coverprofile=gover.coverprofile -service=travis-ci; fi