131 lines
5.0 KiB
Makefile
131 lines
5.0 KiB
Makefile
# Copyright 2020 The Kubernetes Authors.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
# If you update this file, please follow:
|
|
# https://suva.sh/posts/well-documented-makefiles/
|
|
|
|
# Use GOPROXY environment variable if set
|
|
|
|
.DEFAULT_GOAL:=help
|
|
|
|
ARCH ?= $(shell go env GOOS)-$(shell go env GOARCH)
|
|
platform_temp = $(subst -, ,$(ARCH))
|
|
GOOS = $(word 1, $(platform_temp))
|
|
GOARCH = $(word 2, $(platform_temp))
|
|
|
|
GOPROXY := $(shell go env GOPROXY)
|
|
ifeq ($(GOPROXY),)
|
|
GOPROXY := https://proxy.golang.org
|
|
endif
|
|
export GOPROXY
|
|
|
|
REPO_ROOT := $(shell git rev-parse --show-toplevel)
|
|
|
|
help: ## Display this help
|
|
@awk 'BEGIN {FS = ":.*##"; printf "\nUsage:\n make \033[36m<target>\033[0m\n"} /^[a-zA-Z0-9_-]+:.*?##/ { printf " \033[36m%-25s\033[0m %s\n", $$1, $$2 } /^##@/ { printf "\n\033[1m%s\033[0m\n", substr($$0, 5) } ' $(MAKEFILE_LIST)
|
|
|
|
## --------------------------------------
|
|
## Binaries
|
|
## --------------------------------------
|
|
|
|
TOOLS_DIR := $(REPO_ROOT)/hack/tools
|
|
BIN_DIR := bin
|
|
TOOLS_BIN_DIR := $(TOOLS_DIR)/$(BIN_DIR)
|
|
GINKGO := $(GOPATH)/bin/ginkgo
|
|
KUSTOMIZE := $(TOOLS_BIN_DIR)/kustomize
|
|
OUTPUT_DIR := _output/$(GOOS)/$(GOARCH)/bin
|
|
GINKGO_FOCUS ?=
|
|
GINKGO_SKIP ?=
|
|
SKIP_STR := $(foreach var, $(subst ., ,$(GINKGO_SKIP)),-skip "$(var)")
|
|
VELERO_CLI ?=$$(pwd)/../../_output/bin/$(GOOS)/$(GOARCH)/velero
|
|
VELERO_IMAGE ?= velero/velero:main
|
|
VELERO_VERSION ?= $(VERSION)
|
|
PLUGINS ?=
|
|
RESTIC_HELPER_IMAGE ?=
|
|
#Released version only
|
|
UPGRADE_FROM_VELERO_VERSION ?= v1.7.1,v1.8.1
|
|
# UPGRADE_FROM_VELERO_CLI can has the same format(a list divided by comma) with UPGRADE_FROM_VELERO_VERSION
|
|
# Upgrade tests will be executed sequently according to the list by UPGRADE_FROM_VELERO_VERSION
|
|
# So although length of UPGRADE_FROM_VELERO_CLI list is not equal with UPGRADE_FROM_VELERO_VERSION
|
|
# Script will still read UPGRADE_FROM_VELERO_CLI list to match UPGRADE_FROM_VELERO_VERSION list from beginning
|
|
# to the end, nil string will be set if UPGRADE_FROM_VELERO_CLI is shorter than UPGRADE_FROM_VELERO_VERSION
|
|
UPGRADE_FROM_VELERO_CLI ?=
|
|
|
|
VELERO_NAMESPACE ?= velero
|
|
CREDS_FILE ?=
|
|
BSL_BUCKET ?=
|
|
BSL_PREFIX ?=
|
|
BSL_CONFIG ?=
|
|
VSL_CONFIG ?=
|
|
CLOUD_PROVIDER ?=
|
|
OBJECT_STORE_PROVIDER ?=
|
|
INSTALL_VELERO ?= true
|
|
REGISTRY_CREDENTIAL_FILE ?=
|
|
KIBISHII_DIRECTORY ?= github.com/vmware-tanzu-experiments/distributed-data-generator/kubernetes/yaml/
|
|
|
|
|
|
# Flags to create an additional BSL for multiple credentials tests
|
|
ADDITIONAL_BSL_PLUGINS ?=
|
|
ADDITIONAL_OBJECT_STORE_PROVIDER ?=
|
|
ADDITIONAL_CREDS_FILE ?=
|
|
ADDITIONAL_BSL_BUCKET ?=
|
|
ADDITIONAL_BSL_PREFIX ?=
|
|
ADDITIONAL_BSL_CONFIG ?=
|
|
|
|
FEATURES ?=
|
|
DEBUG_E2E_TEST ?= false
|
|
|
|
.PHONY:ginkgo
|
|
ginkgo: # Make sure ginkgo is in $GOPATH/bin
|
|
go get github.com/onsi/ginkgo/ginkgo
|
|
|
|
.PHONY: run
|
|
run: ginkgo
|
|
@[ "${CREDS_FILE}" ] && echo "Using credentials from ${CREDS_FILE}" || \
|
|
( echo "A credentials file is required to run E2E tests, please re-run the make target with CREDS_FILE=<PathToCredentialsFile>"; exit 1 )
|
|
@[ "${BSL_BUCKET}" ] && echo "Using bucket ${BSL_BUCKET} to store backups from E2E tests" || \
|
|
(echo "Bucket to store the backups from E2E tests is required, please re-run with BSL_BUCKET=<BucketName>"; exit 1 )
|
|
@[ "${CLOUD_PROVIDER}" ] && echo "Using cloud provider ${CLOUD_PROVIDER}" || \
|
|
(echo "Cloud provider for target cloud/plug-in provider is required, please rerun with CLOUD_PROVIDER=<aws,azure,kind,vsphere>"; exit 1)
|
|
@$(GINKGO) -v -focus="$(GINKGO_FOCUS)" $(SKIP_STR) . -- -velerocli=$(VELERO_CLI) \
|
|
-velero-image=$(VELERO_IMAGE) \
|
|
-plugins=$(PLUGINS) \
|
|
-velero-version=$(VELERO_VERSION) \
|
|
-restic-helper-image=$(RESTIC_HELPER_IMAGE) \
|
|
-upgrade-from-velero-cli=$(UPGRADE_FROM_VELERO_CLI) \
|
|
-upgrade-from-velero-version=$(UPGRADE_FROM_VELERO_VERSION) \
|
|
-velero-namespace=$(VELERO_NAMESPACE) \
|
|
-credentials-file=$(CREDS_FILE) \
|
|
-bucket=$(BSL_BUCKET) \
|
|
-prefix=$(BSL_PREFIX) \
|
|
-bsl-config=$(BSL_CONFIG) \
|
|
-vsl-config=$(VSL_CONFIG) \
|
|
-cloud-provider=$(CLOUD_PROVIDER) \
|
|
-object-store-provider="$(OBJECT_STORE_PROVIDER)" \
|
|
-additional-bsl-plugins=$(ADDITIONAL_BSL_PLUGINS) \
|
|
-additional-bsl-object-store-provider="$(ADDITIONAL_OBJECT_STORE_PROVIDER)" \
|
|
-additional-bsl-credentials-file=$(ADDITIONAL_CREDS_FILE) \
|
|
-additional-bsl-bucket=$(ADDITIONAL_BSL_BUCKET) \
|
|
-additional-bsl-prefix=$(ADDITIONAL_BSL_PREFIX) \
|
|
-additional-bsl-config=$(ADDITIONAL_BSL_CONFIG) \
|
|
-features=$(FEATURES) \
|
|
-install-velero=$(INSTALL_VELERO) \
|
|
-registry-credential-file=$(REGISTRY_CREDENTIAL_FILE) \
|
|
-kibishii-directory=$(KIBISHII_DIRECTORY) \
|
|
-debug-e2e-test=$(DEBUG_E2E_TEST)
|
|
|
|
build: ginkgo
|
|
mkdir -p $(OUTPUT_DIR)
|
|
$(GINKGO) build .
|