2019-06-20 16:36:40 -07:00
export GO111MODULE = on
2019-07-20 17:30:58 -07:00
TOP_LEVEL = $( shell git rev-parse --show-toplevel)
2019-09-16 11:01:59 -07:00
COMMIT_HASH = $( shell git describe --always --tags --long)
2022-10-11 19:01:59 +03:00
RELEASE_TAG = $( shell git describe --tags --abbrev= 0)
2021-10-15 18:05:00 +03:00
GO_VERSION = $( shell go version | awk '{print $$3}' )
2021-12-15 22:47:53 +00:00
COMMIT ?= $( if $( shell git status --porcelain --untracked-files= no) ,$( COMMIT_HASH) -dirty,$( COMMIT_HASH) )
2019-08-14 12:35:51 -07:00
CONTAINER_RUNTIME := $( shell command -v podman 2> /dev/null || echo docker)
2020-07-09 00:10:11 -07:00
TMPDIR := $( shell mktemp -d)
2022-03-23 00:13:10 +02:00
TOOLSDIR := $( shell pwd ) /hack/tools
PATH := bin:$( TOOLSDIR) /bin:$( PATH)
2020-11-05 17:57:06 -08:00
STACKER := $( shell which stacker)
2021-12-13 19:23:31 +00:00
GOLINTER := $( TOOLSDIR) /bin/golangci-lint
2022-10-05 13:21:14 +03:00
GOLINTER_VERSION := v1.49.0
2021-12-07 15:07:22 +02:00
NOTATION := $( TOOLSDIR) /bin/notation
2023-02-28 07:38:49 -08:00
NOTATION_VERSION := 1.0.0-rc.2
2022-11-01 18:16:14 +02:00
COSIGN := $( TOOLSDIR) /bin/cosign
2022-07-22 14:34:12 +03:00
HELM := $( TOOLSDIR) /bin/helm
ORAS := $( TOOLSDIR) /bin/oras
2023-02-28 07:38:49 -08:00
ORAS_VERSION := 1.0.0-rc.1
2022-07-22 14:34:12 +03:00
REGCLIENT := $( TOOLSDIR) /bin/regctl
2022-11-08 00:38:16 -08:00
REGCLIENT_VERSION := v0.4.5
2023-01-13 00:49:42 -08:00
ACTION_VALIDATOR := $( TOOLSDIR) /bin/action-validator
ACTION_VALIDATOR_VERSION := v0.2.1
2023-02-27 21:25:47 +02:00
ZUI_VERSION := commit-1cf9b3c
2022-10-19 06:47:41 +03:00
STACKER := $( TOOLSDIR) /bin/stacker
2022-03-23 00:13:10 +02:00
BATS := $( TOOLSDIR) /bin/bats
2022-03-15 16:34:39 +02:00
TESTDATA := $( TOP_LEVEL) /test/data
2021-12-03 17:42:03 +00:00
OS ?= linux
ARCH ?= amd64
2022-01-13 22:06:35 +00:00
BENCH_OUTPUT ?= stdout
2023-02-23 22:28:08 +02:00
EXTENSIONS ?= sync,search,scrub,metrics,lint,ui
2022-04-27 09:00:20 +03:00
comma := ,
hyphen := -
extended-name :=
2019-06-20 16:36:40 -07:00
.PHONY : all
2023-02-23 22:28:08 +02:00
all : modcheck swagger binary binary -minimal binary -debug cli bench exporter -minimal verify -config test covhtml check check -gh -actions
2022-03-02 21:20:35 +00:00
.PHONY : modcheck
modcheck :
go mod tidy
2022-01-24 05:19:01 +00:00
2022-04-27 09:00:20 +03:00
.PHONY : create -name
create-name :
i f d e f E X T E N S I O N S
$( eval extended-name= -$( subst $( comma) ,$( hyphen) ,$( EXTENSIONS) ) )
e n d i f
2022-07-07 14:11:01 +03:00
.PHONY : build -metadata
2023-02-11 00:52:54 +02:00
build-metadata : $( if $ ( findstring ui ,$ ( EXTENSIONS ) ) , ui )
2022-07-07 14:11:01 +03:00
echo "Imports: \n"
go list -tags $( EXTENSIONS) -f '{{ join .Imports "\n" }}' ./... | sort -u
echo "\n Files: \n"
go list -tags $( EXTENSIONS) -f '{{ join .GoFiles "\n" }}' ./... | sort -u
2022-10-03 19:53:44 +03:00
.PHONY : binary -minimal
binary-minimal : EXTENSIONS =minimal # tag doesn't exist, but we need it to overwrite default value and indicate that we have no extension in build-metadata
binary-minimal : modcheck build -metadata
2022-10-11 19:01:59 +03:00
env CGO_ENABLED = 0 GOOS = $( OS) GOARCH = $( ARCH) go build -o bin/zot-$( OS) -$( ARCH) -minimal -buildmode= pie -tags containers_image_openpgp -v -trimpath -ldflags " -X zotregistry.io/zot/pkg/api/config.ReleaseTag= ${ RELEASE_TAG } -X zotregistry.io/zot/pkg/api/config.Commit= ${ COMMIT } -X zotregistry.io/zot/pkg/api/config.BinaryType=minimal -X zotregistry.io/zot/pkg/api/config.GoVersion= ${ GO_VERSION } -s -w " ./cmd/zot
2022-10-03 19:53:44 +03:00
2022-04-27 09:00:20 +03:00
.PHONY : binary
2023-02-11 00:52:54 +02:00
binary : $( if $ ( findstring ui ,$ ( EXTENSIONS ) ) , ui )
2022-10-03 19:53:44 +03:00
binary : modcheck create -name build -metadata
2022-10-11 19:01:59 +03:00
env CGO_ENABLED = 0 GOOS = $( OS) GOARCH = $( ARCH) go build -o bin/zot-$( OS) -$( ARCH) -buildmode= pie -tags $( EXTENSIONS) ,containers_image_openpgp -v -trimpath -ldflags " -X zotregistry.io/zot/pkg/api/config.ReleaseTag= ${ RELEASE_TAG } -X zotregistry.io/zot/pkg/api/config.Commit= ${ COMMIT } -X zotregistry.io/zot/pkg/api/config.BinaryType= $( extended-name) -X zotregistry.io/zot/pkg/api/config.GoVersion= ${ GO_VERSION } -s -w " ./cmd/zot
2022-04-27 09:00:20 +03:00
2022-01-24 05:19:01 +00:00
.PHONY : binary -debug
2023-02-11 00:52:54 +02:00
binary-debug : $( if $ ( findstring ui ,$ ( EXTENSIONS ) ) , ui )
2022-07-07 14:11:01 +03:00
binary-debug : modcheck swagger create -name build -metadata
2022-10-11 19:01:59 +03:00
env CGO_ENABLED = 0 GOOS = $( OS) GOARCH = $( ARCH) go build -o bin/zot-$( OS) -$( ARCH) -debug -buildmode= pie -tags $( EXTENSIONS) ,debug,containers_image_openpgp -v -gcflags all = '-N -l' -ldflags " -X zotregistry.io/zot/pkg/api/config.ReleaseTag= ${ RELEASE_TAG } -X zotregistry.io/zot/pkg/api/config.Commit= ${ COMMIT } -X zotregistry.io/zot/pkg/api/config.BinaryType= $( extended-name) -X zotregistry.io/zot/pkg/api/config.GoVersion= ${ GO_VERSION } " ./cmd/zot
2021-12-15 22:14:53 +00:00
2022-01-11 01:15:35 +00:00
.PHONY : cli
2022-07-07 14:11:01 +03:00
cli : modcheck create -name build -metadata
2022-10-10 15:05:55 +03:00
env CGO_ENABLED = 0 GOOS = $( OS) GOARCH = $( ARCH) go build -o bin/zli-$( OS) -$( ARCH) -buildmode= pie -tags $( EXTENSIONS) ,search,containers_image_openpgp -v -trimpath -ldflags " -X zotregistry.io/zot/pkg/api/config.Commit= ${ COMMIT } -X zotregistry.io/zot/pkg/api/config.BinaryType= $( extended-name) -X zotregistry.io/zot/pkg/api/config.GoVersion= ${ GO_VERSION } -s -w " ./cmd/zli
2022-01-11 01:15:35 +00:00
2021-12-10 22:27:40 +00:00
.PHONY : bench
2022-07-07 14:11:01 +03:00
bench : modcheck create -name build -metadata
2022-04-27 09:00:20 +03:00
env CGO_ENABLED = 0 GOOS = $( OS) GOARCH = $( ARCH) go build -o bin/zb-$( OS) -$( ARCH) -buildmode= pie -tags $( EXTENSIONS) ,containers_image_openpgp -v -trimpath -ldflags " -X zotregistry.io/zot/pkg/api/config.Commit= ${ COMMIT } -X zotregistry.io/zot/pkg/api/config.BinaryType= $( extended-name) -X zotregistry.io/zot/pkg/api/config.GoVersion= ${ GO_VERSION } -s -w " ./cmd/zb
2021-12-10 22:27:40 +00:00
2021-10-15 18:05:00 +03:00
.PHONY : exporter -minimal
2022-07-07 14:11:01 +03:00
exporter-minimal : EXTENSIONS =minimal # tag doesn't exist, but we need it to overwrite default value and indicate that we have no extension in build-metadata
exporter-minimal : modcheck build -metadata
2022-04-27 09:00:20 +03:00
env CGO_ENABLED = 0 GOOS = $( OS) GOARCH = $( ARCH) go build -o bin/zxp-$( OS) -$( ARCH) -buildmode= pie -tags containers_image_openpgp -v -trimpath ./cmd/zxp
2019-06-20 16:36:40 -07:00
.PHONY : test
2023-02-11 00:52:54 +02:00
test : $( if $ ( findstring ui ,$ ( EXTENSIONS ) ) , ui )
2023-02-13 20:43:52 +02:00
test : check -skopeo $( TESTDATA ) $( ORAS )
2023-02-09 14:28:01 +02:00
go test -failfast -tags $( EXTENSIONS) ,containers_image_openpgp -v -trimpath -race -timeout 15m -cover -coverpkg ./... -coverprofile= coverage-extended.txt -covermode= atomic ./...
go test -failfast -tags containers_image_openpgp -v -trimpath -race -cover -coverpkg ./... -coverprofile= coverage-minimal.txt -covermode= atomic ./...
2021-12-21 04:18:13 +00:00
# development-mode unit tests possibly using failure injection
2023-02-09 14:28:01 +02:00
go test -failfast -tags dev,$( EXTENSIONS) ,containers_image_openpgp -v -trimpath -race -timeout 15m -cover -coverpkg ./... -coverprofile= coverage-dev-extended.txt -covermode= atomic ./pkg/test/... ./pkg/api/... ./pkg/storage/... ./pkg/extensions/sync/... -run ^TestInject
go test -failfast -tags dev,containers_image_openpgp -v -trimpath -race -cover -coverpkg ./... -coverprofile= coverage-dev-minimal.txt -covermode= atomic ./pkg/test/... ./pkg/storage/... ./pkg/extensions/sync/... -run ^TestInject
go test -failfast -tags stress,$( EXTENSIONS) ,containers_image_openpgp -v -trimpath -race -timeout 15m ./pkg/cli/stress_test.go
2019-06-20 16:36:40 -07:00
2022-03-15 16:34:39 +02:00
.PHONY : privileged -test
2023-02-11 00:52:54 +02:00
privileged-test : $( if $ ( findstring ui ,$ ( EXTENSIONS ) ) , ui )
2023-02-13 20:43:52 +02:00
privileged-test : check -skopeo $( TESTDATA )
2022-04-27 09:00:20 +03:00
go test -failfast -tags needprivileges,$( EXTENSIONS) ,containers_image_openpgp -v -trimpath -race -timeout 15m -cover -coverpkg ./... -coverprofile= coverage-dev-needprivileges.txt -covermode= atomic ./pkg/storage/... ./pkg/cli/... -run ^TestElevatedPrivileges
2022-03-15 16:34:39 +02:00
$(TESTDATA) : check -skopeo
2022-08-12 15:18:41 +03:00
$( shell mkdir -p ${ TESTDATA } ; cd ${ TESTDATA } ; mkdir -p noidentity; ../scripts/gen_certs.sh; cd ${ TESTDATA } /noidentity; ../../scripts/gen_nameless_certs.sh; cd ${ TOP_LEVEL } ; skopeo --insecure-policy copy -q docker://public.ecr.aws/t0x7q1g8/centos:7 oci:${ TESTDATA } /zot-test:0.0.1; skopeo --insecure-policy copy -q docker://public.ecr.aws/t0x7q1g8/centos:8 oci:${ TESTDATA } /zot-cve-test:0.0.1)
2022-03-15 16:34:39 +02:00
$( shell chmod -R a = rwx ${ TESTDATA } )
2022-01-13 22:06:35 +00:00
.PHONY : run -bench
run-bench : binary bench
2022-03-24 17:52:39 +00:00
bin/zot-$( OS) -$( ARCH) serve examples/config-bench.json &
2022-01-13 22:06:35 +00:00
sleep 5
2022-01-24 05:19:01 +00:00
bin/zb-$( OS) -$( ARCH) -c 10 -n 100 -o $( BENCH_OUTPUT) http://localhost:8080
killall -r zot-*
2022-01-13 22:06:35 +00:00
2021-12-07 15:07:22 +02:00
.PHONY : check -skopeo
check-skopeo :
skopeo -v || ( echo "You need skopeo to be installed in order to run tests" ; exit 1)
$(NOTATION) :
mkdir -p $( TOOLSDIR) /bin
2023-02-13 20:43:52 +02:00
curl -Lo notation.tar.gz https://github.com/notaryproject/notation/releases/download/v$( NOTATION_VERSION) /notation_$( NOTATION_VERSION) _linux_amd64.tar.gz
2021-12-07 15:07:22 +02:00
tar xvzf notation.tar.gz -C $( TOOLSDIR) /bin notation
rm notation.tar.gz
2022-07-22 14:34:12 +03:00
$(ORAS) :
mkdir -p $( TOOLSDIR) /bin
2022-11-28 20:43:53 +02:00
curl -Lo oras.tar.gz https://github.com/oras-project/oras/releases/download/v$( ORAS_VERSION) /oras_$( ORAS_VERSION) _linux_amd64.tar.gz
2022-07-22 14:34:12 +03:00
tar xvzf oras.tar.gz -C $( TOOLSDIR) /bin oras
rm oras.tar.gz
$(HELM) :
mkdir -p $( TOOLSDIR) /bin
curl -Lo helm.tar.gz https://get.helm.sh/helm-v3.9.1-linux-amd64.tar.gz
tar xvzf helm.tar.gz -C $( TOOLSDIR) /bin linux-amd64/helm --strip-components= 1
rm helm.tar.gz
$(REGCLIENT) :
mkdir -p $( TOOLSDIR) /bin
2022-11-08 00:38:16 -08:00
curl -Lo regctl https://github.com/regclient/regclient/releases/download/$( REGCLIENT_VERSION) /regctl-linux-amd64
2022-07-22 14:34:12 +03:00
cp regctl $( TOOLSDIR) /bin/regctl
chmod +x $( TOOLSDIR) /bin/regctl
2023-01-13 00:49:42 -08:00
$(ACTION_VALIDATOR) :
mkdir -p $( TOOLSDIR) /bin
curl -Lo action-validator https://github.com/mpalmer/action-validator/releases/download/$( ACTION_VALIDATOR_VERSION) /action-validator_linux_amd64
cp action-validator $( TOOLSDIR) /bin/action-validator
chmod +x $( TOOLSDIR) /bin/action-validator
.PHONY : check -gh -actions
check-gh-actions : $( ACTION_VALIDATOR )
for i in $$ ( ls .github/workflows/*) ; do $( ACTION_VALIDATOR) $$ i; done
2020-01-24 15:32:38 -06:00
.PHONY : covhtml
covhtml :
2021-12-21 04:18:13 +00:00
go install github.com/wadey/gocovmerge@latest
2022-03-15 16:34:39 +02:00
gocovmerge coverage*.txt > coverage.txt
2020-01-24 15:32:38 -06:00
go tool cover -html= coverage.txt -o coverage.html
2021-12-13 19:23:31 +00:00
$(GOLINTER) :
mkdir -p $( TOOLSDIR) /bin
2022-03-21 17:37:23 +00:00
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $( TOOLSDIR) /bin $( GOLINTER_VERSION)
2021-12-13 19:23:31 +00:00
$( GOLINTER) version
2019-06-20 16:36:40 -07:00
.PHONY : check
2023-02-11 00:52:54 +02:00
check : $( if $ ( findstring ui ,$ ( EXTENSIONS ) ) , ui )
2021-12-13 19:23:31 +00:00
check : ./golangcilint .yaml $( GOLINTER )
2023-02-11 00:52:54 +02:00
mkdir -p pkg/extensions/build; touch pkg/extensions/build/.empty
2022-04-27 09:00:20 +03:00
$( GOLINTER) --config ./golangcilint.yaml run --enable-all --out-format= colored-line-number --build-tags containers_image_openpgp ./...
$( GOLINTER) --config ./golangcilint.yaml run --enable-all --out-format= colored-line-number --build-tags $( EXTENSIONS) ,containers_image_openpgp ./...
2023-02-23 22:28:08 +02:00
$( GOLINTER) --config ./golangcilint.yaml run --enable-all --out-format= colored-line-number --build-tags $( EXTENSIONS) ,containers_image_openpgp,debug ./...
2022-04-27 09:00:20 +03:00
$( GOLINTER) --config ./golangcilint.yaml run --enable-all --out-format= colored-line-number --build-tags dev,containers_image_openpgp ./...
$( GOLINTER) --config ./golangcilint.yaml run --enable-all --out-format= colored-line-number --build-tags dev,$( EXTENSIONS) ,containers_image_openpgp ./...
$( GOLINTER) --config ./golangcilint.yaml run --enable-all --out-format= colored-line-number --build-tags stress,$( EXTENSIONS) ,containers_image_openpgp ./...
2023-02-11 00:52:54 +02:00
rm pkg/extensions/build/.empty
2019-06-20 16:36:40 -07:00
2021-10-20 21:01:06 +00:00
swagger/docs.go :
2022-02-24 12:31:36 -08:00
swag -v || go install github.com/swaggo/swag/cmd/swag@1.6.3
2021-10-20 21:01:06 +00:00
swag init -o swagger -g pkg/api/routes.go
2019-06-20 16:36:40 -07:00
2021-10-20 21:01:06 +00:00
.PHONY : swagger
2022-02-24 12:31:36 -08:00
swagger : swagger /docs .go pkg /api /routes .go
2019-08-28 15:58:00 -07:00
2020-12-03 11:33:38 -08:00
.PHONY : update -licenses
update-licenses :
2022-01-24 17:31:39 +00:00
@echo "Detecting and updating licenses ... please be patient!"
go install github.com/google/go-licenses@latest
$( shell echo "Module | License URL | License" > THIRD-PARTY-LICENSES.md; echo "---|---|---" >> THIRD-PARTY-LICENSES.md; for i in $$ ( go list -m all | awk '{print $$1}' ) ; do l = $$ ( go-licenses csv $$ i 2>/dev/null) ; if [ $$ ? -ne 0 ] ; then continue ; fi ; echo $$ l | tr \, \| | tr ' ' '\n' ; done | sort -u >> THIRD-PARTY-LICENSES.md)
.PHONY : check -licenses
check-licenses :
go install github.com/google/go-licenses@latest
2022-04-27 09:00:20 +03:00
@for tag in " $( EXTENSIONS) ,containers_image_openpgp " " $( EXTENSIONS) ,containers_image_openpgp " ; do \
2022-01-24 17:31:39 +00:00
echo Evaluating tag: $$ tag; \
for mod in $$ ( go list -m -f '{{if not (or .Indirect .Main)}}{{.Path}}{{end}}' all) ; do \
while [ x$$ mod != x ] ; do \
echo -n " Checking $$ mod ... " ; \
result = $$ ( GOFLAGS = " -tags= $$ {tag} " go-licenses check $$ mod 2>& 1) ; \
if [ $$ ? -eq 0 ] ; then \
echo OK; \
break; \
fi ; \
echo " $$ {result} " | grep -q "Forbidden" ; \
if [ $$ ? -eq 0 ] ; then \
echo FAIL; \
exit 1; \
fi ; \
2022-10-04 13:36:19 -07:00
echo " $$ {result} " | egrep -q "missing go.sum entry|no required module provides package|build constraints exclude all|updates to go.mod needed|non-Go code" ; \
2022-01-24 17:31:39 +00:00
if [ $$ ? -eq 0 ] ; then \
echo UNKNOWN; \
break; \
fi ; \
done ; \
done ; \
done
2020-12-03 11:33:38 -08:00
2019-06-20 16:36:40 -07:00
.PHONY : clean
clean :
2021-12-10 22:27:40 +00:00
rm -f bin/z*
2021-12-13 19:23:31 +00:00
rm -rf hack
2022-05-10 11:28:26 +03:00
rm -rf test/data/zot-test
rm -rf test/data/zot-cve-test
2023-02-11 00:52:54 +02:00
rm -rf pkg/extensions/build
2019-06-20 16:36:40 -07:00
.PHONY : run
run : binary test
2022-01-24 05:19:01 +00:00
./bin/zot-$( OS) -$( ARCH) serve examples/config-test.json
2019-08-14 12:35:51 -07:00
2022-01-07 14:58:02 +02:00
.PHONY : verify -config
2022-03-30 16:02:03 +03:00
verify-config : _verify -config verify -config -warnings verify -config -commited
.PHONY : _verify -config
_verify-config : binary
rm -f output.txt
$( foreach file, $( wildcard examples/config-*) , ./bin/zot-$( OS) -$( ARCH) verify $( file) 2>& 1 | tee -a output.txt || exit 1; )
.PHONY : verify -config -warnings
verify-config-warnings : _verify -config
$( eval WARNINGS = $( shell cat output.txt | grep -c '"warn"' ) )
$( eval ERRORS = $( shell cat output.txt | grep -c '"error"' ) )
@if [ $( WARNINGS) != 0 ] || [ $( ERRORS) != 0 ] ; then \
echo "verify-config-warnings: warnings or errors found while verifying configs" ; \
rm output.txt; \
exit 1; \
fi
rm -f output.txt
.PHONY : verify -config -commited
verify-config-commited : _verify -config
$( eval UNCOMMITED_FILES = $( shell git status --porcelain | grep -c examples/config-) )
@if [ $( UNCOMMITED_FILES) != 0 ] ; then \
echo "Uncommited config files, make sure all config files are commited. Verify might have changed a config file." ; \
exit 1; \
fi ; \
2022-01-07 14:58:02 +02:00
2022-07-15 11:10:51 +00:00
.PHONY : gqlgen
gqlgen :
cd pkg/extensions/search; \
go run github.com/99designs/gqlgen version; \
go run github.com/99designs/gqlgen generate
.PHONY : verify -gql -committed
verify-gql-committed :
$( eval UNCOMMITED_FILES = $( shell git status --porcelain | grep -c extensions/search) )
@if [ $( UNCOMMITED_FILES) != 0 ] ; then \
echo "Updated gql files uncommitted, make sure all gql files are committed:" ; \
git status; \
exit 1; \
fi ; \
2019-08-14 12:35:51 -07:00
.PHONY : binary -container
binary-container :
2022-11-10 12:09:39 -08:00
${ CONTAINER_RUNTIME } build ${ BUILD_ARGS } -f build/Dockerfile -t zot-build:latest .
2020-11-05 17:39:14 -08:00
.PHONY : run -container
run-container :
2021-12-04 03:50:58 +00:00
${ CONTAINER_RUNTIME } run --rm --security-opt label = disable -v $$ ( pwd ) :/go/src/github.com/project-zot/zot \
2020-11-05 17:39:14 -08:00
zot-build:latest
2019-08-14 16:26:25 -07:00
.PHONY : binary -stacker
binary-stacker :
2023-02-11 00:52:54 +02:00
${ STACKER } --debug build \
2022-11-10 12:09:39 -08:00
-f build/stacker.yaml \
2023-02-11 00:52:54 +02:00
--substitute PWD = $$ PWD \
--substitute COMMIT = $$ COMMIT \
--substitute ARCH = $$ ARCH \
--substitute OS = $$ OS
2020-01-24 11:54:38 -06:00
.PHONY : image
image :
2022-11-10 12:09:39 -08:00
${ CONTAINER_RUNTIME } build ${ BUILD_ARGS } -f build/Dockerfile -t zot:latest .
2022-03-23 00:13:10 +02:00
$(BATS) :
rm -rf bats-core; \
git clone https://github.com/bats-core/bats-core.git; \
cd bats-core; ./install.sh $( TOOLSDIR) ; cd ..; \
rm -rf bats-core
2022-10-19 06:47:41 +03:00
.PHONY : test -push -pull
test-push-pull : binary check -skopeo $( BATS ) $( REGCLIENT ) $( ORAS ) $( HELM )
2022-04-27 09:00:20 +03:00
$( BATS) --trace --print-output-on-failure test/blackbox/pushpull.bats
2022-03-23 00:13:10 +02:00
2022-10-19 06:47:41 +03:00
.PHONY : test -push -pull -verbose
test-push-pull-verbose : binary check -skopeo $( BATS )
2022-04-27 09:00:20 +03:00
$( BATS) --trace --verbose-run --print-output-on-failure --show-output-of-passing-tests test/blackbox/pushpull.bats
2022-11-22 20:29:57 +02:00
.PHONY : test -cloud -only
test-cloud-only : binary check -skopeo $( BATS )
$( BATS) --trace --print-output-on-failure test/blackbox/cloud-only.bats
.PHONY : test -cloud -only -verbose
test-cloud-only-verbose : binary check -skopeo $( BATS )
$( BATS) --trace --verbose-run --print-output-on-failure --show-output-of-passing-tests test/blackbox/cloud-only.bats
2022-10-19 06:47:41 +03:00
.PHONY : test -bats -sync
test-bats-sync : EXTENSIONS =sync
2022-11-22 20:10:32 +02:00
test-bats-sync : binary binary -minimal check -skopeo $( BATS ) $( NOTATION ) $( COSIGN )
2022-04-27 09:00:20 +03:00
$( BATS) --trace --print-output-on-failure test/blackbox/sync.bats
2022-12-16 19:33:46 +02:00
$( BATS) --trace --print-output-on-failure test/blackbox/sync_docker.bats
2022-04-27 09:00:20 +03:00
2022-10-19 06:47:41 +03:00
.PHONY : test -bats -sync -verbose
test-bats-sync-verbose : EXTENSIONS =sync
2022-11-22 20:10:32 +02:00
test-bats-sync-verbose : binary binary -minimal check -skopeo $( BATS ) $( NOTATION ) $( COSIGN )
2022-04-27 09:00:20 +03:00
$( BATS) --trace -t -x -p --verbose-run --print-output-on-failure --show-output-of-passing-tests test/blackbox/sync.bats
2022-12-16 19:33:46 +02:00
$( BATS) --trace -t -x -p --verbose-run --print-output-on-failure --show-output-of-passing-tests test/blackbox/sync_docker.bats
2022-04-27 09:00:20 +03:00
2022-10-19 06:47:41 +03:00
.PHONY : test -bats -cve
test-bats-cve : EXTENSIONS =search
test-bats-cve : binary cli check -skopeo $( BATS )
2022-04-27 09:00:20 +03:00
$( BATS) --trace --print-output-on-failure test/blackbox/cve.bats
2022-10-19 06:47:41 +03:00
.PHONY : test -bats -cve -verbose
test-bats-cve-verbose : EXTENSIONS =search
test-bats-cve-verbose : binary cli check -skopeo $( BATS )
2022-04-27 09:00:20 +03:00
$( BATS) --trace -t -x -p --verbose-run --print-output-on-failure --show-output-of-passing-tests test/blackbox/cve.bats
2022-10-19 06:47:41 +03:00
.PHONY : test -bats -scrub
test-bats-scrub : EXTENSIONS =scrub
test-bats-scrub : binary check -skopeo $( BATS )
2022-04-27 09:00:20 +03:00
$( BATS) --trace --print-output-on-failure test/blackbox/scrub.bats
2022-10-19 06:47:41 +03:00
.PHONY : test -bats -scrub -verbose
test-bats-scrub-verbose : EXTENSIONS =scrub
test-bats-scrub-verbose : binary check -skopeo $( BATS )
2022-04-27 09:00:20 +03:00
$( BATS) --trace -p --verbose-run --print-output-on-failure --show-output-of-passing-tests test/blackbox/scrub.bats
2022-10-19 06:47:41 +03:00
.PHONY : test -bats -metrics
test-bats-metrics : EXTENSIONS =metrics
test-bats-metrics : binary check -skopeo $( BATS )
2022-04-27 09:00:20 +03:00
$( BATS) --trace --print-output-on-failure test/blackbox/metrics.bats
2022-10-19 06:47:41 +03:00
.PHONY : test -bats -metrics -verbose
test-bats-metrics-verbose : EXTENSIONS =metrics
test-bats-metrics-verbose : binary check -skopeo $( BATS )
2022-04-27 09:00:20 +03:00
$( BATS) --trace -p --verbose-run --print-output-on-failure --show-output-of-passing-tests test/blackbox/metrics.bats
2022-07-27 20:37:55 +03:00
2022-11-18 19:35:28 +02:00
.PHONY : test -anonymous -push -pull
test-anonymous-push-pull : binary check -skopeo $( BATS )
$( BATS) --trace --print-output-on-failure test/blackbox/anonymous_policy.bats
.PHONY : test -annotations
test-annotations : binary check -skopeo $( BATS ) $( STACKER ) $( NOTATION ) $( COSIGN )
$( BATS) --trace --print-output-on-failure test/blackbox/annotations.bats
.PHONY : test -detect -manifest -collision
test-detect-manifest-collision : binary check -skopeo $( BATS )
$( BATS) --trace --print-output-on-failure test/blackbox/detect_manifest_collision.bats
2022-07-27 20:37:55 +03:00
.PHONY : fuzz -all
fuzz-all : fuzztime =${1}
fuzz-all :
rm -rf test-data; \
rm -rf pkg/storage/testdata; \
git clone https://github.com/project-zot/test-data.git; \
mv test-data/storage pkg/storage/testdata; \
rm -rf test-data; \
bash test/scripts/fuzzAll.sh ${ fuzztime } ; \
rm -rf pkg/storage/testdata; \
2022-07-14 18:13:46 +03:00
2022-10-19 06:47:41 +03:00
$(STACKER) :
mkdir -p $( TOOLSDIR) /bin; \
curl -fsSL https://github.com/project-stacker/stacker/releases/latest/download/stacker -o $@ ; \
chmod +x $@
2022-11-01 18:16:14 +02:00
$(COSIGN) :
mkdir -p $( TOOLSDIR) /bin
curl -fsSL https://github.com/sigstore/cosign/releases/download/v1.13.0/cosign-linux-amd64 -o $@ ; \
chmod +x $@
2023-02-11 00:52:54 +02:00
2023-02-13 22:55:05 +02:00
# set ZUI_VERSION to empty string in order to clone zui locally and build default branch
2023-02-11 00:52:54 +02:00
.PHONY : ui
ui :
2023-02-13 22:55:05 +02:00
if [ -z $( ZUI_VERSION) ] ; then \
pwd = $$ ( pwd ) ; \
tdir = $$ ( mktemp -d) ; \
cd $$ tdir; \
2023-02-11 00:52:54 +02:00
git clone https://github.com/project-zot/zui.git; \
2023-02-13 22:55:05 +02:00
cd zui; \
npm install; \
npm run build; \
cd $$ pwd; \
rm -rf ./pkg/extensions/build; \
cp -R $$ tdir/zui/build ./pkg/extensions/; \
2023-02-11 00:52:54 +02:00
else \
2023-02-13 22:55:05 +02:00
curl -fsSL https://github.com/project-zot/zui/releases/download/$( ZUI_VERSION) /zui.tgz -o zui.tgz; \
tar xvzf zui.tgz -C ./pkg/extensions/; \
rm zui.tgz; \
2023-02-11 00:52:54 +02:00
fi ; \
2023-02-13 22:55:05 +02:00