2020-10-06 17:09:13 -05:00
|
|
|
#!/usr/bin/env bats
|
|
|
|
|
|
|
|
load helpers
|
|
|
|
|
|
|
|
@test "s1 proxy admin is up on :19000" {
|
|
|
|
retry_default curl -f -s localhost:19000/stats -o /dev/null
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "s2 proxy admin is up on :19001" {
|
|
|
|
retry_default curl -f -s localhost:19001/stats -o /dev/null
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "s1 proxy listener should be up and have right cert" {
|
|
|
|
assert_proxy_presents_cert_uri localhost:21000 s1
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "s2 proxy listener should be up and have right cert" {
|
|
|
|
assert_proxy_presents_cert_uri localhost:21001 s2
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "s2 proxies should be healthy" {
|
|
|
|
assert_service_has_healthy_instances s2 1
|
|
|
|
}
|
|
|
|
|
|
|
|
@test "s1 upstream should have healthy endpoints for s2" {
|
|
|
|
assert_upstream_has_endpoints_in_status 127.0.0.1:19000 s2.default.primary HEALTHY 1
|
|
|
|
}
|
|
|
|
|
2020-10-28 08:43:11 -05:00
|
|
|
@test "s2 should have http rbac rules loaded from xDS" {
|
|
|
|
retry_default assert_envoy_http_rbac_policy_count localhost:19001 1
|
|
|
|
}
|
|
|
|
|
2020-10-06 17:09:13 -05:00
|
|
|
# these all use the same context: "s1 upstream should be able to connect to s2 via upstream s2"
|
|
|
|
|
|
|
|
@test "test exact path" {
|
2020-10-26 17:04:35 -05:00
|
|
|
retry_default must_pass_http_request GET localhost:5000/exact
|
|
|
|
retry_default must_fail_http_request GET localhost:5000/exact-nope
|
2020-10-06 17:09:13 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@test "test prefix path" {
|
2020-10-26 17:04:35 -05:00
|
|
|
retry_default must_pass_http_request GET localhost:5000/prefix
|
|
|
|
retry_default must_fail_http_request GET localhost:5000/nope-prefix
|
2020-10-06 17:09:13 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@test "test regex path" {
|
2020-10-26 17:04:35 -05:00
|
|
|
retry_default must_pass_http_request GET localhost:5000/regex
|
|
|
|
retry_default must_fail_http_request GET localhost:5000/reggex
|
2020-10-06 17:09:13 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@test "test present header" {
|
2020-10-26 17:04:35 -05:00
|
|
|
retry_default must_pass_http_request GET localhost:5000/hdr-present anything
|
|
|
|
retry_default must_fail_http_request GET localhost:5000/hdr-present ""
|
2020-10-06 17:09:13 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@test "test exact header" {
|
2020-10-26 17:04:35 -05:00
|
|
|
retry_default must_pass_http_request GET localhost:5000/hdr-exact exact
|
|
|
|
retry_default must_fail_http_request GET localhost:5000/hdr-exact exact-nope
|
2020-10-06 17:09:13 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@test "test prefix header" {
|
2020-10-26 17:04:35 -05:00
|
|
|
retry_default must_pass_http_request GET localhost:5000/hdr-prefix prefix
|
|
|
|
retry_default must_fail_http_request GET localhost:5000/hdr-prefix nope-prefix
|
2020-10-06 17:09:13 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@test "test suffix header" {
|
2020-10-26 17:04:35 -05:00
|
|
|
retry_default must_pass_http_request GET localhost:5000/hdr-suffix suffix
|
|
|
|
retry_default must_fail_http_request GET localhost:5000/hdr-suffix suffix-nope
|
2020-10-06 17:09:13 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@test "test regex header" {
|
2020-10-26 17:04:35 -05:00
|
|
|
retry_default must_pass_http_request GET localhost:5000/hdr-regex regex
|
|
|
|
retry_default must_fail_http_request GET localhost:5000/hdr-regex reggex
|
2020-10-06 17:09:13 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@test "test method match" {
|
2020-10-26 17:04:35 -05:00
|
|
|
retry_default must_pass_http_request GET localhost:5000/method-match
|
|
|
|
retry_default must_pass_http_request PUT localhost:5000/method-match
|
|
|
|
retry_default must_fail_http_request POST localhost:5000/method-match
|
|
|
|
retry_default must_fail_http_request HEAD localhost:5000/method-match
|
2020-10-06 17:09:13 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
# @test "s1 upstream should NOT be able to connect to s2" {
|
|
|
|
# run retry_default must_fail_tcp_connection localhost:5000
|
|
|
|
|
|
|
|
# echo "OUTPUT $output"
|
|
|
|
|
|
|
|
# [ "$status" == "0" ]
|
|
|
|
# }
|