mirror of
https://github.com/containers/podman.git
synced 2025-06-21 17:38:12 +08:00
system tests: new system-service bats file
Followup to #14957, which added a new test that doesn't actually belong in the 250-systemd.bats file. It was copy-pasted from another test that doesn't belong there. Move both tests to a new .bats file, because (1) they need a custom cleanup, and (2) one of the tests should very definitely run under podman-remote, and the 250 bats file has a global skip_if_remote(). Signed-off-by: Ed Santiago <santiago@redhat.com>
This commit is contained in:

committed by
Matthew Heon

parent
d2e2756a4c
commit
409fbeaaba
@ -296,8 +296,6 @@ LISTEN_FDNAMES=listen_fdnames" | sort)
|
|||||||
}
|
}
|
||||||
|
|
||||||
@test "podman-kube@.service template" {
|
@test "podman-kube@.service template" {
|
||||||
skip_if_remote "systemd units do not work with remote clients"
|
|
||||||
|
|
||||||
# If running from a podman source directory, build and use the source
|
# If running from a podman source directory, build and use the source
|
||||||
# version of the play-kube-@ unit file
|
# version of the play-kube-@ unit file
|
||||||
unit_name="podman-kube@.service"
|
unit_name="podman-kube@.service"
|
||||||
@ -375,48 +373,4 @@ EOF
|
|||||||
rm -f $UNIT_DIR/$unit_name
|
rm -f $UNIT_DIR/$unit_name
|
||||||
}
|
}
|
||||||
|
|
||||||
@test "podman-system-service containers survive service stop" {
|
|
||||||
skip_if_remote "N/A under podman-remote"
|
|
||||||
|
|
||||||
SERVICE_NAME=podman-service-$(random_string)
|
|
||||||
port=$(random_free_port)
|
|
||||||
URL=tcp://127.0.0.1:$port
|
|
||||||
|
|
||||||
systemd-run --unit=$SERVICE_NAME $PODMAN system service $URL --time=0
|
|
||||||
wait_for_port 127.0.0.1 $port
|
|
||||||
|
|
||||||
# Start a long-running container.
|
|
||||||
cname=keeps-running
|
|
||||||
run_podman --url $URL run -d --name $cname $IMAGE top -d 2
|
|
||||||
|
|
||||||
run_podman container inspect -l --format "{{.State.Running}}"
|
|
||||||
is "$output" "true" "This should never fail"
|
|
||||||
|
|
||||||
systemctl stop $SERVICE_NAME
|
|
||||||
|
|
||||||
run_podman container inspect $cname --format "{{.State.Running}}"
|
|
||||||
is "$output" "true" "Container is still running after podman server stops"
|
|
||||||
|
|
||||||
run_podman rm -f -t 0 $cname
|
|
||||||
}
|
|
||||||
|
|
||||||
@test "podman-system-service containers --host" {
|
|
||||||
skip_if_remote "N/A under podman-remote"
|
|
||||||
|
|
||||||
SERVICE_NAME=podman-service-$(random_string)
|
|
||||||
port=$(random_free_port)
|
|
||||||
URL=tcp://127.0.0.1:$port
|
|
||||||
|
|
||||||
systemd-run --unit=$SERVICE_NAME $PODMAN system service $URL --time=0
|
|
||||||
wait_for_port 127.0.0.1 $port
|
|
||||||
|
|
||||||
run_podman --host $URL run --rm $IMAGE true
|
|
||||||
run_podman -H $URL run --rm $IMAGE true
|
|
||||||
|
|
||||||
systemctl stop $SERVICE_NAME
|
|
||||||
|
|
||||||
# Make sure the option is actually connecting
|
|
||||||
run_podman 125 --host $URL run --rm $IMAGE true
|
|
||||||
assert "$output" =~ "Cannot connect to Podman.*connection refused"
|
|
||||||
}
|
|
||||||
# vim: filetype=sh
|
# vim: filetype=sh
|
||||||
|
58
test/system/251-system-service.bats
Normal file
58
test/system/251-system-service.bats
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
#!/usr/bin/env bats -*- bats -*-
|
||||||
|
#
|
||||||
|
# Tests that require 'podman system service' but no other systemd aspects
|
||||||
|
|
||||||
|
load helpers
|
||||||
|
load helpers.systemd
|
||||||
|
|
||||||
|
SERVICE_NAME="podman-service-$(random_string)"
|
||||||
|
|
||||||
|
function teardown() {
|
||||||
|
# Ignore exit status: this is just a backup stop in case tests failed
|
||||||
|
run systemctl stop "$SERVICE_NAME"
|
||||||
|
|
||||||
|
basic_teardown
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@test "podman-system-service containers survive service stop" {
|
||||||
|
skip_if_remote "podman system service unavailable over remote"
|
||||||
|
|
||||||
|
port=$(random_free_port)
|
||||||
|
URL=tcp://127.0.0.1:$port
|
||||||
|
|
||||||
|
systemd-run --unit=$SERVICE_NAME $PODMAN system service $URL --time=0
|
||||||
|
wait_for_port 127.0.0.1 $port
|
||||||
|
|
||||||
|
# Start a long-running container.
|
||||||
|
cname=keeps-running
|
||||||
|
run_podman --url $URL run -d --name $cname $IMAGE top -d 2
|
||||||
|
|
||||||
|
run_podman container inspect -l --format "{{.State.Running}}"
|
||||||
|
is "$output" "true" "This should never fail"
|
||||||
|
|
||||||
|
systemctl stop $SERVICE_NAME
|
||||||
|
|
||||||
|
run_podman container inspect $cname --format "{{.State.Running}}"
|
||||||
|
is "$output" "true" "Container is still running after podman server stops"
|
||||||
|
|
||||||
|
run_podman rm -f -t 0 $cname
|
||||||
|
}
|
||||||
|
|
||||||
|
# This doesn't actually test podman system service, but we require it,
|
||||||
|
# so least-awful choice is to run from this test file.
|
||||||
|
@test "podman --host / -H options" {
|
||||||
|
port=$(random_free_port)
|
||||||
|
URL=tcp://127.0.0.1:$port
|
||||||
|
|
||||||
|
# %%-remote makes this run real podman even when testing podman-remote
|
||||||
|
systemd-run --unit=$SERVICE_NAME ${PODMAN%%-remote*} system service $URL --time=0
|
||||||
|
wait_for_port 127.0.0.1 $port
|
||||||
|
|
||||||
|
for opt in --host -H; do
|
||||||
|
run_podman $opt $URL info --format '{{.Host.RemoteSocket.Path}}'
|
||||||
|
is "$output" "$URL" "RemoteSocket.Path using $opt"
|
||||||
|
done
|
||||||
|
|
||||||
|
systemctl stop $SERVICE_NAME
|
||||||
|
}
|
Reference in New Issue
Block a user