2 # -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
3 # ex: ts=8 sw=4 sts=4 et filetype=sh
4 TEST_DESCRIPTION="Basic systemd setup"
6 . $TEST_BASE_DIR/test-functions
10 mkdir -p $TESTDIR/root
11 mount ${LOOPDEV}p1 $TESTDIR/root
12 [[ -e $TESTDIR/root/testok ]] && ret=0
13 [[ -f $TESTDIR/root/failed ]] && cp -a $TESTDIR/root/failed $TESTDIR
14 [[ -f $TESTDIR/root/var/log/journal ]] && cp -a $TESTDIR/root/var/log/journal $TESTDIR
16 [[ -f $TESTDIR/failed ]] && cat $TESTDIR/failed
17 ls -l $TESTDIR/journal/*/*.journal
18 test -s $TESTDIR/failed && ret=$(($ret+1))
24 check_result_qemu || return 1
26 dwarn "can't run QEMU, skipping"
30 check_result_nspawn || return 1
32 dwarn "can't run systemd-nspawn, skipping"
39 mkdir -p $TESTDIR/root
40 mount ${LOOPDEV}p1 $TESTDIR/root
42 # Create what will eventually be our root filesystem onto an overlay
45 eval $(udevadm info --export --query=env --name=${LOOPDEV}p2)
47 setup_basic_environment
49 # setup the testsuite service
50 cat >$initdir/etc/systemd/system/testsuite.service <<EOF
52 Description=Testsuite service
53 After=multi-user.target
56 ExecStart=/bin/bash -c 'set -x; ( systemctl --failed --no-legend --no-pager; systemctl status --failed ) > /failed ; echo OK > /testok; while : ;do echo "testsuite service waiting for journal to move to /var/log/journal" > /dev/console ; for i in /var/log/journal/*;do [ -d "\$i" ] && echo "\$i" && break 2; done; sleep 1; done; sleep 1; exit 0;'
64 ddebug "umount $TESTDIR/root"
69 umount $TESTDIR/root 2>/dev/null
70 [[ $LOOPDEV ]] && losetup -d $LOOPDEV