From 2244c3de2130bf7613bd7efa30835d21a55a6fa3 Mon Sep 17 00:00:00 2001 From: mrz1836 Date: Sat, 4 Feb 2023 11:45:05 -0500 Subject: [PATCH] Updated makefile, linter version --- .make/go.mk | 32 +++++++++++++++++++++++++------- 1 file changed, 25 insertions(+), 7 deletions(-) diff --git a/.make/go.mk b/.make/go.mk index 2b39e2d..29d6428 100644 --- a/.make/go.mk +++ b/.make/go.mk @@ -19,28 +19,32 @@ ifdef GO_BUILD_TAGS override TAGS=-tags $(GO_BUILD_TAGS) endif -.PHONY: test lint vet install generate - +.PHONY: bench bench: ## Run all benchmarks in the Go application @echo "running benchmarks..." @go test -bench=. -benchmem $(TAGS) +.PHONY: build-go build-go: ## Build the Go application (locally) @echo "building go app..." @go build -o bin/$(BINARY_NAME) $(TAGS) +.PHONY: clean-mods clean-mods: ## Remove all the Go mod cache @echo "cleaning mods..." @go clean -modcache +.PHONY: coverage coverage: ## Shows the test coverage @echo "creating coverage report..." @go test -coverprofile=coverage.out ./... $(TAGS) && go tool cover -func=coverage.out $(TAGS) +.PHONY: generate generate: ## Runs the go generate command in the base of the repo @echo "generating files..." @go generate -v $(TAGS) +.PHONY: godocs godocs: ## Sync the latest tag with GoDocs @echo "syndicating to GoDocs..." @test $(GIT_DOMAIN) @@ -49,62 +53,73 @@ godocs: ## Sync the latest tag with GoDocs @test $(VERSION_SHORT) @curl https://proxy.golang.org/$(GIT_DOMAIN)/$(REPO_OWNER)/$(REPO_NAME)/@v/$(VERSION_SHORT).info +.PHONY: install install: ## Install the application @echo "installing binary..." @go build -o $$GOPATH/bin/$(BINARY_NAME) $(TAGS) +.PHONY: install-go install-go: ## Install the application (Using Native Go) @echo "installing package..." @go install $(GIT_DOMAIN)/$(REPO_OWNER)/$(REPO_NAME) $(TAGS) +.PHONY: lint lint: ## Run the golangci-lint application (install if not found) @echo "installing golangci-lint..." @#Travis (has sudo) - @if [ "$(shell command -v golangci-lint)" = "" ] && [ $(TRAVIS) ]; then curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s v1.45.0 && sudo cp ./bin/golangci-lint $(go env GOPATH)/bin/; fi; + @if [ "$(shell command -v golangci-lint)" = "" ] && [ $(TRAVIS) ]; then curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s v1.51.0 && sudo cp ./bin/golangci-lint $(go env GOPATH)/bin/; fi; @#AWS CodePipeline - @if [ "$(shell command -v golangci-lint)" = "" ] && [ "$(CODEBUILD_BUILD_ID)" != "" ]; then curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.45.0; fi; - @#Github Actions - @if [ "$(shell command -v golangci-lint)" = "" ] && [ "$(GITHUB_WORKFLOW)" != "" ]; then curl -sfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sudo sh -s -- -b $(go env GOPATH)/bin v1.45.0; fi; + @if [ "$(shell command -v golangci-lint)" = "" ] && [ "$(CODEBUILD_BUILD_ID)" != "" ]; then curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.51.0; fi; + @#GitHub Actions + @if [ "$(shell command -v golangci-lint)" = "" ] && [ "$(GITHUB_WORKFLOW)" != "" ]; then curl -sfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sudo sh -s -- -b $(go env GOPATH)/bin v1.51.0; fi; @#Brew - MacOS @if [ "$(shell command -v golangci-lint)" = "" ] && [ "$(shell command -v brew)" != "" ]; then brew install golangci-lint; fi; @#MacOS Vanilla - @if [ "$(shell command -v golangci-lint)" = "" ] && [ "$(shell command -v brew)" != "" ]; then curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- v1.45.0; fi; + @if [ "$(shell command -v golangci-lint)" = "" ] && [ "$(shell command -v brew)" != "" ]; then curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- v1.51.0; fi; @echo "running golangci-lint..." @golangci-lint run --verbose +.PHONY: test test: ## Runs lint and ALL tests @$(MAKE) lint @echo "running tests..." @go test ./... -v $(TAGS) +.PHONY: test-unit test-unit: ## Runs tests and outputs coverage @echo "running unit tests..." @go test ./... -race -coverprofile=coverage.txt -covermode=atomic $(TAGS) +.PHONY: test-short test-short: ## Runs vet, lint and tests (excludes integration tests) @$(MAKE) lint @echo "running tests (short)..." @go test ./... -v -test.short $(TAGS) +.PHONY: test-ci test-ci: ## Runs all tests via CI (exports coverage) @$(MAKE) lint @echo "running tests (CI)..." @go test ./... -race -coverprofile=coverage.txt -covermode=atomic $(TAGS) +.PHONY: test-ci-no-race test-ci-no-race: ## Runs all tests via CI (no race) (exports coverage) @$(MAKE) lint @echo "running tests (CI - no race)..." @go test ./... -coverprofile=coverage.txt -covermode=atomic $(TAGS) +.PHONY: test-ci-short test-ci-short: ## Runs unit tests via CI (exports coverage) @$(MAKE) lint @echo "running tests (CI - unit tests only)..." @go test ./... -test.short -race -coverprofile=coverage.txt -covermode=atomic $(TAGS) +.PHONY: test-no-lint test-no-lint: ## Runs just tests @echo "running tests..." @go test ./... -v $(TAGS) +.PHONY: uninstall uninstall: ## Uninstall the application (and remove files) @echo "uninstalling go application..." @test $(BINARY_NAME) @@ -115,14 +130,17 @@ uninstall: ## Uninstall the application (and remove files) @rm -rf $$GOPATH/src/$(GIT_DOMAIN)/$(REPO_OWNER)/$(REPO_NAME) @rm -rf $$GOPATH/bin/$(BINARY_NAME) +.PHONY: update update: ## Update all project dependencies @echo "updating dependencies..." @go get -u ./... && go mod tidy +.PHONY: update-linter update-linter: ## Update the golangci-lint package (macOS only) @echo "upgrading golangci-lint..." @brew upgrade golangci-lint +.PHONY: vet vet: ## Run the Go vet application @echo "running go vet..." @go vet -v ./... $(TAGS)