summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEd Santiago <santiago@redhat.com>2022-09-22 11:44:42 -0600
committerEd Santiago <santiago@redhat.com>2022-09-27 05:53:18 -0600
commit3e80931529a1bf6f3d871d51a92abe4106801431 (patch)
tree4f2a53db523828e12e0d68a8ce196193bcd4cf42
parentf51aeb45d497379b6e0a11414d69435e83908efa (diff)
downloadpodman-3e80931529a1bf6f3d871d51a92abe4106801431.tar.gz
podman-3e80931529a1bf6f3d871d51a92abe4106801431.tar.bz2
podman-3e80931529a1bf6f3d871d51a92abe4106801431.zip
System tests: light cleanup
Followup to #15895: - add a normal-case test, to ensure that --privileged without systemd continues to pass through /dev/ttyN devices - explain why we die() if host has no ttyN devices - I find grep -vx slightly easier to read than sed backslash-slash - run cleanup with '-t 0', to shave ten seconds from CI run Signed-off-by: Ed Santiago <santiago@redhat.com>
-rw-r--r--test/system/030-run.bats33
1 files changed, 23 insertions, 10 deletions
diff --git a/test/system/030-run.bats b/test/system/030-run.bats
index 65a1150a3..6847880ab 100644
--- a/test/system/030-run.bats
+++ b/test/system/030-run.bats
@@ -901,22 +901,35 @@ $IMAGE--c_ok" \
run_podman rm $ctr_name
}
+# 15895: --privileged + --systemd = hide /dev/ttyNN
@test "podman run --privileged as root with systemd will not mount /dev/tty" {
skip_if_rootless "this test only makes sense as root"
- ctr_name="container-$(random_string 5)"
- run_podman run --rm -d --privileged --systemd=always --name "$ctr_name" "$IMAGE" /home/podman/pause
+ # First, confirm that we _have_ /dev/ttyNN devices on the host.
+ # ('skip' would be nicer in some sense... but could hide a regression.
+ # Fedora, RHEL, Debian, Ubuntu, Gentoo, all have /dev/ttyN, so if
+ # this ever triggers, it means a real problem we should know about.)
+ assert "$(ls /dev/tty* | grep -vx /dev/tty)" != "" \
+ "Expected at least one /dev/ttyN device on host"
- TTYs=$(ls /dev/tty*|sed '/^\/dev\/tty$/d')
+ # Ok now confirm that without --systemd, podman exposes ttyNN devices
+ run_podman run --rm -d --privileged $IMAGE ./pause
+ cid="$output"
- if [[ $TTYs = "" ]]; then
- die "Did not find any /dev/ttyN devices on local host"
- else
- run_podman exec "$ctr_name" ls /dev/
- assert "$(grep tty <<<$output)" = "tty" "There must be no /dev/ttyN devices in the container"
- fi
+ run_podman exec $cid sh -c 'ls /dev/tty*'
+ assert "$output" != "/dev/tty" \
+ "ls /dev/tty* without systemd; should have lots of ttyN devices"
+ run_podman stop -t 0 $cid
+
+ # Actual test for 15895: with --systemd, no ttyN devices are passed through
+ run_podman run --rm -d --privileged --systemd=always $IMAGE ./pause
+ cid="$output"
+
+ run_podman exec $cid sh -c 'ls /dev/tty*'
+ assert "$output" = "/dev/tty" \
+ "ls /dev/tty* with --systemd=always: should have no ttyN devices"
- run_podman stop "$ctr_name"
+ run_podman stop -t 0 $cid
}
# vim: filetype=sh