# Note: Intended to be run as "make run-blackbox-tests" or "make run-blackbox-ci" # Makefile target installs & checks all necessary tooling # Extra tools that are not covered in Makefile target needs to be added in verify_prerequisites() load helpers_zot function verify_prerequisites { if [ ! $(command -v curl) ]; then echo "you need to install curl as a prerequisite to running the tests" >&3 return 1 fi if [ ! $(command -v jq) ]; then echo "you need to install jq as a prerequisite to running the tests" >&3 return 1 fi return 0 } function setup_file() { # Verify prerequisites are available if ! $(verify_prerequisites); then exit 1 fi # Download test data to folder common for the entire suite, not just this file skopeo --insecure-policy copy --format=oci docker://ghcr.io/project-zot/golang:1.20 oci:${TEST_DATA_DIR}/golang:1.20 # Setup zot server local zot_root_dir=${BATS_FILE_TMPDIR}/zot local zot_config_file=${BATS_FILE_TMPDIR}/zot_config.json local oci_data_dir=${BATS_FILE_TMPDIR}/oci mkdir -p ${zot_root_dir} mkdir -p ${oci_data_dir} zot_port=$(get_free_port) echo ${zot_port} > ${BATS_FILE_TMPDIR}/zot.port cat > ${zot_config_file}< config.json echo "hello world" > artifact.txt run oras push --plain-http 127.0.0.1:${zot_port}/hello-artifact:v2 \ --config config.json:application/vnd.acme.rocket.config.v1+json artifact.txt:text/plain -d -v [ "$status" -eq 0 ] rm -f artifact.txt rm -f config.json } @test "pull oras artifact" { zot_port=`cat ${BATS_FILE_TMPDIR}/zot.port` run oras pull --plain-http 127.0.0.1:${zot_port}/hello-artifact:v2 -d -v [ "$status" -eq 0 ] grep -q "hello world" artifact.txt rm -f artifact.txt } @test "attach oras artifacts" { zot_port=`cat ${BATS_FILE_TMPDIR}/zot.port` # attach signature echo "{\"artifact\": \"\", \"signature\": \"pat hancock\"}" > ${BATS_FILE_TMPDIR}/signature.json run oras attach --disable-path-validation --plain-http 127.0.0.1:${zot_port}/golang:1.20 --artifact-type 'signature/example' ${BATS_FILE_TMPDIR}/signature.json:application/json [ "$status" -eq 0 ] # attach sbom echo "{\"version\": \"0.0.0.0\", \"artifact\": \"'127.0.0.1:${zot_port}/golang:1.20'\", \"contents\": \"good\"}" > ${BATS_FILE_TMPDIR}/sbom.json run oras attach --disable-path-validation --plain-http 127.0.0.1:${zot_port}/golang:1.20 --artifact-type 'sbom/example' ${BATS_FILE_TMPDIR}/sbom.json:application/json [ "$status" -eq 0 ] } @test "discover oras artifacts" { zot_port=`cat ${BATS_FILE_TMPDIR}/zot.port` run oras discover --plain-http --format json 127.0.0.1:${zot_port}/golang:1.20 [ "$status" -eq 0 ] [ $(echo "$output" | jq -r ".manifests | length") -eq 2 ] } @test "add and list tags using oras" { zot_port=`cat ${BATS_FILE_TMPDIR}/zot.port` run skopeo --insecure-policy copy --dest-tls-verify=false \ oci:${TEST_DATA_DIR}/golang:1.20 \ docker://127.0.0.1:${zot_port}/oras-tags:1.20 [ "$status" -eq 0 ] run oras tag --plain-http 127.0.0.1:${zot_port}/oras-tags:1.20 1 new latest [ "$status" -eq 0 ] run oras repo tags --plain-http 127.0.0.1:${zot_port}/oras-tags [ "$status" -eq 0 ] echo "$output" [ $(echo "$output" | wc -l) -eq 4 ] [ "${lines[-1]}" == "new" ] [ "${lines[-2]}" == "latest" ] [ "${lines[-3]}" == "1.20" ] [ "${lines[-4]}" == "1" ] run oras repo tags --plain-http --last new 127.0.0.1:${zot_port}/oras-tags [ "$status" -eq 0 ] echo "$output" [ -z $output ] run oras repo tags --plain-http --last latest 127.0.0.1:${zot_port}/oras-tags [ "$status" -eq 0 ] echo "$output" [ $(echo "$output" | wc -l) -eq 1 ] [ "${lines[-1]}" == "new" ] run oras repo tags --plain-http --last "1.20" 127.0.0.1:${zot_port}/oras-tags [ "$status" -eq 0 ] echo "$output" [ $(echo "$output" | wc -l) -eq 2 ] [ "${lines[-2]}" == "latest" ] [ "${lines[-1]}" == "new" ] run oras repo tags --plain-http --last "1" 127.0.0.1:${zot_port}/oras-tags [ "$status" -eq 0 ] echo "$output" [ $(echo "$output" | wc -l) -eq 3 ] [ "${lines[-3]}" == "1.20" ] [ "${lines[-2]}" == "latest" ] [ "${lines[-1]}" == "new" ] } @test "push helm chart" { zot_port=`cat ${BATS_FILE_TMPDIR}/zot.port` run helm package ${BATS_FILE_TMPDIR}/helm-charts/charts/zot -d ${BATS_FILE_TMPDIR} [ "$status" -eq 0 ] local chart_version=$(awk '/version/{printf $2}' ${BATS_FILE_TMPDIR}/helm-charts/charts/zot/Chart.yaml) run helm push ${BATS_FILE_TMPDIR}/zot-${chart_version}.tgz oci://localhost:${zot_port}/zot-chart [ "$status" -eq 0 ] } @test "pull helm chart" { zot_port=`cat ${BATS_FILE_TMPDIR}/zot.port` local chart_version=$(awk '/version/{printf $2}' ${BATS_FILE_TMPDIR}/helm-charts/charts/zot/Chart.yaml) run helm pull oci://localhost:${zot_port}/zot-chart/zot --version ${chart_version} -d ${BATS_FILE_TMPDIR} [ "$status" -eq 0 ] } @test "push image with regclient" { zot_port=`cat ${BATS_FILE_TMPDIR}/zot.port` run regctl registry set localhost:${zot_port} --tls disabled [ "$status" -eq 0 ] run regctl image copy ocidir://${TEST_DATA_DIR}/golang:1.20 localhost:${zot_port}/test-regclient [ "$status" -eq 0 ] } @test "pull image with regclient" { zot_port=`cat ${BATS_FILE_TMPDIR}/zot.port` run regctl image copy localhost:${zot_port}/test-regclient ocidir://${TEST_DATA_DIR}/golang:1.20 [ "$status" -eq 0 ] } @test "list repositories with regclient" { zot_port=`cat ${BATS_FILE_TMPDIR}/zot.port` run regctl repo ls localhost:${zot_port} [ "$status" -eq 0 ] found=0 for i in "${lines[@]}" do if [ "$i" = 'test-regclient' ]; then found=1 fi done [ "$found" -eq 1 ] run regctl repo ls --limit 2 localhost:${zot_port} [ "$status" -eq 0 ] echo "$output" [ $(echo "$output" | wc -l) -eq 2 ] [ "${lines[-2]}" == "busybox" ] [ "${lines[-1]}" == "golang" ] run regctl repo ls --last busybox --limit 1 localhost:${zot_port} [ "$status" -eq 0 ] echo "$output" [ $(echo "$output" | wc -l) -eq 1 ] [ "${lines[-1]}" == "golang" ] } @test "list image tags with regclient" { zot_port=`cat ${BATS_FILE_TMPDIR}/zot.port` run regctl tag ls localhost:${zot_port}/test-regclient [ "$status" -eq 0 ] found=0 for i in "${lines[@]}" do if [ "$i" = 'latest' ]; then found=1 fi done [ "$found" -eq 1 ] } @test "push manifest with regclient" { zot_port=`cat ${BATS_FILE_TMPDIR}/zot.port` manifest=$(regctl manifest get localhost:${zot_port}/test-regclient --format=raw-body) run regctl manifest put localhost:${zot_port}/test-regclient:1.0.0 --format oci --content-type application/vnd.oci.image.manifest.v1+json --format oci < Dockerfile < /testfile EOF docker build -f Dockerfile . -t localhost:${zot_port}/test run docker push localhost:${zot_port}/test [ "$status" -eq 1 ] run docker pull localhost:${zot_port}/test [ "$status" -eq 1 ] }