forked from vmware-tanzu/velero-plugin-for-microsoft-azure
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
66 lines (55 loc) · 1.9 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
# Copyright 2017, 2019 the Velero contributors.
#
# 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.
PKG := github.com/vmware-tanzu/velero-plugin-for-microsoft-azure
BIN := velero-plugin-for-microsoft-azure
REGISTRY ?= velero
IMAGE ?= $(REGISTRY)/velero-plugin-for-microsoft-azure
VERSION ?= master
# Which architecture to build.
# if the 'local' rule is being run, detect the GOOS/GOARCH from 'go env'
# if it wasn't specified by the caller.
local: GOOS ?= $(shell go env GOOS)
GOOS ?= linux
local: GOARCH ?= $(shell go env GOARCH)
GOARCH ?= amd64
# local builds the binary using 'go build' in the local environment.
local: build-dirs
GOOS=$(GOOS) \
GOARCH=$(GOARCH) \
PKG=$(PKG) \
BIN=$(BIN) \
OUTPUT_DIR=$$(pwd)/_output \
./hack/build.sh
# test runs unit tests using 'go test' in the local environment.
test:
CGO_ENABLED=0 go test -v -timeout 60s ./...
# ci is a convenience target for CI builds.
ci: test
# container builds a Docker image containing the binary.
container:
docker build -t $(IMAGE):$(VERSION) .
# push pushes the Docker image to its registry.
push:
@docker push $(IMAGE):$(VERSION)
ifeq ($(TAG_LATEST), true)
docker tag $(IMAGE):$(VERSION) $(IMAGE):latest
docker push $(IMAGE):latest
endif
# build-dirs creates the necessary directories for a build in the local environment.
build-dirs:
@mkdir -p _output
# clean removes build artifacts from the local environment.
clean:
@echo "cleaning"
rm -rf _output