test/system: Make tests non-destructive
This allows to run the test suite without having to worry about blasting the whole local state of Podman. This is done by creating a configuration file with a custom path for the storage of Podman and specifying the config file using an env var. The used location for the temporary storage is located either under XDG_CACHE_HOME and if the one is not defined, $HOME/.cache is used instead. The data are namespaced. This follows the XDG Base Directory Specification[0]. Other locations could be /tmp or /run but those locations usually use tmpfs and that filesystem can not be used by Podman[1] due to missing features in tmpfs. https://github.com/containers/toolbox/pull/818 [0] https://specifications.freedesktop.org/basedir-spec/latest/index.html [1] https://github.com/containers/podman/issues/10693#issuecomment-863007516
This commit is contained in:
parent
8a329752e0
commit
7a5f3ba2e2
|
@ -3,6 +3,8 @@
|
||||||
load 'libs/helpers'
|
load 'libs/helpers'
|
||||||
|
|
||||||
@test "test suite: Setup" {
|
@test "test suite: Setup" {
|
||||||
|
# Setup container storage paths
|
||||||
|
setup_containers_store
|
||||||
# Cache the default image for the system
|
# Cache the default image for the system
|
||||||
_pull_and_cache_distro_image $(get_system_id) $(get_system_version) || die
|
_pull_and_cache_distro_image $(get_system_id) $(get_system_version) || die
|
||||||
# Cache all images that will be needed during the tests
|
# Cache all images that will be needed during the tests
|
||||||
|
|
|
@ -6,6 +6,7 @@ load 'libs/helpers'
|
||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
check_xdg_runtime_dir
|
check_xdg_runtime_dir
|
||||||
|
setup_containers_store
|
||||||
cleanup_containers
|
cleanup_containers
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ load 'libs/helpers'
|
||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
check_xdg_runtime_dir
|
check_xdg_runtime_dir
|
||||||
|
setup_containers_store
|
||||||
cleanup_containers
|
cleanup_containers
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ load 'libs/helpers'
|
||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
check_xdg_runtime_dir
|
check_xdg_runtime_dir
|
||||||
|
setup_containers_store
|
||||||
cleanup_all
|
cleanup_all
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ load 'libs/helpers'
|
||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
check_xdg_runtime_dir
|
check_xdg_runtime_dir
|
||||||
|
setup_containers_store
|
||||||
cleanup_containers
|
cleanup_containers
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ load 'libs/helpers'
|
||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
check_xdg_runtime_dir
|
check_xdg_runtime_dir
|
||||||
|
setup_containers_store
|
||||||
cleanup_containers
|
cleanup_containers
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ load 'libs/helpers'
|
||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
check_xdg_runtime_dir
|
check_xdg_runtime_dir
|
||||||
|
setup_containers_store
|
||||||
cleanup_containers
|
cleanup_containers
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ load 'libs/helpers'
|
||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
check_xdg_runtime_dir
|
check_xdg_runtime_dir
|
||||||
|
setup_containers_store
|
||||||
cleanup_containers
|
cleanup_containers
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ load 'libs/helpers'
|
||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
check_xdg_runtime_dir
|
check_xdg_runtime_dir
|
||||||
|
setup_containers_store
|
||||||
cleanup_all
|
cleanup_all
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,4 +4,5 @@ load 'libs/helpers'
|
||||||
|
|
||||||
@test "test suite: Teardown" {
|
@test "test suite: Teardown" {
|
||||||
_clean_cached_images
|
_clean_cached_images
|
||||||
|
_clean_temporary_storage
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,8 +5,8 @@ These tests are built with BATS (Bash Automated Testing System).
|
||||||
The tests are meant to ensure that Toolbox's functionality remains stable
|
The tests are meant to ensure that Toolbox's functionality remains stable
|
||||||
throughout updates of both Toolbox and Podman/libpod.
|
throughout updates of both Toolbox and Podman/libpod.
|
||||||
|
|
||||||
**Warning**: The tests are not executed in an isolated environment. Running the
|
The tests are set up in a way that does not affect the host environment.
|
||||||
tests will clear all podman state (delete all containers, images, etc).
|
Running them won't remove any existing containers or images.
|
||||||
|
|
||||||
## Dependencies
|
## Dependencies
|
||||||
|
|
||||||
|
|
Binary file not shown.
|
@ -2,14 +2,19 @@
|
||||||
|
|
||||||
load 'libs/bats-support/load'
|
load 'libs/bats-support/load'
|
||||||
|
|
||||||
|
# Helpful globals
|
||||||
|
readonly TEMP_BASE_DIR="${XDG_CACHE_HOME:-$HOME/.cache}/toolbox"
|
||||||
|
readonly TEMP_STORAGE_DIR="${TEMP_BASE_DIR}/system-test-storage"
|
||||||
|
|
||||||
|
readonly IMAGE_CACHE_DIR="${BATS_RUN_TMPDIR}/image-cache"
|
||||||
|
readonly ROOTLESS_PODMAN_STORE_DIR="${TEMP_STORAGE_DIR}/storage"
|
||||||
|
readonly PODMAN_STORE_CONFIG_FILE="${TEMP_STORAGE_DIR}/store.conf"
|
||||||
|
|
||||||
# Podman and Toolbox commands to run
|
# Podman and Toolbox commands to run
|
||||||
readonly PODMAN=${PODMAN:-podman}
|
readonly PODMAN=${PODMAN:-podman}
|
||||||
readonly TOOLBOX=${TOOLBOX:-toolbox}
|
readonly TOOLBOX=${TOOLBOX:-toolbox}
|
||||||
readonly SKOPEO=$(command -v skopeo)
|
readonly SKOPEO=$(command -v skopeo)
|
||||||
|
|
||||||
# Helpful globals
|
|
||||||
readonly IMAGE_CACHE_DIR="${BATS_RUN_TMPDIR}/image-cache"
|
|
||||||
|
|
||||||
# Images
|
# Images
|
||||||
declare -Ag IMAGES=([busybox]="quay.io/toolbox_tests/busybox" \
|
declare -Ag IMAGES=([busybox]="quay.io/toolbox_tests/busybox" \
|
||||||
[fedora]="registry.fedoraproject.org/fedora-toolbox" \
|
[fedora]="registry.fedoraproject.org/fedora-toolbox" \
|
||||||
|
@ -26,6 +31,19 @@ function cleanup_containers() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function _setup_containers_store() {
|
||||||
|
mkdir -p ${TEMP_STORAGE_DIR}
|
||||||
|
# Setup a storage config file for PODMAN
|
||||||
|
echo -e "[storage]\n driver = \"overlay\"\n rootless_storage_path = \"${ROOTLESS_PODMAN_STORE_DIR}\"\n" > ${PODMAN_STORE_CONFIG_FILE}
|
||||||
|
export CONTAINERS_STORAGE_CONF=${PODMAN_STORE_CONFIG_FILE}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function _clean_temporary_storage() {
|
||||||
|
rm -rf ${TEMP_STORAGE_DIR}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
# Pulls an image using Podman and saves it to a image dir using Skopeo
|
# Pulls an image using Podman and saves it to a image dir using Skopeo
|
||||||
#
|
#
|
||||||
# Parameters
|
# Parameters
|
||||||
|
@ -69,7 +87,7 @@ function _pull_and_cache_distro_image() {
|
||||||
|
|
||||||
sleep $timeout
|
sleep $timeout
|
||||||
done
|
done
|
||||||
|
|
||||||
if ! $pulled; then
|
if ! $pulled; then
|
||||||
echo "Failed to pull image ${image}"
|
echo "Failed to pull image ${image}"
|
||||||
assert_success
|
assert_success
|
||||||
|
@ -133,7 +151,8 @@ function pull_distro_image() {
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
|
|
||||||
run $SKOPEO copy "dir:${IMAGE_CACHE_DIR}/${image_archive}" "containers-storage:${image}"
|
# https://github.com/containers/skopeo/issues/547 for the options for containers-storage
|
||||||
|
run $SKOPEO copy "dir:${IMAGE_CACHE_DIR}/${image_archive}" "containers-storage:[overlay@$ROOTLESS_PODMAN_STORE_DIR+$ROOTLESS_PODMAN_STORE_DIR]${image}"
|
||||||
if [ "$status" -ne 0 ]; then
|
if [ "$status" -ne 0 ]; then
|
||||||
echo "Failed to load image ${image} from cache ${IMAGE_CACHE_DIR}/${image_archive}"
|
echo "Failed to load image ${image} from cache ${IMAGE_CACHE_DIR}/${image_archive}"
|
||||||
assert_success
|
assert_success
|
||||||
|
|
Loading…
Reference in New Issue