-
Notifications
You must be signed in to change notification settings - Fork 31
/
Copy pathMakefile
84 lines (65 loc) · 1.93 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
DYNAMIC_REGO_FOLDER=./checks/kubernetes/policies/dynamic
BUNDLE_FILE=bundle.tar.gz
REGISTRY_PORT=5111
.PHONY: test
test:
go test -v ./...
.PHONY: integration-test
test-integration:
go test -v -timeout 5m -tags=integration ./integration/...
.PHONY: rego
rego: fmt-rego test-rego
.PHONY: fmt-rego
fmt-rego:
go run ./cmd/opa fmt -w lib/ checks/ examples/ .regal/rules
.PHONY: test-rego
test-rego:
go run ./cmd/opa test --explain=fails lib/ checks/ examples/ --ignore '*.yaml'
.PHONY: lint-rego
lint-rego:
@regal test .regal/rules
@regal lint lib checks \
--config-file .regal/config.yaml \
--enable deny-rule,naming-convention \
--timeout 5m
.PHONY: bundle
bundle: create-bundle verify-bundle
.PHONY: id
id:
@go run ./cmd/id
.PHONY: command-id
command-id:
@go run ./cmd/command_id
.PHONY: outdated-api-updated
outdated-api-updated:
sed -i.bak "s|recommendedVersions :=.*|recommendedVersions := $(OUTDATE_API_DATA)|" $(DYNAMIC_REGO_FOLDER)/outdated_api.rego && rm $(DYNAMIC_REGO_FOLDER)/outdated_api.rego.bak
.PHONY: docs
docs: fmt-examples
go run ./cmd/avd_generator
.PHONY: docs-test
docs-test:
go test -v ./cmd/avd_generator/...
.PHONY: create-bundle
create-bundle:
./scripts/bundle.sh
.PHONY: verify-bundle
verify-bundle:
cp $(BUNDLE_FILE) scripts/$(BUNDLE_FILE)
cd scripts && go run verify-bundle.go
rm scripts/$(BUNDLE_FILE)
build-opa:
go build ./cmd/opa
.PHONY: fmt-examples
fmt-examples:
go run ./cmd/fmt-examples
start-registry:
docker run --rm -it -d -p ${REGISTRY_PORT}:5000 --name registry registry:2
stop-registry:
docker stop registry
push-bundle: create-bundle
@REPO=localhost:${REGISTRY_PORT}/trivy-checks:latest ;\
echo "Pushing to repository: $$REPO" ;\
docker run --rm -it --net=host -v $$PWD/${BUNDLE_FILE}:/${BUNDLE_FILE} bitnami/oras:latest push \
$$REPO \
--artifact-type application/vnd.cncf.openpolicyagent.config.v1+json \
"$(BUNDLE_FILE):application/vnd.cncf.openpolicyagent.layer.v1.tar+gzip"