buildah/tests/commit.bats

99 lines
4.0 KiB
Bash

#!/usr/bin/env bats
load helpers
@test "commit-flags-order-verification" {
run_buildah 1 commit cnt1 --tls-verify
check_options_flag_err "--tls-verify"
run_buildah 1 commit cnt1 -q
check_options_flag_err "-q"
run_buildah 1 commit cnt1 -f=docker --quiet --creds=bla:bla
check_options_flag_err "-f=docker"
run_buildah 1 commit cnt1 --creds=bla:bla
check_options_flag_err "--creds=bla:bla"
}
@test "commit" {
cid=$(buildah from --pull --signature-policy ${TESTSDIR}/policy.json alpine)
buildah commit --signature-policy ${TESTSDIR}/policy.json $cid alpine-image
run_buildah images alpine-image
buildah rm $cid
buildah rmi -a
}
@test "commit format test" {
cid=$(buildah from --pull --signature-policy ${TESTSDIR}/policy.json alpine)
buildah commit --signature-policy ${TESTSDIR}/policy.json $cid alpine-image-oci
buildah commit --format docker --disable-compression=false --signature-policy ${TESTSDIR}/policy.json $cid alpine-image-docker
buildah --debug=false inspect --type=image --format '{{.Manifest}}' alpine-image-oci | grep "application/vnd.oci.image.layer.v1.tar"
buildah --debug=false inspect --type=image --format '{{.Manifest}}' alpine-image-docker | grep "application/vnd.docker.image.rootfs.diff.tar.gzip"
buildah rm $cid
buildah rmi -a
}
@test "commit quiet test" {
cid=$(buildah from --pull --signature-policy ${TESTSDIR}/policy.json alpine)
run_buildah --debug=false commit --iidfile /dev/null --signature-policy ${TESTSDIR}/policy.json -q $cid alpine-image
is "$output" "" "no output from commit"
buildah rm $cid
buildah rmi -a
}
@test "commit rm test" {
cid=$(buildah from --pull --signature-policy ${TESTSDIR}/policy.json alpine)
buildah commit --signature-policy ${TESTSDIR}/policy.json --rm $cid alpine-image
run_buildah 1 --debug=false rm $cid
is "$output" ".*error removing container \"alpine-working-container\": error reading build container: container not known" "buildah rm"
buildah rmi -a
}
@test "commit-alternate-storage" {
echo FROM
cid=$(buildah from --pull --signature-policy ${TESTSDIR}/policy.json openshift/hello-openshift)
echo COMMIT
buildah commit --signature-policy ${TESTSDIR}/policy.json $cid "containers-storage:[vfs@${TESTDIR}/root2+${TESTDIR}/runroot2]newimage"
echo FROM
buildah --storage-driver vfs --root ${TESTDIR}/root2 --runroot ${TESTDIR}/runroot2 from --signature-policy ${TESTSDIR}/policy.json newimage
}
@test "commit-rejected-name" {
cid=$(buildah from --pull --signature-policy ${TESTSDIR}/policy.json alpine)
run_buildah 1 --debug=false commit --signature-policy ${TESTSDIR}/policy.json $cid ThisNameShouldBeRejected
is "$output" ".*must be lower" "buildah commit output"
}
@test "commit-no-empty-created-by" {
if ! python3 -c 'import json, sys' 2> /dev/null ; then
skip "python interpreter with json module not found"
fi
target=new-image
cid=$(buildah from --pull --signature-policy ${TESTSDIR}/policy.json alpine)
run_buildah --debug=false config --created-by "untracked actions" $cid
run_buildah --debug=false commit --signature-policy ${TESTSDIR}/policy.json $cid ${target}
run_buildah --debug=false inspect --format '{{.Config}}' ${target}
config="$output"
run python3 -c 'import json, sys; config = json.load(sys.stdin); print(config["history"][len(config["history"])-1]["created_by"])' <<< "$config"
echo "$output"
[ "${status}" -eq 0 ]
[ "$output" == "untracked actions" ]
run_buildah --debug=false config --created-by "" $cid
run_buildah --debug=false commit --signature-policy ${TESTSDIR}/policy.json $cid ${target}
run_buildah --debug=false inspect --format '{{.Config}}' ${target}
config="$output"
run python3 -c 'import json, sys; config = json.load(sys.stdin); print(config["history"][len(config["history"])-1]["created_by"])' <<< "$config"
echo "$output"
[ "${status}" -eq 0 ]
[ "$output" == "/bin/sh" ]
}
@test "commit-no-name" {
cid=$(buildah from --pull --signature-policy ${TESTSDIR}/policy.json alpine)
run_buildah commit --signature-policy ${TESTSDIR}/policy.json $cid
}