#!/bin/bash set -e TEST_DESCRIPTION="cryptsetup systemd setup" TEST_NO_NSPAWN=1 . $TEST_BASE_DIR/test-functions check_result_qemu() { ret=1 mkdir -p $TESTDIR/root mount ${LOOPDEV}p1 $TESTDIR/root [[ -e $TESTDIR/root/testok ]] && ret=0 [[ -f $TESTDIR/root/failed ]] && cp -a $TESTDIR/root/failed $TESTDIR cryptsetup luksOpen ${LOOPDEV}p2 varcrypt <$TESTDIR/keyfile mount /dev/mapper/varcrypt $TESTDIR/root/var cp -a $TESTDIR/root/var/log/journal $TESTDIR umount $TESTDIR/root/var umount $TESTDIR/root cryptsetup luksClose /dev/mapper/varcrypt [[ -f $TESTDIR/failed ]] && cat $TESTDIR/failed ls -l $TESTDIR/journal/*/*.journal test -s $TESTDIR/failed && ret=$(($ret+1)) return $ret } test_setup() { create_empty_image echo -n test >$TESTDIR/keyfile cryptsetup -q luksFormat --pbkdf pbkdf2 --pbkdf-force-iterations 1000 ${LOOPDEV}p2 $TESTDIR/keyfile cryptsetup luksOpen ${LOOPDEV}p2 varcrypt <$TESTDIR/keyfile mkfs.ext4 -L var /dev/mapper/varcrypt 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) setup_basic_environment # 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 # setup the testsuite service cat >$initdir/etc/systemd/system/testsuite.service < /failed ; echo OK > /testok' Type=oneshot EOF setup_testsuite install_dmevent generate_module_dependencies cat >$initdir/etc/crypttab < $initdir/etc/varkey cat $initdir/etc/crypttab | ddebug cat >>$initdir/etc/fstab </dev/null || true [[ $LOOPDEV ]] && losetup -d $LOOPDEV return 0 } do_test "$@"