-
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathMakefile
88 lines (63 loc) · 4.06 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
GOFMT_FILES?=$$(find . -not -path "./vendor/*" -type f -name '*.go')
APP_NAME?=terraform-provider-k3d
APP_DIR?=$$(git rev-parse --show-toplevel)
SRC_PACKAGES=$(shell go list -mod=vendor ./... | grep -v "vendor" | grep -v "mocks")
VERSION?=0.1.3
# Get the currently used golang install path (in GOPATH/bin, unless GOBIN is set)
ifeq (,$(shell go env GOBIN))
GOBIN=$(shell go env GOPATH)/bin
else
GOBIN=$(shell go env GOBIN)
endif
.PHONY: help
help: ## Prints help (only for targets with comments)
@grep -E '^[a-zA-Z0-9._-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; \
{printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'
local.fmt: ## Lints all the go code in the application.
@gofmt -w $(GOFMT_FILES)
$(GOBIN)/goimports -w $(GOFMT_FILES)
$(GOBIN)/gofumpt -l -w $(GOFMT_FILES)
$(GOBIN)/gci write $(GOFMT_FILES) --skip-generated
local.check: local.fmt ## Loads all the dependencies to vendor directory
@go mod vendor
@go mod tidy
build.local: local.check ## Generates the artifact with the help of 'go build'
@go build -o $(APP_NAME)_v$(VERSION) -ldflags="-s -w"
local.push: local.build ## Pushes built artifact to the specified location
local.run: local.build ## Generates the artifact and start the service in the current directory
./${APP_NAME}
dockerise: local.check ## Containerise the appliction
@docker build . --tag ${DOCKER_USER}/${PROJECT_NAME}:${VERSION}
docker.lint: ## Linting Dockerfile for
@docker run --rm -v $(APP_DIR):/app -w /app hadolint/hadolint:latest-alpine hadolint Dockerfile
docker.login: ## Establishes the connection to the docker registry
@docker login -u ${DOCKER_USER} -p ${DOCKER_PASSWD} ${DOCKER_REPO}
docker.publish.image: docker_login ## Publisies the image to the registered docker registry.
@docker push ${DOCKER_USER}/${PROJECT_NAME}:${VERSION}
lint: ## Lint's application for errors, it is a linters aggregator (https://github.com/golangci/golangci-lint).
if [ -z "${DEV}" ]; then golangci-lint run --color always ; else docker run --rm -v $(APP_DIR):/app -w /app golangci/golangci-lint:v1.46.2-alpine golangci-lint run --color always ; fi
test: ## runs test cases
@time go test $(TEST_FILES) -mod=vendor -coverprofile cover.out && go tool cover -html=cover.out -o cover.html && open cover.html
copy.terraformrc: ## copies terraformrc to user's home directory that helps in local development of the provider.
cp terraformrc.sample ${HOME}/terraformrc
report: ## Publishes the go-report of the appliction (uses go-reportcard)
@docker run --rm -v $(APP_DIR):/app -w /app basnik/goreportcard-cli:latest goreportcard-cli -v
dev.prerequisite.up: ## Sets up the development environment with all necessary components.
$(APP_DIR)/scripts/prerequisite.sh
generate.mock: ## generates mocks for the selected source packages.
@go generate ${SRC_PACKAGES}
generate.document:
tfplugindocs generate --website-source-dir templates/ --website-temp-dir templates-latest --examples-dir examples
tflint:
@terraform fmt -write=false -check=true -diff=true examples/
create.newversion.tfregistry: build.local ## Sets up the local terraform registry with the version specified.
@mkdir -p ~/terraform-providers/registry.terraform.io/hashicorp/k3d/$(VERSION)/darwin_arm64/
upload.newversion.provider: create.newversion.tfregistry ## Uploads the updated provider to local terraform registry.
@rm -rf ~/terraform-providers/registry.terraform.io/hashicorp/k3d/$(VERSION)/darwin_arm64/terraform-provider-k3d_v$(VERSION)
@cp terraform-provider-k3d_v$(VERSION) ~/terraform-providers/registry.terraform.io/hashicorp/k3d/$(VERSION)/darwin_arm64/
local.build: local.check ## Generates the artifact with the help of 'go build'
GORELEASER_CURRENT_TAG=$(VERSION) BUILD_ENVIRONMENT=${BUILD_ENVIRONMENT} goreleaser build --rm-dist
publish: local.check ## Builds and publishes the app
GOVERSION=${GOVERSION} BUILD_ENVIRONMENT=${BUILD_ENVIRONMENT} PLUGIN_PATH=${APP_DIR} goreleaser release --rm-dist
mock.publish: local.check ## Builds and mocks app release
GOVERSION=${GOVERSION} BUILD_ENVIRONMENT=${BUILD_ENVIRONMENT} PLUGIN_PATH=${APP_DIR} goreleaser release --skip-publish --rm-dist