diff options
author | Paul Holzinger <pholzing@redhat.com> | 2022-02-07 15:04:04 +0100 |
---|---|---|
committer | Matthew Heon <matthew.heon@pm.me> | 2022-02-10 13:59:07 -0500 |
commit | ed60f8908672a251a6cd366c42152c100dbf68f7 (patch) | |
tree | 2895fba7d48c1c11419952edbd2e9c631f34645b /test/system | |
parent | 7e37c608f7ac04ffbb6e11b5b774acfd7afb6d95 (diff) | |
download | podman-ed60f8908672a251a6cd366c42152c100dbf68f7.tar.gz podman-ed60f8908672a251a6cd366c42152c100dbf68f7.tar.bz2 podman-ed60f8908672a251a6cd366c42152c100dbf68f7.zip |
move rootless netns slirp4netns process to systemd user.slice
When running podman inside systemd user units, it is possible that
systemd kills the rootless netns slirp4netns process because it was
started in the default unit cgroup. When the unit is stopped all
processes in that cgroup are killed. Since the slirp4netns process is
run once for all containers it should not be killed. To make sure
systemd will not kill the process we move it to the user.slice.
Fixes #13153
Signed-off-by: Paul Holzinger <pholzing@redhat.com>
Diffstat (limited to 'test/system')
-rw-r--r-- | test/system/250-systemd.bats | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/test/system/250-systemd.bats b/test/system/250-systemd.bats index c47679904..3847d9510 100644 --- a/test/system/250-systemd.bats +++ b/test/system/250-systemd.bats @@ -281,4 +281,34 @@ LISTEN_FDNAMES=listen_fdnames" | sort) is "$output" "" "output should be empty" } +# https://github.com/containers/podman/issues/13153 +@test "podman rootless-netns slirp4netns process should be in different cgroup" { + is_rootless || skip "only meaningful for rootless" + + cname=$(random_string) + local netname=testnet-$(random_string 10) + + # create network and container with network + run_podman network create $netname + run_podman create --name $cname --network $netname $IMAGE top + + # run container in systemd unit + service_setup + + # run second container with network + cname2=$(random_string) + run_podman run -d --name $cname2 --network $netname $IMAGE top + + # stop systemd container + service_cleanup + + # now check that the rootless netns slirp4netns process is still alive and working + run_podman unshare --rootless-netns ip addr + is "$output" ".*tap0.*" "slirp4netns interface exists in the netns" + run_podman exec $cname2 nslookup google.com + + run_podman rm -f -t0 $cname2 + run_podman network rm -f $netname +} + # vim: filetype=sh |