diff options
| -rw-r--r-- | man/systemd.network.xml | 2 | ||||
| -rw-r--r-- | src/core/device.c | 2 | ||||
| -rw-r--r-- | src/run/run.c | 4 | ||||
| -rw-r--r-- | src/shared/machine-pool.c | 8 | ||||
| -rw-r--r-- | test/TEST-08-ISSUE-2730/Makefile | 10 | ||||
| -rwxr-xr-x | test/TEST-08-ISSUE-2730/test.sh | 94 | ||||
| -rw-r--r-- | test/test-functions | 9 | 
7 files changed, 118 insertions, 11 deletions
| diff --git a/man/systemd.network.xml b/man/systemd.network.xml index c6bbb95833..73b9c00543 100644 --- a/man/systemd.network.xml +++ b/man/systemd.network.xml @@ -278,7 +278,7 @@              <para>An IPv6 address with the top 64 bits unset. When set, indicates the              64-bit interface part of SLAAC IPv6 addresses for this link. Note that              the token is only ever used for SLAAC, and not for DHCPv6 addresses, even -            in the case DHCP is requested by router advertisment. By default, the +            in the case DHCP is requested by router advertisement. By default, the              token is autogenerated.</para>            </listitem>          </varlistentry> diff --git a/src/core/device.c b/src/core/device.c index d201dc5e4b..28e4039da2 100644 --- a/src/core/device.c +++ b/src/core/device.c @@ -318,7 +318,7 @@ static int device_setup_unit(Manager *m, struct udev_device *dev, const char *pa           * the GC to have garbaged it. That's desired since the device           * unit may have a dependency on the mount unit which was           * added during the loading of the later. */ -        if (u && DEVICE(u)->state == DEVICE_PLUGGED) { +        if (dev && u && DEVICE(u)->state == DEVICE_PLUGGED) {                  /* This unit is in plugged state: we're sure it's                   * attached to a device. */                  if (!path_equal(DEVICE(u)->sysfs, sysfs)) { diff --git a/src/run/run.c b/src/run/run.c index e7f4c21f73..1ed1bd96bf 100644 --- a/src/run/run.c +++ b/src/run/run.c @@ -83,8 +83,8 @@ static void polkit_agent_open_if_enabled(void) {  static void help(void) {          printf("%s [OPTIONS...] {COMMAND} [ARGS...]\n\n"                 "Run the specified command in a transient scope or service or timer\n" -               "unit. If timer option is specified and unit is exist which is\n" -               "specified with --unit option then command can be omitted.\n\n" +               "unit. If a timer option is specified and the unit specified with\n" +               "the --unit option exists, the command can be omitted.\n\n"                 "  -h --help                       Show this help\n"                 "     --version                    Show package version\n"                 "     --no-ask-password            Do not prompt for password\n" diff --git a/src/shared/machine-pool.c b/src/shared/machine-pool.c index f080b849a4..23890c63a0 100644 --- a/src/shared/machine-pool.c +++ b/src/shared/machine-pool.c @@ -139,7 +139,7 @@ static int setup_machine_raw(uint64_t size, sd_bus_error *error) {                  execlp("mkfs.btrfs", "-Lvar-lib-machines", tmp, NULL);                  if (errno == ENOENT) -                        return 99; +                        _exit(99);                  _exit(EXIT_FAILURE);          } @@ -239,10 +239,8 @@ int setup_machine_directory(uint64_t size, sd_bus_error *error) {          }          r = mkfs_exists("btrfs"); -        if (r == -ENOENT) { -                log_debug("mkfs.btrfs is missing, cannot create loopback file for /var/lib/machines."); -                return 0; -        } +        if (r == 0) +                return sd_bus_error_set_errnof(error, ENOENT, "Cannot set up /var/lib/machines, mkfs.btrfs is missing");          if (r < 0)                  return r; diff --git a/test/TEST-08-ISSUE-2730/Makefile b/test/TEST-08-ISSUE-2730/Makefile new file mode 100644 index 0000000000..5e89a29eff --- /dev/null +++ b/test/TEST-08-ISSUE-2730/Makefile @@ -0,0 +1,10 @@ +all: +	@make -s --no-print-directory -C ../.. all +	@basedir=../.. TEST_BASE_DIR=../ ./test.sh --all +setup: +	@make --no-print-directory -C ../.. all +	@basedir=../.. TEST_BASE_DIR=../ ./test.sh --setup +clean: +	@basedir=../.. TEST_BASE_DIR=../ ./test.sh --clean +run: +	@basedir=../.. TEST_BASE_DIR=../ ./test.sh --run diff --git a/test/TEST-08-ISSUE-2730/test.sh b/test/TEST-08-ISSUE-2730/test.sh new file mode 100755 index 0000000000..92e70b828b --- /dev/null +++ b/test/TEST-08-ISSUE-2730/test.sh @@ -0,0 +1,94 @@ +#!/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="https://github.com/systemd/systemd/issues/2730" + +. $TEST_BASE_DIR/test-functions +SKIP_INITRD=yes +QEMU_TIMEOUT=180 +FSTYPE=ext4 + +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 +    cp -a $TESTDIR/root/var/log/journal $TESTDIR +    umount $TESTDIR/root +    [[ -f $TESTDIR/failed ]] && cat $TESTDIR/failed +    ls -l $TESTDIR/journal/*/*.journal +    test -s $TESTDIR/failed && ret=$(($ret+1)) +    return $ret +} + +test_run() { +    run_qemu || return 1 +    check_result_qemu || return 1 +    return 0 +} + +test_setup() { +    create_empty_image +    mkdir -p $TESTDIR/root +    mount ${LOOPDEV}p1 $TESTDIR/root + +    # Create what will eventually be our root filesystem onto an overlay +    ( +        LOG_LEVEL=5 +        eval $(udevadm info --export --query=env --name=${LOOPDEV}p2) + +        setup_basic_environment + +        # setup the testsuite service +        cat >$initdir/etc/systemd/system/testsuite.service <<EOF +[Unit] +Description=Testsuite service +After=multi-user.target + +[Service] +ExecStart=/bin/sh -x -c 'mount -o remount,rw /dev/sda1 && echo OK > /testok; systemctl poweroff' +Type=oneshot +EOF + +    rm $initdir/etc/fstab +    cat >$initdir/etc/systemd/system/-.mount <<EOF +[Unit] +Before=local-fs.target + +[Mount] +What=/dev/sda1 +Where=/ +Type=ext4 +Options=errors=remount-ro,noatime + +[Install] +WantedBy=local-fs.target +Alias=root.mount +EOF + +        setup_testsuite +    ) || return 1 + +    ln -s /etc/systemd/system/-.mount $initdir/etc/systemd/system/root.mount +    mkdir -p $initdir/etc/systemd/system/local-fs.target.wants +    ln -s /etc/systemd/system/-.mount $initdir/etc/systemd/system/local-fs.target.wants/-.mount + +    # 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 + +    ddebug "umount $TESTDIR/root" +    umount $TESTDIR/root +} + +test_cleanup() { +    umount $TESTDIR/root 2>/dev/null +    [[ $LOOPDEV ]] && losetup -d $LOOPDEV +    return 0 +} + +do_test "$@" diff --git a/test/test-functions b/test/test-functions index 6667e0524f..92e1ae9f8d 100644 --- a/test/test-functions +++ b/test/test-functions @@ -7,6 +7,8 @@ export PATH  LOOKS_LIKE_DEBIAN=$(source /etc/os-release && [[ "$ID" = "debian" || "$ID_LIKE" = "debian" ]] && echo yes)  KERNEL_VER=${KERNEL_VER-$(uname -r)}  KERNEL_MODS="/lib/modules/$KERNEL_VER/" +QEMU_TIMEOUT="${QEMU_TIMEOUT:-infinity}" +FSTYPE="${FSTYPE:-ext3}"  if ! ROOTLIBDIR=$(pkg-config --variable=systemdutildir systemd); then      echo "WARNING! Cannot determine rootlibdir from pkg-config, assuming /usr/lib/systemd" >&2 @@ -78,7 +80,7 @@ $KERNEL_APPEND \  -kernel $KERNEL_BIN \  " -    if [ "$INITRD" ]; then +    if [[ "$INITRD" && "$SKIP_INITRD" != "yes" ]]; then          QEMU_OPTIONS="$QEMU_OPTIONS -initrd $INITRD"      fi @@ -86,6 +88,9 @@ $KERNEL_APPEND \          QEMU_OPTIONS="$QEMU_OPTIONS -machine accel=kvm -enable-kvm -cpu host"      fi +    if [[ "$QEMU_TIMEOUT" != "infinity" ]]; then +        QEMU_BIN="timeout --foreground $QEMU_TIMEOUT $QEMU_BIN" +    fi      ( set -x        $QEMU_BIN $QEMU_OPTIONS -append "$KERNEL_APPEND" $TESTDIR/rootdisk.img ) || return 1  } @@ -241,7 +246,7 @@ create_empty_image() {  ,  EOF -    mkfs.ext3 -L systemd "${LOOPDEV}p1" +    mkfs -t "$FSTYPE" -L systemd "${LOOPDEV}p1"  }  check_result_nspawn() { | 
