2012-09-13 23:19:05 +02:00
#!/bin/bash
# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
# ex: ts=8 sw=4 sts=4 et filetype=sh
2017-08-07 21:09:21 +02:00
set -e
2012-09-13 23:19:05 +02:00
TEST_DESCRIPTION = "cryptsetup systemd setup"
2017-08-04 14:34:14 +02:00
TEST_NO_NSPAWN = 1
2012-09-13 23:19:05 +02:00
2013-04-22 20:39:40 -04:00
. $TEST_BASE_DIR /test-functions
2012-09-13 23:19:05 +02:00
2013-11-05 23:32:56 +01:00
check_result_qemu( ) {
2012-09-13 23:19:05 +02:00
ret = 1
mkdir -p $TESTDIR /root
mount ${ LOOPDEV } p1 $TESTDIR /root
[ [ -e $TESTDIR /root/testok ] ] && ret = 0
2013-11-05 23:32:56 +01:00
[ [ -f $TESTDIR /root/failed ] ] && cp -a $TESTDIR /root/failed $TESTDIR
2012-09-13 23:19:05 +02:00
cryptsetup luksOpen ${ LOOPDEV } p2 varcrypt <$TESTDIR /keyfile
mount /dev/mapper/varcrypt $TESTDIR /root/var
2015-11-19 14:48:21 +00:00
cp -a $TESTDIR /root/var/log/journal $TESTDIR
2012-09-13 23:19:05 +02:00
umount $TESTDIR /root/var
umount $TESTDIR /root
cryptsetup luksClose /dev/mapper/varcrypt
2013-11-05 23:32:56 +01:00
[ [ -f $TESTDIR /failed ] ] && cat $TESTDIR /failed
2012-09-13 23:19:05 +02:00
ls -l $TESTDIR /journal/*/*.journal
test -s $TESTDIR /failed && ret = $(( $ret + 1 ))
return $ret
}
test_setup( ) {
2013-11-05 23:32:56 +01:00
create_empty_image
2012-09-13 23:19:05 +02:00
echo -n test >$TESTDIR /keyfile
2019-03-15 10:05:33 +01:00
cryptsetup -q luksFormat --pbkdf pbkdf2 --pbkdf-force-iterations 1000 ${ LOOPDEV } p2 $TESTDIR /keyfile
2012-09-13 23:19:05 +02:00
cryptsetup luksOpen ${ LOOPDEV } p2 varcrypt <$TESTDIR /keyfile
2017-11-07 09:51:30 -05:00
mkfs.ext4 -L var /dev/mapper/varcrypt
2012-09-13 23:19:05 +02:00
mkdir -p $TESTDIR /root
mount ${ LOOPDEV } p1 $TESTDIR /root
mkdir -p $TESTDIR /root/var
mount /dev/mapper/varcrypt $TESTDIR /root/var
# Create what will eventually be our root filesystem onto an overlay
(
LOG_LEVEL = 5
eval $( udevadm info --export --query= env --name= /dev/mapper/varcrypt)
eval $( udevadm info --export --query= env --name= ${ LOOPDEV } p2)
2013-11-05 23:32:56 +01:00
setup_basic_environment
2012-09-13 23:19:05 +02:00
2018-11-01 17:26:36 +09:00
# mask some services that we do not want to run in these tests
ln -fs /dev/null $initdir /etc/systemd/system/systemd-hwdb-update.service
ln -fs /dev/null $initdir /etc/systemd/system/systemd-journal-catalog-update.service
ln -fs /dev/null $initdir /etc/systemd/system/systemd-networkd.service
ln -fs /dev/null $initdir /etc/systemd/system/systemd-networkd.socket
ln -fs /dev/null $initdir /etc/systemd/system/systemd-resolved.service
ln -fs /dev/null $initdir /etc/systemd/system/systemd-machined.service
2012-09-13 23:19:05 +02:00
# setup the testsuite service
cat >$initdir /etc/systemd/system/testsuite.service <<EOF
[ Unit]
Description = Testsuite service
After = multi-user.target
[ Service]
2016-04-25 13:01:25 -04:00
ExecStart = /bin/sh -x -c 'systemctl --state=failed --no-legend --no-pager > /failed ; echo OK > /testok'
2012-09-13 23:19:05 +02:00
Type = oneshot
EOF
2013-01-25 22:19:19 +01:00
2013-11-05 23:32:56 +01:00
setup_testsuite
2012-09-13 23:19:05 +02:00
2013-11-05 23:32:56 +01:00
install_dmevent
2013-12-08 00:30:16 +01:00
generate_module_dependencies
2013-11-05 23:32:56 +01:00
cat >$initdir /etc/crypttab <<EOF
$DM_NAME UUID = $ID_FS_UUID /etc/varkey
2012-09-13 23:19:05 +02:00
EOF
2013-11-05 23:32:56 +01:00
echo -n test > $initdir /etc/varkey
cat $initdir /etc/crypttab | ddebug
2012-09-13 23:19:05 +02:00
2013-11-05 23:32:56 +01:00
cat >>$initdir /etc/fstab <<EOF
2017-11-07 09:51:30 -05:00
/dev/mapper/varcrypt /var ext4 defaults 0 1
2013-11-05 23:32:56 +01:00
EOF
2015-11-25 17:51:17 +00:00
) || return 1
2012-09-13 23:19:05 +02:00
ddebug " umount $TESTDIR /root/var "
umount $TESTDIR /root/var
cryptsetup luksClose /dev/mapper/varcrypt
ddebug " umount $TESTDIR /root "
umount $TESTDIR /root
}
test_cleanup( ) {
2017-08-07 21:09:21 +02:00
[ -d $TESTDIR /root/var ] && mountpoint $TESTDIR /root/var && umount $TESTDIR /root/var
2012-09-13 23:19:05 +02:00
[ [ -b /dev/mapper/varcrypt ] ] && cryptsetup luksClose /dev/mapper/varcrypt
2017-08-07 21:09:21 +02:00
umount $TESTDIR /root 2>/dev/null || true
2012-09-13 23:19:05 +02:00
[ [ $LOOPDEV ] ] && losetup -d $LOOPDEV
return 0
}
do_test " $@ "