blob: 8d4e052635e2fdb8439b9d3eae7af98406267c7a [file] [log] [blame]
#!/usr/bin/sh
set -eux
SOCAT="$1"
SERVER="$2"
# Meet DBus bus and path name constraints, append own PID for parallel runs
TEST_NAME="$(basename "$0" | tr '-' '_')"_${$}
TEST_DIR="$(mktemp --tmpdir --directory "${TEST_NAME}.XXXXXX")"
PTYS_PID=""
SERVER_PID=""
cd "$TEST_DIR"
cleanup()
{
[ -z "$SERVER_PID" ] || kill -s INT "$SERVER_PID"
[ -z "$PTYS_PID" ] || kill "$PTYS_PID"
wait
cd -
rm -rf "$TEST_DIR"
}
trap cleanup EXIT
TEST_CONF="${TEST_NAME}.conf"
TEST_LOG="${TEST_NAME}.log"
cat <<EOF > "$TEST_CONF"
logfile = $TEST_LOG
console-id = $TEST_NAME
EOF
"$SOCAT" -u PTY,raw,echo=0,link=remote PTY,raw,echo=0,wait-slave,link=local &
PTYS_PID="$!"
while ! [ -e remote ] || ! [ -e local ]; do sleep 1; done
"$SERVER" --config "$TEST_CONF" "$(realpath local)" &
SERVER_PID="$!"
while ! busctl status --user xyz.openbmc_project.Console."${TEST_NAME}"; do sleep 1; done
echo console-should-log-to-file-legacy-syntax > remote
sleep 1
grep -LF console-should-log-to-file-legacy-syntax "$TEST_LOG"