mirror of
https://github.com/systemd/systemd.git
synced 2024-11-26 19:53:45 +08:00
tests: add a smoke test for --version option in binaries
This is very similar to (and directly based on) the test for --help. I think it's nice to do this: the test is very quick, but it'll catch cases where we forgot to hook up the option, or forgot to exit after printing --version, and it'll also increase our test coverage a bit.
This commit is contained in:
parent
42ac3bf1a3
commit
ffb7406ba9
@ -3891,6 +3891,7 @@ endif
|
||||
############################################################
|
||||
|
||||
check_help = find_program('tools/check-help.sh')
|
||||
check_version = find_program('tools/check-version.sh')
|
||||
|
||||
foreach exec : public_programs
|
||||
name = exec.full_path().split('/')[-1]
|
||||
@ -3899,6 +3900,12 @@ foreach exec : public_programs
|
||||
check_help,
|
||||
args : exec.full_path(),
|
||||
depends: exec)
|
||||
|
||||
test('check-version-' + name,
|
||||
check_version,
|
||||
args : [exec.full_path(),
|
||||
meson.project_version()],
|
||||
depends: exec)
|
||||
endif
|
||||
endforeach
|
||||
|
||||
|
@ -3,8 +3,8 @@
|
||||
set -eu
|
||||
set -o pipefail
|
||||
|
||||
# Note: `grep ... >/dev/null` instead of just `grep -q` is used intentionally
|
||||
# here, since `grep -q` exits on the first match causing SIGPIPE being
|
||||
# Note: 'grep ... >/dev/null' instead of just 'grep -q' is used intentionally
|
||||
# here, since 'grep -q' exits on the first match causing SIGPIPE being
|
||||
# sent to the sender.
|
||||
|
||||
BINARY="${1:?}"
|
||||
@ -24,11 +24,11 @@ fi
|
||||
|
||||
# --help prints something. Also catches case where args are ignored.
|
||||
if ! "$BINARY" --help | grep . >/dev/null; then
|
||||
echo "$(basename "$BINARY") --help output is empty."
|
||||
echo "$(basename "$BINARY") --help output is empty"
|
||||
exit 2
|
||||
fi
|
||||
|
||||
# no --help output to stdout
|
||||
# no --help output to stderr
|
||||
if "$BINARY" --help 2>&1 1>/dev/null | grep .; then
|
||||
echo "$(basename "$BINARY") --help prints to stderr"
|
||||
exit 3
|
||||
|
36
tools/check-version.sh
Executable file
36
tools/check-version.sh
Executable file
@ -0,0 +1,36 @@
|
||||
#!/usr/bin/env bash
|
||||
# SPDX-License-Identifier: LGPL-2.1-or-later
|
||||
set -eu
|
||||
set -o pipefail
|
||||
|
||||
# Note: 'grep ... >/dev/null' instead of just 'grep -q' is used intentionally
|
||||
# here, since 'grep -q' exits on the first match causing SIGPIPE being
|
||||
# sent to the sender.
|
||||
|
||||
BINARY="${1:?}"
|
||||
VERSION="${2:?}"
|
||||
export SYSTEMD_LOG_LEVEL=info
|
||||
|
||||
if [[ ! -x "$BINARY" ]]; then
|
||||
echo "$BINARY is not an executable"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# --version prints something. Also catches case where args are ignored.
|
||||
if ! "$BINARY" --version | grep . >/dev/null; then
|
||||
echo "$(basename "$BINARY") --version output is empty"
|
||||
exit 2
|
||||
fi
|
||||
|
||||
# no --version output to stderr
|
||||
if "$BINARY" --version 2>&1 1>/dev/null | grep .; then
|
||||
echo "$(basename "$BINARY") --version prints to stderr"
|
||||
exit 3
|
||||
fi
|
||||
|
||||
# project version appears in version output
|
||||
out="$("$BINARY" --version)"
|
||||
if ! grep -F "$VERSION" >/dev/null <<<"$out"; then
|
||||
echo "$(basename "$BINARY") --version output does not match '$VERSION': $out"
|
||||
exit 4
|
||||
fi
|
Loading…
Reference in New Issue
Block a user