aboutsummaryrefslogtreecommitdiff
path: root/test/apiv2/26-containersWait.at
blob: 41938d5673a29ced970683cce67c918cb8cfa77a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# -*- sh -*-
#
# test more container-related endpoints
#

podman pull "${IMAGE}" &>/dev/null

# Ensure clean slate
podman rm -a -f &>/dev/null

CTR="WaitTestingCtr"

t POST "containers/nonExistent/wait?condition=next-exit" 404

podman create --name "${CTR}" --entrypoint '["true"]' "${IMAGE}"

t POST "containers/${CTR}/wait?condition=non-existent-cond" 400

t POST "containers/${CTR}/wait?condition=not-running" 200

# Test waiting for EXIT (need to start a background trigger first)
(sleep 2;podman start "${CTR}") &
child_pid=$!

# This will block until the background job completes
t POST "containers/${CTR}/wait?condition=next-exit" 200 \
  .StatusCode=0 \
  .Error=null
wait "${child_pid}"

# Test that headers are sent before body. (We should actually never get a body)
APIV2_TEST_EXPECT_TIMEOUT=2 t POST "containers/${CTR}/wait?condition=next-exit" 999
like "$(<$WORKDIR/curl.headers.out)" ".*HTTP.* 200 OK.*" \
     "Received headers from /wait"
if [[ -e $WORKDIR/curl.result.out ]]; then
    _show_ok 0 "UNEXPECTED: curl on /wait returned results"
fi

# Test waiting for REMOVE. Like above, start a background trigger.
(sleep 2;podman container rm "${CTR}") &
child_pid=$!

t POST "containers/${CTR}/wait?condition=removed" 200 \
  .StatusCode=0 \
  .Error=null
wait "${child_pid}"