summaryrefslogtreecommitdiff
path: root/test/system/030-run.bats
diff options
context:
space:
mode:
authorEd Santiago <santiago@redhat.com>2020-10-14 06:24:17 -0600
committerEd Santiago <santiago@redhat.com>2020-10-14 15:32:02 -0600
commit1646da834c06d55e7bf56b272f2666659117e6fa (patch)
tree85044a2360ddbb7a7845de11ec1016bf6996baab /test/system/030-run.bats
parent1814bac92e98bf24c8f757dcd42fc0ae9fb9f9b0 (diff)
downloadpodman-1646da834c06d55e7bf56b272f2666659117e6fa.tar.gz
podman-1646da834c06d55e7bf56b272f2666659117e6fa.tar.bz2
podman-1646da834c06d55e7bf56b272f2666659117e6fa.zip
System test additions
- run --userns=keep-id: confirm that $HOME gets set (#8013) - inspect: confirm that JSON output is a sane number of lines (10 or more), not an unreadable one-liner (#8011 and #8021). Do so with image, pod, network, volume because the code paths might be different. - cgroups: confirm that 'run' preserves cgroup manager (#7970) - sdnotify: reenable tests, and hope CI doesn't hang. This test was disabled on August 18 because CI jobs were hanging and timing out. My suspicion was that it was #7316, which in turn seems to have hinged on conmon #182. The latter was merged on Sep 16, so let's cross our fingers and see what happens. Also: remove inaccurate warning from a networking test. And, wow, fix is_cgroupsv2(), it has never actually worked. Signed-off-by: Ed Santiago <santiago@redhat.com>
Diffstat (limited to 'test/system/030-run.bats')
-rw-r--r--test/system/030-run.bats30
1 files changed, 29 insertions, 1 deletions
diff --git a/test/system/030-run.bats b/test/system/030-run.bats
index 766948ecc..28dc7c7a7 100644
--- a/test/system/030-run.bats
+++ b/test/system/030-run.bats
@@ -303,8 +303,36 @@ echo $rand | 0 | $rand
# This would always work on root, but is new behavior on rootless: #6829
# adds a user entry to /etc/passwd
+ whoami=$(id -un)
run_podman run --rm --userns=keep-id $IMAGE id -un
- is "$output" "$(id -un)" "username on container with keep-id"
+ is "$output" "$whoami" "username on container with keep-id"
+
+ # Setting user should also set $HOME (#8013).
+ # Test setup below runs three cases: one with an existing home dir
+ # and two without (one without any volume mounts, one with a misspelled
+ # username). In every case, initial cwd should be /home/podman because
+ # that's the container-defined WORKDIR. In the case of an existing
+ # home dir, $HOME and ~ (passwd entry) will be /home/user; otherwise
+ # they should be /home/podman.
+ if is_rootless; then
+ tests="
+ | /home/podman /home/podman /home/podman | no vol mount
+/home/x$whoami | /home/podman /home/podman /home/podman | bad vol mount
+/home/$whoami | /home/podman /home/$whoami /home/$whoami | vol mount
+"
+ while read vol expect name; do
+ opts=
+ if [[ "$vol" != "''" ]]; then
+ opts="-v $vol"
+ fi
+ run_podman run --rm $opts --userns=keep-id \
+ $IMAGE sh -c 'echo $(pwd;printenv HOME;echo ~)'
+ is "$output" "$expect" "run with --userns=keep-id and $name sets \$HOME"
+ done < <(parse_table "$tests")
+
+ # Clean up volumes
+ run_podman volume rm -a
+ fi
# --privileged should make no difference
run_podman run --rm --privileged --userns=keep-id $IMAGE id -un