-
Notifications
You must be signed in to change notification settings - Fork 699
/
Makefile
108 lines (94 loc) · 2.33 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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
# Old-skool build tools.
#
# Targets (see each target for more information):
# all: Build code.
# build: Build code.
# check: Run build, verify and tests.
# test: Run tests.
# clean: Clean up.
# release: Build release.
OUT_DIR = _output
export GOFLAGS
VERSION = latest
CONTAINER_ENGINE = podman
# Build code.
#
# Args:
# GOFLAGS: Extra flags to pass to 'go' when building.
#
# Example:
# make
# make all
all build:
hack/build-go.sh
.PHONY: all build
build-container:
${CONTAINER_ENGINE} build -t localhost/source-to-image/s2i:${VERSION} .
# Verify if code is properly organized.
#
# Example:
# make verify
verify: build
hack/verify-gofmt.sh
hack/verify-deps.sh
hack/verify-bash-completion.sh
hack/verify-imports.sh
.PHONY: verify
imports: ## Organize imports in go files using goio. Example: make imports
go run ./vendor/github.com/go-imports-organizer/goio
.PHONY: imports
verify-imports: ## Run import verifications. Example: make verify-imports
hack/verify-imports.sh
.PHONY: verify-imports
# Build and run unit tests
#
# Args:
# WHAT: Directory names to test. All *_test.go files under these
# directories will be run. If not specified, "everything" will be tested.
# TESTS: Same as WHAT.
# GOFLAGS: Extra flags to pass to 'go' when building.
# TESTFLAGS: Extra flags that should only be passed to hack/test-go.sh
#
# Example:
# make check
# make test
# make check WHAT=pkg/docker TESTFLAGS=-v
check: verify test
.PHONY: check
# Run unit tests
# Example:
# make test
# make test-unit
# make test WHAT=pkg/docker TESTFLAGS=-v
test test-unit:
hack/test-go.sh $(WHAT) $(TESTS) $(TESTFLAGS)
.PHONY: test test-unit
# Run dockerfile integration tests
# Example:
# make test-dockerfile
# make test-dockerfile TESTFLAGS="-run TestDockerfileIncremental"
test-dockerfile:
hack/test-dockerfile.sh $(TESTFLAGS)
.PHONY: test-dockerfile
# Run docker integration tests - may require sudo permissions
# Exmaple:
# make test-docker
# make test-docker TESTFLAGS="-run TestCleanBuild"
test-docker:
hack/test-docker.sh $(TESTFLAGS)
.PHONY: test-docker
# Remove all build artifacts.
#
# Example:
# make clean
clean:
rm -rf $(OUT_DIR)
.PHONY: clean
# Build the release.
#
# Example:
# make release
release: clean
S2I_BUILD_CMD="${CONTAINER_ENGINE}" hack/build-release.sh
hack/extract-release.sh
.PHONY: release