forked from vmware-archive/kubecfg
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
71 lines (54 loc) · 1.99 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
# Copyright 2017 The kubecfg 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.
VERSION ?= dev-$(shell date +%FT%T%z)
GO ?= go
GO_FLAGS ?= -mod=vendor
GO_LDFLAGS ?=
GO_TESTFLAGS ?= -race
GO_BUILDFLAGS ?= -tags netgo -installsuffix netgo -ldflags="-X main.version=$(VERSION) $(GO_LDFLAGS)"
GOFMT ?= gofmt
# GINKGO = "go test" also works if you want to avoid ginkgo tool
GINKGO ?= ginkgo
GO_BINDATA ?= go-bindata
JSONNET_FILES = testdata/kubecfg_test.jsonnet examples/guestbook.jsonnet testdata/import_test.jsonnet testdata/exec.jsonnet
GO_PACKAGES = ./...
# forces go modules regardless of where the source code is checked out
export GO111MODULE = on
# Default cluster from this config is used for integration tests
KUBECONFIG ?= $(HOME)/.kube/config
all: kubecfg
kubecfg:
CGO_ENABLED=0 $(GO) build $(GO_FLAGS) $(GO_BUILDFLAGS) .
generate:
$(GO) generate -x $(GO_FLAGS) $(GO_PACKAGES)
test: gotest jsonnettest
gotest:
$(GO) test $(GO_FLAGS) $(GO_BUILDFLAGS) $(GO_TESTFLAGS) $(GO_PACKAGES)
jsonnettest: kubecfg $(JSONNET_FILES)
# TODO: use `kubecfg validate` once it works offline
./kubecfg show $(JSONNET_FILES) >/dev/null
integrationtest: kubecfg
$(GINKGO) -tags 'integration' integration -- -kubeconfig $(KUBECONFIG) -kubecfg-bin $(abspath $<)
vet:
$(GO) vet $(GO_FLAGS) $(GO_PACKAGES)
fmt:
$(GOFMT) -s -w $(shell $(GO) list -f '{{.Dir}}' $(GO_PACKAGES))
vendor:
$(GO) mod tidy -v
$(GO) mod vendor
clean:
$(RM) ./kubecfg
.PHONY: all test clean vet fmt vendor
.PHONY: kubecfg