From add3e0676b17840d088de221fee3bf9a721dbe92 Mon Sep 17 00:00:00 2001 From: Panu Matilainen Date: Wed, 22 Jan 2025 15:21:25 +0200 Subject: [PATCH] Run test-suite environment setup inside the image Commit c17cc691569040fdfd741c2a423e9efecde181b0 introduced an `rpmdb --initdb` call into test-suite make_install() but at that point, it's actually the rpm from the host, which is NOT what we want. Split the image preparation to two stages: install, which runs from the outside and basically just copies data into the image, and setup which runs from inside the image. For this we need some extra container gymnastics. Fixes: #3530 --- tests/CMakeLists.txt | 1 + tests/mktree.common | 21 +-------------------- tests/mktree.oci | 6 ++++-- tests/mktree.rootfs | 1 + tests/setup.sh | 25 +++++++++++++++++++++++++ 5 files changed, 32 insertions(+), 22 deletions(-) create mode 100755 tests/setup.sh diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index adc09aea98..bce3ffad7e 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -106,6 +106,7 @@ message(STATUS "Using mktree backend: ${MKTREE_BACKEND} " "(native: ${MKTREE_NATIVE})") configure_file(mktree.common mktree.common @ONLY) configure_file(mktree.${MKTREE_BACKEND} mktree @ONLY) +configure_file(setup.sh setup.sh @ONLY) if (MKTREE_NATIVE) find_program(AUTOM4TE autom4te REQUIRED) diff --git a/tests/mktree.common b/tests/mktree.common index f1441dcef1..2998ea1119 100644 --- a/tests/mktree.common +++ b/tests/mktree.common @@ -18,25 +18,6 @@ make_install() ln -s $script_dir/rpmtests.sh $DESTDIR/usr/bin/rpmtests mkdir -p $DESTDIR/$script_dir - cp rpmtests atlocal mktree.common $DESTDIR/$script_dir/ + cp rpmtests atlocal mktree.common setup.sh $DESTDIR/$script_dir/ cp @CMAKE_CURRENT_SOURCE_DIR@/rpmtests.sh $DESTDIR/$script_dir/ - - mkdir -p $DESTDIR/build - ln -sf ../data/SOURCES $DESTDIR/build/ - - # setup an empty db that all tests are pointed to by default - dbpath="/var/lib/rpm-testsuite" - mkdir -p $DESTDIR/$dbpath - echo "%_dbpath $dbpath" > $DESTDIR/@CMAKE_INSTALL_FULL_SYSCONFDIR@/rpm/macros.db - rpmdb --dbpath $DESTDIR/$dbpath --initdb - - # system-wide config to match our test environment - cp @CMAKE_CURRENT_SOURCE_DIR@/data/macros.testenv $DESTDIR/@CMAKE_INSTALL_FULL_SYSCONFDIR@/rpm/ - - # gpg-connect-agent is very, very unhappy if this doesn't exist - mkdir -p $DESTDIR/root/.gnupg - chmod 700 $DESTDIR/root/.gnupg - - # set up new-style XDG config directory - mkdir -p $DESTDIR/root/.config/rpm } diff --git a/tests/mktree.oci b/tests/mktree.oci index b7d79570be..06c004bba3 100755 --- a/tests/mktree.oci +++ b/tests/mktree.oci @@ -70,9 +70,11 @@ case $CMD in [ -n "$($PODMAN images -q $IMAGE)" ] && $PODMAN rmi $IMAGE if [ $NATIVE == yes ]; then # Native build - id=$($PODMAN create $IMAGE/base) - trap "$PODMAN rm $id >/dev/null" EXIT + id=$($PODMAN create -t $IMAGE/base) + trap "$PODMAN kill $id >/dev/null; $PODMAN rm $id > /dev/null" EXIT + $PODMAN start $id make_install $($PODMAN mount $id) + $PODMAN exec $id /usr/share/mktree/setup.sh $PODMAN commit -q $id $IMAGE else # Standalone build diff --git a/tests/mktree.rootfs b/tests/mktree.rootfs index 409aa90eda..4357c2800c 100755 --- a/tests/mktree.rootfs +++ b/tests/mktree.rootfs @@ -14,6 +14,7 @@ case $CMD in build) source ./mktree.common make_install / + ./setup.sh / ;; check) ./rpmtests "$@" diff --git a/tests/setup.sh b/tests/setup.sh new file mode 100755 index 0000000000..91c40f7921 --- /dev/null +++ b/tests/setup.sh @@ -0,0 +1,25 @@ +#!/bin/bash + +# Setup the environment inside the test-image +# DESTDIR is only for testing purposes, inside the image it's always / +export DESTDIR=${1:-/} + +mkdir -p $DESTDIR/build +ln -sf ../data/SOURCES $DESTDIR/build/ + +# setup an empty db that all tests are pointed to by default +dbpath="/var/lib/rpm-testsuite" +mkdir -p $DESTDIR/$dbpath +echo "%_dbpath $dbpath" > $DESTDIR/@CMAKE_INSTALL_FULL_SYSCONFDIR@/rpm/macros.db +rpmdb --dbpath $DESTDIR/$dbpath --initdb + +# system-wide config to match our test environment +cp /data/macros.testenv $DESTDIR/@CMAKE_INSTALL_FULL_SYSCONFDIR@/rpm/ + +# gpg-connect-agent is very, very unhappy if this doesn't exist +mkdir -p $DESTDIR/root/.gnupg +chmod 700 $DESTDIR/root/.gnupg + +# set up new-style XDG config directory +mkdir -p $DESTDIR/root/.config/rpm +