-
Notifications
You must be signed in to change notification settings - Fork 155
/
Copy pathMakefile
235 lines (179 loc) · 6.57 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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
# This Makefile encodes the "go generate" prerequisites ensuring that the proper tooling is installed and
# that the generate steps are executed when their prerequeisites files change.
SHELL := /bin/bash
GO_TAGS=
GO_ARGS=-tags '$(GO_TAGS)'
# This invokes a custom package config during Go builds, such that
# the Rust library libflux is built on the fly.
export PKG_CONFIG:=$(shell pwd)/pkg-config.sh
export GOOS=$(shell go env GOOS)
export GO_BUILD=env GO111MODULE=on go build $(GO_ARGS)
export GO_TEST=env GO111MODULE=on go test $(GO_ARGS)
export GO_RUN=env GO111MODULE=on go run $(GO_ARGS)
export GO_TEST_FLAGS=
# Do not add GO111MODULE=on to the call to go generate so it doesn't pollute the environment.
export GO_GENERATE=go generate $(GO_ARGS)
export GO_VET=env GO111MODULE=on go vet $(GO_ARGS)
export CARGO=cargo
export CARGO_ARGS=
export PATH := $(shell pwd)/bin:$(PATH)
define go_deps
$(shell env GO111MODULE=on go list -f "{{range .GoFiles}} {{$$.Dir}}/{{.}}{{end}}" $(1))
endef
default: build
STDLIB_SOURCES = $(shell find . -name '*.flux')
GENERATED_TARGETS = \
internal/feature/flags.go \
ast/asttest/cmpopts.go \
stdlib/packages.go \
internal/fbsemantic/semantic_generated.go \
libflux/go/libflux/buildinfo.gen.go \
$(LIBFLUX_GENERATED_TARGETS)
LIBFLUX_GENERATED_TARGETS = \
libflux/flux-core/src/semantic/flatbuffers/semantic_generated.rs
generate: $(GENERATED_TARGETS)
internal/fbsemantic/semantic_generated.go: internal/fbsemantic/semantic.fbs
$(GO_GENERATE) ./internal/fbsemantic
libflux/flux-core/src/semantic/flatbuffers/semantic_generated.rs: internal/fbsemantic/semantic.fbs
flatc --rust -o libflux/flux-core/src/semantic/flatbuffers internal/fbsemantic/semantic.fbs && rustfmt $@
libflux/go/libflux/buildinfo.gen.go: $(LIBFLUX_GENERATED_TARGETS)
$(GO_GENERATE) ./libflux/go/libflux
# Force a second expansion to happen so the call to go_deps works correctly.
.SECONDEXPANSION:
ast/asttest/cmpopts.go: ast/ast.go ast/asttest/gen.go $$(call go_deps,./internal/cmd/cmpgen)
$(GO_GENERATE) ./ast/asttest
stdlib/packages.go: $(STDLIB_SOURCES) libflux-go internal/fbsemantic/semantic_generated.go
$(GO_GENERATE) ./stdlib
internal/feature/flags.go: internal/feature/flags.yml
$(GO_GENERATE) ./internal/feature
libflux: $(LIBFLUX_GENERATED_TARGETS)
cd libflux && $(CARGO) build $(CARGO_ARGS)
build: libflux-go
$(GO_BUILD) ./...
clean:
rm -rf bin
cd libflux && $(CARGO) clean && rm -rf pkg
cd libflux/c && $(MAKE) clean
cleangenerate:
rm -rf $(GENERATED_TARGETS)
fmt-go:
go fmt ./...
fmt-rust:
cd libflux; $(CARGO) fmt
fmt-flux:
$(GO_RUN) ./cmd/flux fmt -w ./stdlib
fmt: $(SOURCES_NO_VENDOR) fmt-go fmt-rust fmt-flux
checkfmt:
./etc/checkfmt.sh
tidy:
GO111MODULE=on go mod tidy
checktidy:
./etc/checktidy.sh
checkgenerate:
./etc/checkgenerate.sh
checkrelease:
./gotool.sh github.com/goreleaser/goreleaser check
checkreproducibility:
./etc/checkreproducibility.sh
# Run this in two passes to to keep memory usage down. As of this commit,
# running on everything (./...) uses just over 4G of memory. Breaking stdlib
# out keeps memory under 3G.
staticcheck:
GO111MODULE=on go mod vendor # staticcheck looks in vendor for dependencies.
GO111MODULE=on ./gotool.sh honnef.co/go/tools/cmd/staticcheck \
`go list ./... | grep -v '\/flux\/stdlib\>'`
GO111MODULE=on ./gotool.sh honnef.co/go/tools/cmd/staticcheck ./stdlib/...
test: test-go test-rust test-flux
test-go: libflux-go
$(GO_TEST) $(GO_TEST_FLAGS) ./...
test-rust: lint-rust
cd libflux && $(CARGO) test $(CARGO_ARGS) --all-features && \
$(CARGO) doc --no-deps && \
$(CARGO) test --doc
test-flux:
$(GO_RUN) ./cmd/flux test -p stdlib -v --parallel 8
test-flux-integration:
./etc/spawn-containers.sh
# Run tests in order: sql injection attack, write, read
# This way we can read our writes and validate the sql injection failed
$(GO_RUN) ./cmd/flux test -p stdlib -v --skip-untagged --tags integration_injection
$(GO_RUN) ./cmd/flux test -p stdlib -v --skip-untagged --tags integration_write
$(GO_RUN) ./cmd/flux test -p stdlib -v --skip-untagged --tags integration_read
test-race: libflux-go
$(GO_TEST) -race -count=1 ./...
test-bench: libflux-go
$(GO_TEST) -run=NONE -bench=. -benchtime=1x ./...
cd libflux && $(CARGO) test --benches
vet: libflux-go
$(GO_VET) ./...
lint-rust:
cd libflux && $(CARGO) clippy $(CARGO_ARGS) --all-features --all-targets -- -Dclippy::all -Dclippy::undocumented_unsafe_blocks
bench: libflux-go
$(GO_TEST) -bench=. -run=^$$ ./...
# This requires ragel 7.0.1.
libflux/flux-core/src/scanner/scanner_generated.rs: libflux/flux-core/src/scanner/scanner.rl
ragel-rust -I libflux/flux-core/src/scanner -o $@ $<
rm libflux/flux-core/src/scanner/scanner_generated.ri
# This target generates a file that forces the go libflux wrapper
# to recompile which forces pkg-config to run again.
libflux-go: $(LIBFLUX_GENERATED_TARGETS)
$(GO_GENERATE) ./libflux/go/libflux
libflux-wasm:
cd libflux/flux && CC=clang AR=llvm-ar wasm-pack build --scope influxdata --dev
clean-wasm:
rm -rf libflux/flux/pkg
build-wasm:
cd libflux/flux && CC=clang AR=llvm-ar wasm-pack build -t nodejs --scope influxdata
publish-wasm: clean-wasm build-wasm
cd libflux/flux/pkg && npm publish --access public
test-wasm: clean-wasm build-wasm
cd libflux/flux && CC=clang AR==llvm-ar wasm-pack test --node
test-valgrind: libflux
cd libflux/c && $(MAKE) test-valgrind
# Build the set of supported cross-compiled binaries
test-release: Dockerfile_build
docker build -t flux-release -f Dockerfile_build .
docker run --rm -it -v "$(PWD):/home/builder/src" flux-release /bin/sh -c "\
cd src/ &&\
go build -o /go/bin/pkg-config github.com/influxdata/pkg-config &&\
./gotool.sh github.com/goreleaser/goreleaser release --rm-dist --snapshot"
bin/flux: $(STDLIB_SOURCES) $$(call go_deps,./cmd/flux)
$(GO_BUILD) -o ./bin/flux ./cmd/flux
libflux/target/release/fluxdoc: libflux
cd libflux && $(CARGO) build $(CARGO_ARGS) --features=doc --release --bin fluxdoc
fluxdocs: $(STDLIB_SOURCES) libflux/target/release/fluxdoc bin/flux
FLUXDOC=./libflux/target/release/fluxdoc ./etc/gen_docs.sh
checkdocs: $(STDLIB_SOURCES) libflux/target/release/fluxdoc bin/flux
FLUXDOC=./libflux/target/release/fluxdoc ./etc/checkdocs.sh
# This list is sorted for easy inspection
.PHONY: bench \
build \
build-wasm \
checkdocs \
checkfmt \
checkgenerate \
checkrelease \
checkreproducibility \
checktidy \
clean \
clean-wasm \
cleangenerate \
default \
fluxdocs \
fmt \
generate \
libflux \
libflux-go \
libflux-wasm \
lint-rust \
publish-wasm \
release \
staticcheck \
test \
test-bench \
test-go \
test-race \
test-rust \
test-valgrind \
tidy \
vet