forked from secureCodeBox/secureCodeBox
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
117 lines (96 loc) · 4.62 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
# SPDX-FileCopyrightText: the secureCodeBox authors
#
# SPDX-License-Identifier: Apache-2.0
include ./prerequisites.mk
include ./env-paths.mk
all: help
.PHONY: npm-ci-all
npm-ci-all: ## Runs npm ci in all node module subfolders.
@echo "Installing all NPM dependencies"
@"$(BIN_DIR)/npm-ci-all.sh"
.PHONY: npm-test-all
npm-test-all: ## Runs all Jest based test suites.
npm test -- --ci --colors --coverage --testPathIgnorePatterns /integration-tests/
.PHONY: test-all
test-all: install-operator install-sdks ## Runs all makefile based test suites (unit + integration Tests).
@echo "Running make test for all scanner and hook modules..."
@for dir in $(SCANNERS_TEST_LIST) $(HOOKS_TEST_LIST); do \
echo "🧪 Test Suite for $${dir}" && cd $$(dirname $$dir) && $(MAKE) -s test || exit 1; \
done
.PHONY: install-operator
install-operator: ## Install the operator for makefile based testing.
@echo "Installing the operator for makefile based testing..."
cd "$(OPERATOR_DIR)" && $(MAKE) -s docker-build docker-export kind-import helm-deploy
.PHONY: install-sdks
install-sdks: ## Install the SDKs for makefile based testing.
@echo "Installing the SDKs (parser, hooks) for makefile based testing..."
cd "$(PARSER_SDK_DIR)" && $(MAKE) -s docker-build
cd "$(HOOK_SDK_DIR)" && $(MAKE) -s docker-build
.PHONY: readme
readme: ## Generate README.md based on Chart.yaml and template.
"$(BIN_DIR)/generate-helm-docs.sh" --readme $(PROJECT_DIR) $(HELM_DOCS_DIR)
.PHONY: hook-docs
hook-docs: ## Generate documentation for hooks.
@for chart in $(HOOKS_CHART_LIST); do \
"$(BIN_DIR)/generate-helm-docs.sh" --hook "$${chart}" "$(HELM_DOCS_DIR)"; \
done
.PHONY: scanner-docs
scanner-docs: ## Generate documentation for scanners.
@for chart in $(SCANNERS_CHART_LIST); do \
"$(BIN_DIR)/generate-helm-docs.sh" --scanner "$${chart}" "$(HELM_DOCS_DIR)"; \
done
.PHONY: operator-docs
operator-docs: ## Generate documentation for the operator.
"$(BIN_DIR)/generate-helm-docs.sh" --operator "$(OPERATOR_DIR)/Chart.yaml" "$(HELM_DOCS_DIR)"
.PHONY: auto-discovery-docs
auto-discovery-docs: ## Generate documentation for the auto-discovery.
"$(BIN_DIR)/generate-helm-docs.sh" --operator "$(AUTO_DISCOVERY_DIR)/kubernetes/Chart.yaml" "$(HELM_DOCS_DIR)"
.PHONY: demo-target-docs
demo-target-docs: ## Generate documentation for demo targets.
@for chart in $(DEMO_TARGETS_CHART_LIST); do \
"$(BIN_DIR)/generate-helm-docs.sh" --demo-target "$${chart}" "$(HELM_DOCS_DIR)"; \
done
.PHONY: docs
docs: readme hook-docs scanner-docs operator-docs auto-discovery-docs demo-target-docs ## Generate all documentation.
.PHONY: create-new-scanner
create-new-scanner: ## Creates templates for a new scanner, pass NAME=NEW-SCANNER to this target.
ifndef NAME
$(error Scanner name not defined, please provide via make create-new-scanner NAME=NEW-SCANNER)
endif
rm -rf "$(SCANNERS_DIR)/$(NAME)"
cp -r "$(TEMPLATES_DIR)/new-scanner/" "$(SCANNERS_DIR)/$(NAME)"
find "$(SCANNERS_DIR)/$(NAME)" -type f ! -name tmp \
-exec sed -n "s/new-scanner/$(NAME)/g;w $(SCANNERS_DIR)/$(NAME)/tmp" {} \; \
-exec mv "$(SCANNERS_DIR)/$(NAME)/tmp" {} \;
mv "$(SCANNERS_DIR)/$(NAME)/templates/new-scanner-parse-definition.yaml" \
"$(SCANNERS_DIR)/$(NAME)/templates/$(NAME)-parse-definition.yaml"
mv "$(SCANNERS_DIR)/$(NAME)/templates/new-scanner-scan-type.yaml" \
"$(SCANNERS_DIR)/$(NAME)/templates/$(NAME)-scan-type.yaml"
.PHONY: test-scanner
test-scanner: ## Shorthand to test a scanner w/o changing in its subdirectory.
ifndef NAME
$(error Scanner name not defined, please provide via make test-scanner NAME=SCANNER_NAME)
endif
$(MAKE) test -C $(SCANNERS_DIR)/$(NAME)
.PHONY: test-hook
test-hook: ## Shorthand to test a hook w/o changing in its subdirectory.
ifndef NAME
$(error Hook name not defined, please provide via make test-hook NAME=HOOK_NAME)
endif
$(MAKE) test -C $(HOOKS_DIR)/$(NAME)
.PHONY: lint
lint: ## Lint only changed files with respect to main branch
npx mega-linter-runner
@printf "\033[36m\n\n\nThe generated reports can be found under ./report/linters_logs/ \n\n\033[0m"
.PHONY: lintfix
lintfix: ## Lint only changed files with respect to main branch and apply automatic fixes if possible
npx mega-linter-runner --fix
@printf "\033[36m\n\n\nThe generated reports can be found under ./report/linters_logs/ \n\n\033[0m"
.PHONY: lintall
lintall: ## Lint complete repo
npx mega-linter-runner --env VALIDATE_ALL_CODEBASE=true
@printf "\033[36m\n\n\nThe generated reports can be found under ./report/linters_logs/ \n\n\033[0m"
.PHONY: help
help: ## Display this help screen.
@grep -h -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | \
awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'