183 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			Makefile
		
	
	
	
			
		
		
	
	
			183 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			Makefile
		
	
	
	
# Image URL to use all building/pushing image targets
 | 
						|
IMG ?= fluxcd/source-controller
 | 
						|
TAG ?= latest
 | 
						|
 | 
						|
# Base image used to build the Go binary
 | 
						|
LIBGIT2_IMG ?= ghcr.io/fluxcd/golang-with-libgit2
 | 
						|
LIBGIT2_TAG ?= libgit2-1.1.1
 | 
						|
 | 
						|
# Allows for defining additional Docker buildx arguments,
 | 
						|
# e.g. '--push'.
 | 
						|
BUILD_ARGS ?=
 | 
						|
# Architectures to build images for
 | 
						|
BUILD_PLATFORMS ?= linux/amd64,linux/arm64,linux/arm/v7
 | 
						|
 | 
						|
# Produce CRDs that work back to Kubernetes 1.16
 | 
						|
CRD_OPTIONS ?= crd:crdVersions=v1
 | 
						|
 | 
						|
# Repository root based on Git metadata
 | 
						|
REPOSITORY_ROOT := $(shell git rev-parse --show-toplevel)
 | 
						|
 | 
						|
# Libgit2 version
 | 
						|
LIBGIT2_VERSION ?= 1.1.1
 | 
						|
 | 
						|
# Other dependency versions
 | 
						|
ENVTEST_BIN_VERSION ?= 1.19.2
 | 
						|
KUBEBUILDER_ASSETS ?= $(shell $(SETUP_ENVTEST) use -i $(ENVTEST_BIN_VERSION) -p path)
 | 
						|
 | 
						|
# libgit2 related magical paths
 | 
						|
# These are used to determine if the target libgit2 version is already available on
 | 
						|
# the system, or where they should be installed to
 | 
						|
SYSTEM_LIBGIT2_VERSION := $(shell pkg-config --modversion libgit2 2>/dev/null)
 | 
						|
LIBGIT2_PATH := $(REPOSITORY_ROOT)/hack/libgit2
 | 
						|
LIBGIT2_LIB_PATH := $(LIBGIT2_PATH)/lib
 | 
						|
LIBGIT2 := $(LIBGIT2_LIB_PATH)/libgit2.so.$(LIBGIT2_VERSION)
 | 
						|
 | 
						|
ifneq ($(LIBGIT2_VERSION),$(SYSTEM_LIBGIT2_VERSION))
 | 
						|
	LIBGIT2_FORCE ?= 1
 | 
						|
endif
 | 
						|
 | 
						|
ifeq ($(shell uname -s),Darwin)
 | 
						|
	LIBGIT2 := $(LIBGIT2_LIB_PATH)/libgit2.$(LIBGIT2_VERSION).dylib
 | 
						|
endif
 | 
						|
 | 
						|
# API (doc) generation utilities
 | 
						|
CONTROLLER_GEN_VERSION ?= v0.5.0
 | 
						|
GEN_API_REF_DOCS_VERSION ?= 0.3.0
 | 
						|
 | 
						|
# 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
 | 
						|
 | 
						|
all: build
 | 
						|
 | 
						|
build: $(LIBGIT2) ## Build manager binary
 | 
						|
	PKG_CONFIG_PATH=$(LIBGIT2_LIB_PATH)/pkgconfig/ \
 | 
						|
	go build -o bin/manager main.go
 | 
						|
 | 
						|
test: $(LIBGIT2) test-api  ## Run tests
 | 
						|
	LD_LIBRARY_PATH=$(LIBGIT2_LIB_PATH) \
 | 
						|
	PKG_CONFIG_PATH=$(LIBGIT2_LIB_PATH)/pkgconfig/ \
 | 
						|
	go test ./... -coverprofile cover.out
 | 
						|
 | 
						|
test-api: ## Run api tests
 | 
						|
	cd api; go test ./... -coverprofile cover.out
 | 
						|
 | 
						|
run: $(LIBGIT2) generate fmt vet manifests  ## Run against the configured Kubernetes cluster in ~/.kube/config
 | 
						|
	LD_LIBRARY_PATH=$(LIBGIT2_LIB_PATH) \
 | 
						|
	go run ./main.go
 | 
						|
 | 
						|
install: manifests  ## Install CRDs into a cluster
 | 
						|
	kustomize build config/crd | kubectl apply -f -
 | 
						|
 | 
						|
uninstall: manifests  ## Uninstall CRDs from a cluster
 | 
						|
	kustomize build config/crd | kubectl delete -f -
 | 
						|
 | 
						|
deploy: manifests  ## Deploy controller in the configured Kubernetes cluster in ~/.kube/config
 | 
						|
	cd config/manager && kustomize edit set image fluxcd/source-controller=$(IMG):$(TAG)
 | 
						|
	kustomize build config/default | kubectl apply -f -
 | 
						|
 | 
						|
dev-deploy:  ## Deploy controller dev image in the configured Kubernetes cluster in ~/.kube/config
 | 
						|
	mkdir -p config/dev && cp config/default/* config/dev
 | 
						|
	cd config/dev && kustomize edit set image fluxcd/source-controller=$(IMG):$(TAG)
 | 
						|
	kustomize build config/dev | kubectl apply -f -
 | 
						|
	rm -rf config/dev
 | 
						|
 | 
						|
manifests: controller-gen  ## Generate manifests, e.g. CRD, RBAC, etc.
 | 
						|
	$(CONTROLLER_GEN) $(CRD_OPTIONS) rbac:roleName=manager-role paths="./..." output:crd:artifacts:config="config/crd/bases"
 | 
						|
	cd api; $(CONTROLLER_GEN) $(CRD_OPTIONS) rbac:roleName=manager-role paths="./..." output:crd:artifacts:config="../config/crd/bases"
 | 
						|
 | 
						|
api-docs: gen-crd-api-reference-docs  ## Generate API reference documentation
 | 
						|
	$(API_REF_GEN) -api-dir=./api/v1beta1 -config=./hack/api-docs/config.json -template-dir=./hack/api-docs/template -out-file=./docs/api/source.md
 | 
						|
 | 
						|
tidy:  ## Run go mod tidy
 | 
						|
	go mod tidy
 | 
						|
	cd api; go mod tidy
 | 
						|
 | 
						|
fmt:  ## Run go fmt against code
 | 
						|
	go fmt ./...
 | 
						|
	cd api; go fmt ./...
 | 
						|
 | 
						|
vet: $(LIBGIT2)	## Run go vet against code
 | 
						|
	PKG_CONFIG_PATH=$(LIBGIT2_LIB_PATH)/pkgconfig \
 | 
						|
	go vet ./...
 | 
						|
	cd api; go vet ./...
 | 
						|
 | 
						|
generate: controller-gen  ## Generate API code
 | 
						|
	cd api; $(CONTROLLER_GEN) object:headerFile="../hack/boilerplate.go.txt" paths="./..."
 | 
						|
 | 
						|
docker-build:  ## Build the Docker image
 | 
						|
	docker buildx build \
 | 
						|
		--build-arg LIBGIT2_IMG=$(LIBGIT2_IMG) \
 | 
						|
		--build-arg LIBGIT2_TAG=$(LIBGIT2_TAG) \
 | 
						|
		--platform=$(BUILD_PLATFORMS) \
 | 
						|
		-t $(IMG):$(TAG) \
 | 
						|
		$(BUILD_ARGS) .
 | 
						|
 | 
						|
docker-push:  ## Push Docker image
 | 
						|
	docker push $(IMG):$(TAG)
 | 
						|
 | 
						|
controller-gen: ## Find or download controller-gen
 | 
						|
ifeq (, $(shell which controller-gen))
 | 
						|
	@{ \
 | 
						|
	set -e; \
 | 
						|
	CONTROLLER_GEN_TMP_DIR=$$(mktemp -d); \
 | 
						|
	cd $$CONTROLLER_GEN_TMP_DIR; \
 | 
						|
	go mod init tmp; \
 | 
						|
	go get sigs.k8s.io/controller-tools/cmd/controller-gen@$(CONTROLLER_GEN_VERSION); \
 | 
						|
	rm -rf $$CONTROLLER_GEN_TMP_DIR; \
 | 
						|
	}
 | 
						|
CONTROLLER_GEN=$(GOBIN)/controller-gen
 | 
						|
else
 | 
						|
CONTROLLER_GEN=$(shell which controller-gen)
 | 
						|
endif
 | 
						|
 | 
						|
gen-crd-api-reference-docs:  ## Find or download gen-crd-api-reference-docs
 | 
						|
ifeq (, $(shell which gen-crd-api-reference-docs))
 | 
						|
	@{ \
 | 
						|
	set -e; \
 | 
						|
	API_REF_GEN_TMP_DIR=$$(mktemp -d); \
 | 
						|
	cd $$API_REF_GEN_TMP_DIR; \
 | 
						|
	go mod init tmp; \
 | 
						|
	go get github.com/ahmetb/gen-crd-api-reference-docs@$(GEN_API_REF_DOCS_VERSION); \
 | 
						|
	rm -rf $$API_REF_GEN_TMP_DIR; \
 | 
						|
	}
 | 
						|
API_REF_GEN=$(GOBIN)/gen-crd-api-reference-docs
 | 
						|
else
 | 
						|
API_REF_GEN=$(shell which gen-crd-api-reference-docs)
 | 
						|
endif
 | 
						|
 | 
						|
setup-envtest:  ## Find or download setup-envtest
 | 
						|
ifeq (, $(shell which setup-envtest))
 | 
						|
	@{ \
 | 
						|
	set -e; \
 | 
						|
	SETUP_ENVTEST_TMP_DIR=$$(mktemp -d); \
 | 
						|
	cd $$SETUP_ENVTEST_TMP_DIR; \
 | 
						|
	go mod init tmp; \
 | 
						|
	go get sigs.k8s.io/controller-runtime/tools/setup-envtest@latest; \
 | 
						|
	rm -rf $$SETUP_ENVTEST_TMP_DIR; \
 | 
						|
	}
 | 
						|
SETUP_ENVTEST=$(GOBIN)/setup-envtest
 | 
						|
else
 | 
						|
SETUP_ENVTEST=$(shell which setup-envtest)
 | 
						|
endif
 | 
						|
 | 
						|
libgit2: $(LIBGIT2)  ## Detect or download libgit2 library
 | 
						|
 | 
						|
$(LIBGIT2):
 | 
						|
ifeq (1, $(LIBGIT2_FORCE))
 | 
						|
	@{ \
 | 
						|
	set -e; \
 | 
						|
	mkdir -p $(LIBGIT2_PATH); \
 | 
						|
	curl -sL https://raw.githubusercontent.com/fluxcd/golang-with-libgit2/$(LIBGIT2_TAG)/hack/Makefile -o $(LIBGIT2_PATH)/Makefile; \
 | 
						|
	INSTALL_PREFIX=$(LIBGIT2_PATH) make -C $(LIBGIT2_PATH) libgit2; \
 | 
						|
	}
 | 
						|
endif
 | 
						|
 | 
						|
.PHONY: help
 | 
						|
help:  ## Display this help menu
 | 
						|
	@awk 'BEGIN {FS = ":.*##"; printf "\nUsage:\n  make \033[36m<target>\033[0m\n"} /^[a-zA-Z_0-9-]+:.*?##/ { printf "  \033[36m%-20s\033[0m %s\n", $$1, $$2 } /^##@/ { printf "\n\033[1m%s\033[0m\n", substr($$0, 5) } ' $(MAKEFILE_LIST)
 |