diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 6319c2903..3bb3d5472 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -1,19 +1,31 @@ repos: -- repo: https://github.com/dnephin/pre-commit-golang - rev: v0.5.1 - hooks: - - id: go-fmt - exclude: ^vendor - - id: go-vet - - id: go-mod-tidy - -- repo: https://github.com/golangci/golangci-lint - rev: v1.50.1 - hooks: - - id: golangci-lint - - repo: local hooks: + - id: golangci-lint + name: golangci-lint + language: golang + types: [go] + entry: make + args: ["golangci-lint"] + pass_filenames: false + - id: gofmt + name: gofmt + language: system + entry: make + args: ["fmt"] + pass_filenames: false + - id: govet + name: govet + language: system + entry: make + args: ["vet"] + pass_filenames: false + - id: gotidy + name: gotidy + language: system + entry: make + args: ["tidy"] + pass_filenames: false - id: make-manifests name: make-manifests language: system @@ -60,4 +72,13 @@ repos: rev: 2.1.1 hooks: - id: bashate - entry: bashate --error . --ignore=E006,E040,E043 + entry: bashate --error . --ignore=E006,E040,E020,E012 + # Run bashate check for all bash scripts + # Ignores the following rules: + # E006: Line longer than 79 columns (as many scripts use jinja + # templating, this is very difficult) + # E040: Syntax error determined using `bash -n` (as many scripts + # use jinja templating, this will often fail and the syntax + # error will be discovered in execution anyway) + # E020: Function declaration not in format ^function name {$ + # E012: here doc didn't end before EOF diff --git a/Makefile b/Makefile index a09451de9..159cac272 100644 --- a/Makefile +++ b/Makefile @@ -121,6 +121,19 @@ vet: gowork ## Run go vet against code. go vet ./... go vet ./api/... +.PHONY: tidy +tidy: fmt + go mod tidy; \ + pushd "$(LOCALBIN)/../api"; \ + go mod tidy; \ + popd + +.PHONY: golangci-lint +golangci-lint: + # NOTE this will install golangci-lint in to local bin dir + test -s $(LOCALBIN)/golangci-lint || curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s v1.51.2 + $(LOCALBIN)/golangci-lint run --fix + PROCS?=$(shell expr $(shell nproc --ignore 2) / 2) PROC_CMD = --procs ${PROCS}