Add some tests
This commit is contained in:
parent
dd0f51a714
commit
189ed4b29b
1 changed files with 69 additions and 0 deletions
69
test/path-based-routes.bats
Normal file
69
test/path-based-routes.bats
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
#!/usr/bin/env bats
|
||||||
|
|
||||||
|
load test_helpers
|
||||||
|
SUT_CONTAINER=bats-nginx-proxy-${TEST_FILE}
|
||||||
|
|
||||||
|
function setup {
|
||||||
|
stop_bats_containers web
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "[$TEST_FILE] start a nginx-proxy container" {
|
||||||
|
run nginxproxy $SUT_CONTAINER -v /var/run/docker.sock:/tmp/docker.sock:ro
|
||||||
|
assert_success
|
||||||
|
docker_wait_for_log $SUT_CONTAINER 9 "Watching docker events"
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "[$TEST_FILE] nginx-proxy can put a container at a specific path" {
|
||||||
|
#WHEN a container is run with VIRTUAL_PATH set
|
||||||
|
prepare_web_container bats-virtual-path-1 80 -e VIRTUAL_HOST=virtual-path-1.bats -e VIRTUAL_PATH=/virtual_path
|
||||||
|
dockergen_wait_for_event $SUT_CONTAINER start bats-virtual-path-1
|
||||||
|
sleep 1
|
||||||
|
|
||||||
|
#THEN querying the root -> 404
|
||||||
|
run curl_container $SUT_CONTAINER / --head --header "Host: virtual-path-1.bats"
|
||||||
|
assert_output -l 0 $'HTTP/1.1 404 Not Found\r'
|
||||||
|
|
||||||
|
#THEN querying an unmatched path -> 503
|
||||||
|
run curl_container $SUT_CONTAINER /some_other_path --head --header "Host: virtual-path-1.bats"
|
||||||
|
assert_output -l 0 $'HTTP/1.1 404 Not Found\r'
|
||||||
|
|
||||||
|
#THEN
|
||||||
|
run curl_container $SUT_CONTAINER /virtual_path/data --header "Host: virtual-path-1.bats"
|
||||||
|
assert_output "answer from port 80"
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "[$TEST_FILE] nginx-proxy can put a container at the root" {
|
||||||
|
#WHEN a container is run with VIRTUAL_PATH set to /
|
||||||
|
prepare_web_container bats-virtual-path-1 80 -e VIRTUAL_HOST=virtual-path-1.bats -e VIRTUAL_PATH=/
|
||||||
|
dockergen_wait_for_event $SUT_CONTAINER start bats-virtual-path-1
|
||||||
|
sleep 1
|
||||||
|
|
||||||
|
#THEN
|
||||||
|
run curl_container $SUT_CONTAINER /data --header "Host: virtual-path-1.bats"
|
||||||
|
assert_output "answer from port 80"
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "[$TEST_FILE] nginx-proxy can put multiple containers at different paths" {
|
||||||
|
#WHEN a multiple containers are run with VIRTUAL_PATH set
|
||||||
|
prepare_web_container bats-virtual-path-1 80 -e VIRTUAL_HOST=virtual-path-1.bats -e VIRTUAL_PATH=/at-80
|
||||||
|
prepare_web_container bats-virtual-path-2 90 -e VIRTUAL_HOST=virtual-path-1.bats -e VIRTUAL_PATH=/at-90
|
||||||
|
prepare_web_container bats-virtual-path-3 100 -e VIRTUAL_HOST=virtual-path-1.bats -e VIRTUAL_PATH=/
|
||||||
|
dockergen_wait_for_event $SUT_CONTAINER start bats-virtual-path-1
|
||||||
|
sleep 1
|
||||||
|
|
||||||
|
#THEN
|
||||||
|
run curl_container $SUT_CONTAINER /data --header "Host: virtual-path-1.bats"
|
||||||
|
assert_output "answer from port 100"
|
||||||
|
|
||||||
|
#THEN
|
||||||
|
run curl_container $SUT_CONTAINER /at-80/data --header "Host: virtual-path-1.bats"
|
||||||
|
assert_output "answer from port 80"
|
||||||
|
|
||||||
|
#THEN
|
||||||
|
run curl_container $SUT_CONTAINER /at-90/data --header "Host: virtual-path-1.bats"
|
||||||
|
assert_output "answer from port 90"
|
||||||
|
}
|
||||||
|
|
||||||
|
@test "[$TEST_FILE] stop all bats containers" {
|
||||||
|
stop_bats_containers
|
||||||
|
}
|
Loading…
Reference in a new issue