-
Notifications
You must be signed in to change notification settings - Fork 54
/
Copy pathMakefile
206 lines (158 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
# This Makefile contains common development / build commands for Package Analysis. For everything to work properly, it needs to be kept in the top-level project directory.
# Get absolute path to top-level package analysis project directory
# outermost abspath removes the trailing slash from the directory path
PREFIX := $(abspath $(dir $(abspath $(lastword $(MAKEFILE_LIST)))))
SANDBOX_DIR := $(PREFIX)/sandboxes
# Registry for Docker images built and used by package analysis
REGISTRY := gcr.io/ossf-malware-analysis
# If RELEASE_TAG environment variable is not specified, images will be tagged
# as 'latest' which is equivalent to just tagging without specifying a version
TAG := ${RELEASE_TAG}
ifeq ($(TAG), )
TAG := latest
BUILD_ARG=
else
# pass tag into analysis image build
BUILD_ARG=--build-arg=SANDBOX_IMAGE_TAG=$(TAG)
endif
.PHONY: help
help: ## Display this help
@awk 'BEGIN {FS = ":.*##"; \
printf "\nUsage:\n make \033[36m<target>\033[0m\n"} /^[a-zA-Z_0-9\/-]+:.*?##/ \
{ printf " \033[36m%-25s\033[0m %s\n", $$1, $$2 } \
/^##@/ { printf "\n\033[1m%s\033[0m\n", substr($$0, 5) } ' $(MAKEFILE_LIST)
#
# This recipe builds and pushes images for production. Note: RELEASE_TAG must be set
#
.PHONY: cloudbuild
cloudbuild: require_release_tag push ## Build and push images
.PHONY: require_release_tag
require_release_tag:
ifndef RELEASE_TAG
$(error RELEASE_TAG must be set)
endif
#
# These recipes build all the top-level docker images
build/image/%:
@# if TAG is 'latest', the two -t arguments are equivalent and do the same thing
docker build $(BUILD_ARG) -t ${REGISTRY}/$(IMAGE_NAME) -t ${REGISTRY}/$(IMAGE_NAME):$(TAG) -f $(DOCKERFILE) $(DIR)
#
# These recipes build the sandbox images.
#
build/sandbox/%:
@# if TAG is 'latest', the two -t arguments are equivalent and do the same thing
docker build -t ${REGISTRY}/$(IMAGE_NAME) -t ${REGISTRY}/$(IMAGE_NAME):$(TAG) -f $(DOCKERFILE) $(DIR)
build/image/analysis: DIR=$(PREFIX)
build/image/analysis: DOCKERFILE=$(PREFIX)/cmd/analyze/Dockerfile
build/image/analysis: IMAGE_NAME=analysis
build/image/scheduler: DIR=$(PREFIX)
build/image/scheduler: DOCKERFILE=$(PREFIX)/cmd/scheduler/Dockerfile
build/image/scheduler: IMAGE_NAME=scheduler
build/sandbox/static_analysis: DIR=$(PREFIX)
build/sandbox/static_analysis: DOCKERFILE=$(SANDBOX_DIR)/staticanalysis/Dockerfile
build/sandbox/static_analysis: IMAGE_NAME=static-analysis
build/sandbox/dynamic_analysis: DIR=$(SANDBOX_DIR)/dynamicanalysis
build/sandbox/dynamic_analysis: DOCKERFILE=$(SANDBOX_DIR)/dynamicanalysis/Dockerfile
build/sandbox/dynamic_analysis: IMAGE_NAME=dynamic-analysis
.PHONY: build
build: build/sandbox/dynamic_analysis build/sandbox/static_analysis build/image/analysis build/image/scheduler ## Build images
#
# Builds then pushes analysis and sandbox images
#
push/image/%:
docker push --all-tags ${REGISTRY}/$(IMAGE_NAME)
push/sandbox/%:
docker push --all-tags ${REGISTRY}/$(IMAGE_NAME)
push/image/analysis: IMAGE_NAME=analysis
push/image/analysis: build/image/analysis
push/image/scheduler: IMAGE_NAME=scheduler
push/image/scheduler: build/image/scheduler
push/sandbox/dynamic_analysis: IMAGE_NAME=dynamic-analysis
push/sandbox/dynamic_analysis: build/sandbox/dynamic_analysis
push/sandbox/static_analysis: IMAGE_NAME=static-analysis
push/sandbox/static_analysis: build/sandbox/static_analysis
.PHONY: push/prod_sandboxes
push/prod_sandboxes: push/sandbox/dynamic_analysis push/sandbox/static_analysis
.PHONY: push
push: push/prod_sandboxes push/image/analysis push/image/scheduler ## Push production images
#
# These update (sync) locally built sandbox images from Docker to
# podman. In order to use locally built sandbox images for analysis,
# pass '-nopull' to scripts/run_analysis.sh
#
sync/sandbox/%:
docker save ${REGISTRY}/${IMAGE_NAME}:$(TAG) | sudo podman load
sync/sandbox/dynamic_analysis: IMAGE_NAME=dynamic-analysis
sync/sandbox/dynamic_analysis: build/sandbox/dynamic_analysis
sync/sandbox/static_analysis: IMAGE_NAME=static-analysis
sync/sandbox/static_analysis: build/sandbox/static_analysis
.PHONY: sync
sync: sync/sandbox/dynamic_analysis sync/sandbox/static_analysis ## Sync prod sandboxes
#
# This runs a lint check on all shell scripts in the repo
#
.PHONY: check_scripts
check_scripts:
find -type f -name '*.sh' | xargs --no-run-if-empty shellcheck -S warning
.PHONY: run
run:
@echo "To perform a local analysis, please use ./run_analysis.sh"
@echo
#
# These recipes control docker-compose, which is used for
# end-to-end testing of the complete scheduler/worker system
#
E2E_TEST_COMPOSE_ARGS := -p pa-e2e-testing -f ./configs/e2e/docker-compose.yml -f ./test/e2e/docker-compose.test.yml
.PHONY: e2e_test_build
e2e_test_build: build_e2e_test_images
.PHONY: e2e_test_start
e2e_test_start:
docker-compose $(E2E_TEST_COMPOSE_ARGS) up -d
@echo
@echo "To see analysis results, go to http://localhost:9000/minio/package-analysis"
@echo "Username: minio"
@echo "Password: minio123"
@echo
@echo "Remember to run 'make e2e_test_stop' when done!"
@sleep 5
@echo
curl localhost:8080
.PHONY: e2e_test_stop
e2e_test_stop:
docker-compose $(E2E_TEST_COMPOSE_ARGS) down
.PHONY: e2e_test_logs_all
e2e_test_logs_all:
docker-compose $(E2E_TEST_COMPOSE_ARGS) logs
.PHONY: e2e_test_logs_feeds
e2e_test_logs_feeds:
docker-compose $(E2E_TEST_COMPOSE_ARGS) logs -f feeds
.PHONY: e2e_test_logs_scheduler
e2e_test_logs_scheduler:
docker-compose $(E2E_TEST_COMPOSE_ARGS) logs -f scheduler
.PHONY: e2e_test_logs_analysis
e2e_test_logs_analysis:
docker-compose $(E2E_TEST_COMPOSE_ARGS) logs -f analysis
.PHONY: build_e2e_test_images
build_e2e_test_images: TAG=test
build_e2e_test_images: sync build/image/analysis build/image/scheduler
.PHONY: test_go
test_go:
go test -v ./...
.PHONY: test_dynamic_analysis
test_dynamic_analysis:
@echo -e "\n##\n## Test NPM \n##\n"
scripts/run_analysis.sh -mode dynamic -nopull -ecosystem npm -package async
@echo -e "\n##\n## Test PyPI \n##\n"
scripts/run_analysis.sh -mode dynamic -nopull -ecosystem pypi -package requests
@echo -e "\n##\n## Test Packagist \n##\n"
scripts/run_analysis.sh -mode dynamic -nopull -ecosystem packagist -package symfony/deprecation-contracts
@echo -e "\n##\n## Test Crates.io \n##\n"
scripts/run_analysis.sh -mode dynamic -nopull -ecosystem crates.io -package itoa
@echo -e "\n##\n## Test RubyGems \n##\n"
scripts/run_analysis.sh -mode dynamic -nopull -ecosystem rubygems -package guwor_palindrome
@echo "Dynamic analysis test passed"
.PHONY: test_static_analysis
test_static_analysis:
@echo -e "\n##\n## Test NPM \n##\n"
scripts/run_analysis.sh -mode static -nopull -ecosystem npm -package async
@echo "Static analysis test passed"