docs/test/integration/api/logs.bats

49 lines
1.2 KiB
Bash

#!/usr/bin/env bats
load ../helpers
function teardown() {
swarm_manage_cleanup
stop_docker
}
@test "docker logs" {
start_docker_with_busybox 2
swarm_manage
# run a container with echo command
docker_swarm run -d --name test_container busybox /bin/sh -c "echo hello world; echo hello docker; echo hello swarm"
# make sure container exists
run docker_swarm ps -l
[ "${#lines[@]}" -eq 2 ]
[[ "${lines[1]}" == *"test_container"* ]]
# verify
run docker_swarm logs test_container
[ "$status" -eq 0 ]
[ "${#lines[@]}" -eq 3 ]
[[ "${lines[0]}" == *"hello world"* ]]
[[ "${lines[1]}" == *"hello docker"* ]]
[[ "${lines[2]}" == *"hello swarm"* ]]
}
@test "docker logs unhealthy node" {
start_docker_with_busybox 1
swarm_manage --engine-refresh-min-interval=1s --engine-refresh-max-interval=1s --engine-failure-retry=1 ${HOSTS[0]}
# run a container with echo command
docker_swarm run -d --name test_container busybox /bin/sh -c "echo hello world; echo hello docker; echo hello swarm"
# Stop node-0
docker_host stop ${DOCKER_CONTAINERS[0]}
retry 5 1 eval "docker_swarm info | grep -q 'Unhealthy'"
# verify
run docker_swarm logs test_container
[ "$status" -eq 1 ]
[[ "${output}" == *" running on unhealthy node"* ]]
}