#!/usr/bin/env bash # SPDX-License-Identifier: LGPL-2.1-or-later set -ex TEST_RULE="/run/udev/rules.d/49-test.rules" KILL_PID= setup() { mkdir -p "${TEST_RULE%/*}" [[ -e /etc/udev/udev.conf ]] && cp -f /etc/udev/udev.conf /etc/udev/udev.conf.bak # Don't bother storing the coredumps in journal for this particular test mkdir -p /run/systemd/coredump.conf.d/ echo -ne "[Coredump]\nStorage=external\n" >/run/systemd/coredump.conf.d/99-storage-journal.conf cat >"${TEST_RULE}" </etc/udev/udev.conf <"$TMPDIR"/monitor.txt & KILL_PID="$!" SYSTEMD_LOG_LEVEL=debug udevadm trigger --verbose --action add /dev/null for _ in {1..40}; do if coredumpctl --since "$since" --no-legend --no-pager | grep /bin/udevadm ; then kill "$KILL_PID" KILL_PID= cat "$TMPDIR"/monitor.txt grep -q 'UDEV_WORKER_FAILED=1' "$TMPDIR"/monitor.txt grep -q 'UDEV_WORKER_SIGNAL=6' "$TMPDIR"/monitor.txt grep -q 'UDEV_WORKER_SIGNAL_NAME=ABRT' "$TMPDIR"/monitor.txt return 0 fi sleep .5 done return 1 } trap teardown EXIT setup run_test exit 0