-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathMakefile
324 lines (276 loc) · 12.2 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
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
default: ci
ci: lint test fmt-check imports-check integration
# Tooling versions
GOLANGCILINTVERSION?=1.54.1
GOIMPORTSVERSION?=v0.1.12
GOXVERSION?=v1.0.1
GOTESTSUMVERSION?=v1.8.2
GOJUNITVERSION?=v2.0.0
PROTOCGENGOVERSION?=v1.28
PROTOCGENGOGRPCVERSION?=v1.2
CIARTIFACTS?=ci-artifacts
COVERAGEOUT?=coverage.out
COVERAGEHTML?=coverage.html
GOJUNITOUT?=go-junit.xml
PACKAGENAME?=lacework-cli
CLINAME?=lacework
# Honeycomb variables
HONEYDATASET?=lacework-cli-dev
GO_LDFLAGS="-X github.com/lacework/go-sdk/v2/cli/cmd.Version=$(shell cat VERSION) \
-X github.com/lacework/go-sdk/v2/cli/cmd.GitSHA=$(shell git rev-parse HEAD) \
-X github.com/lacework/go-sdk/v2/cli/cmd.HoneyDataset=$(HONEYDATASET) \
-X github.com/lacework/go-sdk/v2/cli/cmd.BuildTime=$(shell date +%Y%m%d%H%M%S)"
GOFLAGS=-mod=vendor
CGO_ENABLED?=0
export GOFLAGS GO_LDFLAGS CGO_ENABLED
INTEGRATION_TEST_TAGS=account \
agent_token \
alert \
alert_rule \
alert_channel \
alert_profile \
agent \
configure \
cloud_account \
container_registry \
query \
policy \
help \
version \
compliance \
team_member \
vulnerability \
report_definitions \
component \
resource_groups \
generation
.PHONY: help
help:
@echo "-------------------------------------------------------------------"
@echo "Lacework go-sdk Makefile helper:"
@echo ""
@grep -Fh "##" $(MAKEFILE_LIST) | grep -v grep | sed -e 's/\\$$//' | sed -E 's/^([^:]*):.*##(.*)/ \1 -\2/'
@echo "-------------------------------------------------------------------"
.PHONY: prepare
prepare: git-env install-tools go-vendor ## Initialize the go environment
.PHONY: test
test: prepare test-only ## Run all go-sdk tests
.PHONY: test-only
test-only: ## Run all go-sdk tests only (without prepare)
$(eval PACKAGES := $(shell go list ./... | grep -v integration))
gotestsum -f testname --packages="$(PACKAGES)" \
-- -v -cover -run=$(regex) -coverprofile=$(COVERAGEOUT) $(PACKAGES)
.PHONY: integration
integration: build-cli-cross-platform integration-only ## Build and run integration tests
.PHONY: integration-generation
integration-generation: build-cli-cross-platform integration-generation-only ## Build and run integration tests
.PHONY: integration-context-tests
integration-context-tests: install-tools ## Run integration tests with build tags from changed files
scripts/integration_test_ctx.sh
.PHONY: integration-generation-only
integration-generation-only: ## Run integration tests
PATH="$(PWD)/bin:${PATH}" go test -v github.com/lacework/go-sdk/v2/integration -timeout 30m -run "^TestGeneration" -tags="generation"
.PHONY: integration-only
integration-only: install-tools ## Run integration tests
PATH="$(PWD)/bin:${PATH}" gotestsum -f testname --packages="github.com/lacework/go-sdk/v2/integration" \
-- -v github.com/lacework/go-sdk/v2/integration -timeout 30m -tags="$(INTEGRATION_TEST_TAGS)" -run=$(regex)
.PHONY: integration-only-subset
integration-only-subset: install-tools ## Run a subset of integration tests
$(eval START := $(shell echo 1+$(index)*5 | bc))
$(eval END := $(shell echo 5+$(index)*5 | bc))
$(eval LENGTH := ${words $(INTEGRATION_TEST_TAGS)})
if [ ${START} -le ${LENGTH} ]; then \
PATH="$(PWD)/bin:${PATH}" gotestsum -f testname --packages="github.com/lacework/go-sdk/v2/integration" \
-- -v github.com/lacework/go-sdk/v2/integration -timeout 30m \
-tags="${wordlist $(START), $(END), $(INTEGRATION_TEST_TAGS)}" -run=$(regex) \
exit 1; \
fi
.PHONY: integration-lql
integration-lql: build-cli-cross-platform integration-lql-only ## Build and run lql integration tests
.PHONY: integration-lql-only
integration-lql-only: ## Run lql integration tests
PATH=$(PWD)/bin:${PATH} gotestsum -- -v github.com/lacework/go-sdk/v2/integration -timeout 30m -tags="query"
.PHONY: integration-policy
integration-policy: build-cli-cross-platform integration-policy-only ## Build and run lql policy tests
.PHONY: integration-policy-only
integration-policy-only: ## Run lql policy tests
PATH=$(PWD)/bin:${PATH} gotestsum -- -v github.com/lacework/go-sdk/v2/integration -timeout 30m -tags="policy"
.PHONY: coverage
coverage: test ## Output coverage profile information for each function
go tool cover -func=$(COVERAGEOUT)
.PHONY: coverage-html
coverage-html: test ## Generate HTML representation of coverage profile
go tool cover -html=$(COVERAGEOUT)
.PHONY: coverage-ci
coverage-ci: test ## Generate HTML coverage output for ci pipeline.
mkdir -p $(CIARTIFACTS)
go tool cover -html=$(COVERAGEOUT) -o "$(CIARTIFACTS)/$(COVERAGEHTML)"
.PHONY: install-go-junit
install-go-junit: ## Install go-junit-report tool for outputting tests in xml junit format. Used in ci pipeline
ifeq (, $(shell which go-junit-report))
GOFLAGS=-mod=readonly go install github.com/jstemmer/go-junit-report@$(GOJUNITVERSION)
endif
.PHONY: test-go-junit-ci
test-go-junit-ci: install-go-junit ## Generate go test report output for ci pipeline.
mkdir -p $(CIARTIFACTS)
go test ./... -v 2>&1 | go-junit-report > "$(CIARTIFACTS)/$(GOJUNITOUT)"
.PHONY: go-vendor
go-vendor: ## Runs go mod tidy, vendor and verify to cleanup, copy and verify dependencies
go mod tidy
go mod vendor
go mod verify
.PHONY: lint
lint: ## Runs go linter
golangci-lint run
.PHONY: fmt
fmt: ## Runs and applies go formatting changes
@gofmt -w -l $(shell go list -f {{.Dir}} ./...)
@goimports -w -l $(shell go list -f {{.Dir}} ./...)
.PHONY: fmt-check
fmt-check: ## Lists formatting issues
$(eval PACKAGES := $(shell go list -f {{.Dir}} ./... | grep -v proto | grep -v databox))
@echo "Verifying formatting from Go packages: "$(PACKAGES)
$(eval ISSUES := $(shell gofmt -l $(PACKAGES)))
@echo "Issues found:\n"$(ISSUES)
@test -z $(ISSUES)
.PHONY: imports-check
imports-check: ## Lists imports issues
@test -z $(shell goimports -l $(shell find . -type f -name '*.go' -not -path './vendor/*' -not -path './cli/cdk/go/proto/*'))
.PHONY: run-api-example
run-api-example: ## Run an API example like 'make run-api-example example=api/_examples/active-containers/main.go'
LW_API_KEY=$(shell lacework configure show api_key) \
LW_API_SECRET=$(shell lacework configure show api_secret) \
LW_ACCOUNT=$(shell lacework configure show account) \
LW_SUBACCOUNT=$(shell lacework configure show subaccount) \
go run $(example)
.PHONY: build
build: ## Compiles binary for the running workstation
go build -o bin/lacework -ldflags=$(GO_LDFLAGS) github.com/lacework/go-sdk/v2/cli
.PHONY: build-cli-cross-platform
build-cli-cross-platform: ## Compiles the Lacework CLI for all supported platforms
gox -output="bin/$(PACKAGENAME)-{{.OS}}-{{.Arch}}" \
-os="linux windows" \
-arch="amd64 386" \
-osarch="darwin/amd64 darwin/arm64 linux/arm linux/arm64" \
-ldflags=$(GO_LDFLAGS) \
github.com/lacework/go-sdk/v2/cli
.PHONY: generate-databox
generate-databox: ## *CI ONLY* Generates in memory representation of template files
go generate internal/databox/box.go
.PHONY: generate-docs
generate-docs: ## *CI ONLY* Generates documentation
go generate cli/cmd/docs.go
.PHONY: test-resources
test-resources: ## *CI ONLY* Prepares CI test containers
scripts/prepare_test_resources.sh all
go-component-from := integration/test_resources/cdk/go-component/bin/go-component
go-component-to := ~/.config/lacework/components/go-component/go-component
.PHONY: cdk-go-component-ci
cdk-go-component-ci: ## Creates a go-component for development
scripts/prepare_test_resources.sh go_component
mkdir -p $(shell dirname $(go-component-to))
echo '{"name":"go-component","description":"(dev-mode) A go-component for development","type":"CLI_COMMAND","artifacts":[],"breadcrumbs":{},"version":"0.0.0-dev"}' \
> $(shell dirname $(go-component-to))/.dev
ifeq (x86_64, $(shell uname -m))
cp $(go-component-from)-$(shell uname -s | tr '[:upper:]' '[:lower:]')-amd64 $(go-component-to)
else ifeq (arm64, $(shell uname -m))
cp $(go-component-from)-$(shell uname -s | tr '[:upper:]' '[:lower:]')-arm64 $(go-component-to)
else
cp $(go-component-from)-$(shell uname -s | tr '[:upper:]' '[:lower:]')-386 $(go-component-to)
endif
.PHONY: cdk-go-component
cdk-go-component: install-cli ## Creates a go-component for development
scripts/prepare_test_resources.sh go_component
lacework component dev go-component \
--type CLI_COMMAND --noninteractive \
--description 'A go-component for development'
ifeq (x86_64, $(shell uname -m))
cp $(go-component-from)-$(shell uname -s | tr '[:upper:]' '[:lower:]')-amd64 $(go-component-to)
else ifeq (arm64, $(shell uname -m))
cp $(go-component-from)-$(shell uname -s | tr '[:upper:]' '[:lower:]')-arm64 $(go-component-to)
else
cp $(go-component-from)-$(shell uname -s | tr '[:upper:]' '[:lower:]')-386 $(go-component-to)
endif
lacework component list
.PHONY: protoc-go
protoc-go: install-tools ## Generates code from proto files inside 'cli/cdk'
protoc --go_out=./cli/cdk/go --go_opt=paths=source_relative \
--go-grpc_out=./cli/cdk/go --go-grpc_opt=paths=source_relative \
proto/v1/*.proto
protoc-python: install-tools
python3 -m grpc_tools.protoc -I. --python_out=./cli/cdk/python \
--grpc_python_out=./cli/cdk/python proto/v1/*.proto
.PHONY: install-cli
install-cli: build ## Build and install the Lacework CLI binary at /usr/local/bin/lacework
mv bin/lacework /usr/local/bin/$(CLINAME)
@echo "\nThe lacework cli has been installed at /usr/local/bin"
.PHONY: release
release: lint test fmt-check imports-check build-cli-cross-platform ## *CI ONLY* Prepares a new release of the go-sdk
scripts/release.sh prepare
.PHONY: install-tools
install-tools: ## Install go indirect dependencies
ifeq (, $(shell which golangci-lint))
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(shell go env GOPATH)/bin v$(GOLANGCILINTVERSION)
endif
ifeq (, $(shell which goimports))
GOFLAGS=-mod=readonly go install golang.org/x/tools/cmd/goimports@$(GOIMPORTSVERSION)
endif
ifeq (, $(shell which gox))
GOFLAGS=-mod=readonly go install github.com/mitchellh/gox@$(GOXVERSION)
endif
ifeq (, $(shell which gotestsum))
GOFLAGS=-mod=readonly go install gotest.tools/gotestsum@$(GOTESTSUMVERSION)
endif
ifeq (, $(shell which protoc-gen-go))
GOFLAGS=-mod=readonly go install google.golang.org/protobuf/cmd/protoc-gen-go@$(PROTOCGENGOVERSION)
endif
ifeq (, $(shell which protoc-gen-go-grpc))
GOFLAGS=-mod=readonly go install google.golang.org/grpc/cmd/protoc-gen-go-grpc@$(PROTOCGENGOGRPCVERSION)
endif
.PHONY: uninstall-tools
uninstall-tools: ## Uninstall go indirect dependencies
ifneq (, $(shell which golangci-lint))
rm $(shell go env GOPATH)/bin/golangci-lint
endif
ifneq (, $(shell which goimports))
rm $(shell go env GOPATH)/bin/goimports
endif
ifneq (, $(shell which gox))
rm $(shell go env GOPATH)/bin/gox
endif
ifneq (, $(shell which gotestsum))
rm $(shell go env GOPATH)/bin/gotestsum
endif
.PHONY: git-env
git-env: ## Configure git commit message style enforcement by applying git_env.sh
scripts/git_env.sh
.PHONY: vagrant-macos-up
vagrant-macos-up: build-cli-cross-platform ## Start and provision the vagrant environment: MacOs Sierra
$(call run_vagrant,macos-sierra,up)
.PHONY: vagrant-macos-login
vagrant-macos-login: build-cli-cross-platform ## Connect to vagrant environment: MacOs Sierra
$(call run_vagrant,macos-sierra,ssh)
.PHONY: vagrant-macos-destroy
vagrant-macos-destroy: ## Stop and delete vagrant environment: MacOs Sierra
$(call run_vagrant,macos-sierra,destroy -f)
.PHONY: vagrant-linux-up
vagrant-linux-up: build-cli-cross-platform ## Start and provision the vagrant environment: Ubuntu 1804
$(call run_vagrant,ubuntu-1804,up)
.PHONY: vagrant-linux-login
vagrant-linux-login: build-cli-cross-platform ## Connect to vagrant environment: Ubuntu 1804
$(call run_vagrant,ubuntu-1804,ssh)
.PHONY: vagrant-linux-destroy
vagrant-linux-destroy: ## Stop and delete vagrant environment: Ubuntu 1804
$(call run_vagrant,ubuntu-1804,destroy -f)
.PHONY: vagrant-windows-up
vagrant-windows-up: build-cli-cross-platform ## Start and provision the vagrant environment: Windows 10
$(call run_vagrant,windows-10,up)
.PHONY: vagrant-windows-login
vagrant-windows-login: build-cli-cross-platform ## Connect to vagrant environment: Windows 10
$(call run_vagrant,windows-10,powershell)
.PHONY: vagrant-windows-destroy
vagrant-windows-destroy: ## Stop and delete vagrant environment: Windows 10
$(call run_vagrant,windows-10,destroy -f)
define run_vagrant
cd cli/vagrant/${1}; vagrant ${2}
endef