File 0018-TEST-17-UDEV-WANTS-adapt-for-SUSE-openQA.patch of Package systemd-v244-testsuite
From eeebc593d65357f884d1b6bc3328d19ac79a45ab Mon Sep 17 00:00:00 2001
From: Thomas Blume <Thomas.Blume@suse.com>
Date: Thu, 19 Dec 2019 09:00:32 +0100
Subject: [PATCH 18/24] TEST-17-UDEV-WANTS: adapt for SUSE openQA
---
test/TEST-17-UDEV-WANTS/test.sh | 47 ++++++++++++++++++++++++++++++++----
test/TEST-17-UDEV-WANTS/testsuite.sh | 46 +++++++++++++++++------------------
2 files changed, 65 insertions(+), 28 deletions(-)
diff --git a/test/TEST-17-UDEV-WANTS/test.sh b/test/TEST-17-UDEV-WANTS/test.sh
index 1cdbbd2d8a..2d47923a4d 100755
--- a/test/TEST-17-UDEV-WANTS/test.sh
+++ b/test/TEST-17-UDEV-WANTS/test.sh
@@ -3,18 +3,35 @@ set -e
TEST_DESCRIPTION="UDEV SYSTEMD_WANTS property"
TEST_NO_NSPAWN=1
+export TEST_BASE_DIR=/var/opt/systemd-tests/test
. $TEST_BASE_DIR/test-functions
-QEMU_TIMEOUT=300
+
+test_run() {
+ ret=1
+ systemctl daemon-reload
+ systemctl start testsuite.service || return 1
+ systemctl status --full testsuite.service
+ if [ -z "$TEST_NO_NSPAWN" ]; then
+ if run_nspawn; then
+ check_result_nspawn || return 1
+ else
+ dwarn "can't run systemd-nspawn, skipping"
+ fi
+ fi
+ test -s /failed && ret=$(($ret+1))
+ [[ -e /testok ]] && ret=0
+ return $ret
+}
test_setup() {
- create_empty_image_rootdir
+ mkdir -p $TESTDIR/root
+ initdir=$TESTDIR/root
+ STRIP_BINARIES=no
(
LOG_LEVEL=5
- eval $(udevadm info --export --query=env --name=${LOOPDEV}p2)
setup_basic_environment
- mask_supporting_services
# setup the testsuite service
cat >$initdir/etc/systemd/system/testsuite.service <<EOF
@@ -23,12 +40,32 @@ Description=Testsuite service
[Service]
ExecStart=/bin/bash -x /testsuite.sh
+ExecStartPost=/bin/sh -x -c 'systemctl --state=failed --no-pager > /failed'
Type=oneshot
+StandardOutput=kmsg
+StandardError=kmsg
EOF
- cp testsuite.sh $initdir/
+ cp testsuite.sh /
+
+ for service in testsuite.service; do
+ cp $initdir/etc/systemd/system/$service /etc/systemd/system/
+ done
setup_testsuite
)
+
+ mask_supporting_services
+
+}
+
+test_cleanup() {
+ for service in testsuite.service; do
+ rm /etc/systemd/system/$service
+ done
+ [[ -e /testok ]] && rm /testok
+ [[ -e /failed ]] && rm /failed
+ rm /testsuite.sh
+ return 0
}
do_test "$@"
diff --git a/test/TEST-17-UDEV-WANTS/testsuite.sh b/test/TEST-17-UDEV-WANTS/testsuite.sh
index ceac3697b5..cc8319d841 100755
--- a/test/TEST-17-UDEV-WANTS/testsuite.sh
+++ b/test/TEST-17-UDEV-WANTS/testsuite.sh
@@ -6,48 +6,48 @@ mkdir -p /run/udev/rules.d/
rm -f /run/udev/rules.d/50-testsuite.rules
udevadm control --reload
-udevadm trigger /dev/sda
+udevadm trigger /dev/vda
while : ; do
(
- udevadm info /dev/sda | grep -q -v SYSTEMD_WANTS=foobar.service
- udevadm info /dev/sda | grep -q -v SYSTEMD_WANTS=waldo.service
- systemctl show -p WantedBy foobar.service | grep -q -v sda
- systemctl show -p WantedBy waldo.service | grep -q -v sda
+ udevadm info /dev/vda | grep -q -v SYSTEMD_WANTS=foobar.service
+ udevadm info /dev/vda | grep -q -v SYSTEMD_WANTS=waldo.service
+ systemctl show -p WantedBy foobar.service | grep -q -v vda
+ systemctl show -p WantedBy waldo.service | grep -q -v vda
) && break
sleep .5
done
cat > /run/udev/rules.d/50-testsuite.rules <<EOF
-ACTION!="remove", SUBSYSTEM=="block", KERNEL=="sda", ENV{SYSTEMD_WANTS}="foobar.service"
+ACTION!="remove", SUBSYSTEM=="block", KERNEL=="vda", ENV{SYSTEMD_WANTS}="foobar.service"
EOF
udevadm control --reload
-udevadm trigger /dev/sda
+udevadm trigger /dev/vda
while : ; do
(
- udevadm info /dev/sda | grep -q SYSTEMD_WANTS=foobar.service
- udevadm info /dev/sda | grep -q -v SYSTEMD_WANTS=waldo.service
- systemctl show -p WantedBy foobar.service | grep -q sda
- systemctl show -p WantedBy waldo.service | grep -q -v sda
+ udevadm info /dev/vda | grep -q SYSTEMD_WANTS=foobar.service
+ udevadm info /dev/vda | grep -q -v SYSTEMD_WANTS=waldo.service
+ systemctl show -p WantedBy foobar.service | grep -q vda
+ systemctl show -p WantedBy waldo.service | grep -q -v vda
) && break
sleep .5
done
cat > /run/udev/rules.d/50-testsuite.rules <<EOF
-ACTION!="remove", SUBSYSTEM=="block", KERNEL=="sda", ENV{SYSTEMD_WANTS}="waldo.service"
+ACTION!="remove", SUBSYSTEM=="block", KERNEL=="vda", ENV{SYSTEMD_WANTS}="waldo.service"
EOF
udevadm control --reload
-udevadm trigger /dev/sda
+udevadm trigger /dev/vda
while : ; do
(
- udevadm info /dev/sda | grep -q -v SYSTEMD_WANTS=foobar.service
- udevadm info /dev/sda | grep -q SYSTEMD_WANTS=waldo.service
- systemctl show -p WantedBy foobar.service | grep -q -v sda
- systemctl show -p WantedBy waldo.service | grep -q sda
+ udevadm info /dev/vda | grep -q -v SYSTEMD_WANTS=foobar.service
+ udevadm info /dev/vda | grep -q SYSTEMD_WANTS=waldo.service
+ systemctl show -p WantedBy foobar.service | grep -q -v vda
+ systemctl show -p WantedBy waldo.service | grep -q vda
) && break
sleep .5
@@ -56,19 +56,19 @@ done
rm /run/udev/rules.d/50-testsuite.rules
udevadm control --reload
-udevadm trigger /dev/sda
+udevadm trigger /dev/vda
while : ; do
(
- udevadm info /dev/sda | grep -q -v SYSTEMD_WANTS=foobar.service
- udevadm info /dev/sda | grep -q -v SYSTEMD_WANTS=waldo.service
- systemctl show -p WantedBy foobar.service | grep -q -v sda
- systemctl show -p WantedBy waldo.service | grep -q -v sda
+ udevadm info /dev/vda | grep -q -v SYSTEMD_WANTS=foobar.service
+ udevadm info /dev/vda | grep -q -v SYSTEMD_WANTS=waldo.service
+ systemctl show -p WantedBy foobar.service | grep -q -v vda
+ systemctl show -p WantedBy waldo.service | grep -q -v vda
) && break
sleep .5
done
-echo OK > /testok
+echo SUSEtest OK > /testok
exit 0
--
2.16.4