seaweedfs-operator/Makefile
2019-11-19 17:35:57 +08:00

78 lines
3.2 KiB
Makefile

.DEFAULT_GOAL:=help
SHELL:=/bin/bash
NAMESPACE=seaweedfs
##@ Application
install: ## Install all resources (CR/CRD's, RBCA and Operator)
@echo ....... Creating namespace .......
- kubectl create namespace ${NAMESPACE}
@echo ....... Applying CRDS and Operator .......
- kubectl apply -f deploy/crds/cluster.seaweedfs.com_seaweedfsclusters_crd.yaml -n ${NAMESPACE}
@echo ....... Applying Rules and Service Account .......
- kubectl apply -f deploy/role.yaml -n ${NAMESPACE}
- kubectl apply -f deploy/role_binding.yaml -n ${NAMESPACE}
- kubectl apply -f deploy/service_account.yaml -n ${NAMESPACE}
@echo ....... Applying Operator .......
- kubectl apply -f deploy/operator.yaml -n ${NAMESPACE}
@echo ....... Creating the Database .......
- kubectl apply -f deploy/crds/cluster.seaweedfs.com_v1alpha1_seaweedfscluster_cr.yaml -n ${NAMESPACE}
uninstall: ## Uninstall all that all performed in the $ make install
@echo ....... Uninstalling .......
@echo ....... Deleting CRDs.......
- kubectl delete -f deploy/crds/cluster.seaweedfs.com_seaweedfsclusters_crd.yaml -n ${NAMESPACE}
@echo ....... Deleting Rules and Service Account .......
- kubectl delete -f deploy/role.yaml -n ${NAMESPACE}
- kubectl delete -f deploy/role_binding.yaml -n ${NAMESPACE}
- kubectl delete -f deploy/service_account.yaml -n ${NAMESPACE}
@echo ....... Deleting Operator .......
- kubectl delete -f deploy/operator.yaml -n ${NAMESPACE}
@echo ....... Deleting namespace ${NAMESPACE}.......
- kubectl delete namespace ${NAMESPACE}
##@ Development
code-vet: ## Run go vet for this project. More info: https://golang.org/cmd/vet/
@echo go vet
go vet $$(go list ./... )
code-fmt: ## Run go fmt for this project
@echo go fmt
go fmt $$(go list ./... )
code-dev: ## Run the default dev commands which are the go fmt and vet then execute the $ make code-gen
@echo Running the common required commands for developments purposes
- make code-fmt
- make code-vet
- make code-gen
code-gen: ## Run the operator-sdk commands to generated code (k8s and openapi)
@echo Updating the deep copy files with the changes in the API
operator-sdk generate k8s
@echo Updating the CRD files with the OpenAPI validations
operator-sdk generate openapi
##@ Tests
test-e2e: ## Run integration e2e tests with different options.
@echo ... Running the same e2e tests with different args ...
@echo ... Running locally ...
- operator-sdk test local ./test/e2e --up-local --namespace=${NAMESPACE}
@echo ... Running NOT in parallel ...
- operator-sdk test local ./test/e2e --go-test-flags "-v -parallel=1"
@echo ... Running in parallel ...
- operator-sdk test local ./test/e2e --go-test-flags "-v -parallel=2
@echo ... Running without options/args ...
- operator-sdk test local ./test/e2e
@echo ... Running with the --debug param ...
- operator-sdk test local ./test/e2e --debug
@echo ... Running with the --verbose param ...
- operator-sdk test local ./test/e2e --verbose
.PHONY: help
help: ## Display this help
@echo -e "Usage:\n make \033[36m<target>\033[0m"
@awk 'BEGIN {FS = ":.*##"}; \
/^[a-zA-Z0-9_-]+:.*?##/ { printf " \033[36m%-15s\033[0m %s\n", $$1, $$2 } \
/^##@/ { printf "\n\033[1m%s\033[0m\n", substr($$0, 5) } ' $(MAKEFILE_LIST)