2012-05-21 20:55:48 +04:00
#!/bin/bash
# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
# ex: ts=8 sw=4 sts=4 et filetype=sh
TEST_DESCRIPTION = "Basic systemd setup"
2013-04-23 04:39:40 +04:00
. $TEST_BASE_DIR /test-functions
2012-05-21 20:55:48 +04:00
2013-11-06 02:32:56 +04:00
check_result_qemu( ) {
2012-05-21 20:55:48 +04:00
ret = 1
mkdir -p $TESTDIR /root
mount ${ LOOPDEV } p1 $TESTDIR /root
[ [ -e $TESTDIR /root/testok ] ] && ret = 0
2013-11-06 02:32:56 +04:00
[ [ -f $TESTDIR /root/failed ] ] && cp -a $TESTDIR /root/failed $TESTDIR
2015-11-19 17:48:21 +03:00
cp -a $TESTDIR /root/var/log/journal $TESTDIR
2012-05-21 20:55:48 +04:00
umount $TESTDIR /root
2013-11-06 02:32:56 +04:00
[ [ -f $TESTDIR /failed ] ] && cat $TESTDIR /failed
2012-05-21 20:55:48 +04:00
ls -l $TESTDIR /journal/*/*.journal
2012-05-24 16:32:48 +04:00
test -s $TESTDIR /failed && ret = $(( $ret + 1 ))
2012-05-21 20:55:48 +04:00
return $ret
}
2012-05-24 17:51:10 +04:00
test_run( ) {
2013-12-08 03:01:53 +04:00
if run_qemu; then
2013-11-06 02:32:56 +04:00
check_result_qemu || return 1
2012-05-25 20:32:55 +04:00
else
2013-12-08 03:01:53 +04:00
dwarn "can't run QEMU, skipping"
2012-05-25 20:32:55 +04:00
fi
if check_nspawn; then
2013-11-06 02:32:56 +04:00
run_nspawn
check_result_nspawn || return 1
2012-05-25 20:32:55 +04:00
else
dwarn "can't run systemd-nspawn, skipping"
2012-05-24 18:00:33 +04:00
fi
2012-05-24 17:51:10 +04:00
return 0
}
2012-05-21 20:55:48 +04:00
test_setup( ) {
2013-11-06 02:32:56 +04:00
create_empty_image
2012-05-21 20:55:48 +04:00
mkdir -p $TESTDIR /root
mount ${ LOOPDEV } p1 $TESTDIR /root
# Create what will eventually be our root filesystem onto an overlay
(
LOG_LEVEL = 5
2012-05-25 20:32:55 +04:00
eval $( udevadm info --export --query= env --name= ${ LOOPDEV } p2)
2013-11-06 02:32:56 +04:00
setup_basic_environment
2012-05-21 20:55:48 +04:00
# setup the testsuite service
2012-05-24 17:27:53 +04:00
cat >$initdir /etc/systemd/system/testsuite.service <<EOF
2012-05-21 20:55:48 +04:00
[ Unit]
Description = Testsuite service
After = multi-user.target
[ Service]
2015-11-09 01:00:34 +03:00
ExecStart = /bin/sh -x -c 'systemctl --failed --no-legend --no-pager > /failed ; echo OK > /testok'
2012-05-21 20:55:48 +04:00
Type = oneshot
EOF
2013-01-26 01:19:19 +04:00
2013-11-06 02:32:56 +04:00
setup_testsuite
2015-11-25 20:51:17 +03:00
) || return 1
2013-11-06 02:32:56 +04:00
setup_nspawn_root
2012-05-25 20:32:55 +04:00
2015-11-19 15:27:39 +03:00
# mask some services that we do not want to run in these tests
ln -s /dev/null $initdir /etc/systemd/system/systemd-hwdb-update.service
ln -s /dev/null $initdir /etc/systemd/system/systemd-journal-catalog-update.service
ln -s /dev/null $initdir /etc/systemd/system/systemd-networkd.service
ln -s /dev/null $initdir /etc/systemd/system/systemd-networkd.socket
ln -s /dev/null $initdir /etc/systemd/system/systemd-resolved.service
2012-05-25 20:32:55 +04:00
ddebug " umount $TESTDIR /root "
2012-05-24 17:51:10 +04:00
umount $TESTDIR /root
2012-05-21 20:55:48 +04:00
}
test_cleanup( ) {
umount $TESTDIR /root 2>/dev/null
[ [ $LOOPDEV ] ] && losetup -d $LOOPDEV
return 0
}
do_test " $@ "