istio.io/content/en/docs/tasks/traffic-management/ingress/ingress-control/test.sh

90 lines
2.7 KiB
Bash

#!/usr/bin/env bash
# shellcheck disable=SC1090,SC2034,SC2154
# Copyright Istio Authors
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
set -e
set -u
set -o pipefail
source "tests/util/samples.sh"
GATEWAY_API="${GATEWAY_API:-false}"
# @setup profile=default
kubectl label namespace default istio-injection=enabled --overwrite
# start the httpbin sample
startup_httpbin_sample
if [ "$GATEWAY_API" == "true" ]; then
# create the gateway and routes
snip_configuring_ingress_using_a_gateway_3
_wait_for_gateway default httpbin-gateway
snip_configuring_ingress_using_a_gateway_4
snip_configuring_ingress_using_a_gateway_5
# set INGRESS_HOST and INGRESS_PORT environment variables
snip_determining_the_ingress_ip_and_ports_7
else
# create the gateway and routes
snip_configuring_ingress_using_a_gateway_1
snip_configuring_ingress_using_a_gateway_2
# wait for rules to propagate
_wait_for_istio gateway default httpbin-gateway
_wait_for_istio virtualservice default httpbin
# check for external load balancer
snip_determining_the_ingress_ip_and_ports_2
_verify_like snip_determining_the_ingress_ip_and_ports_4 "$snip_determining_the_ingress_ip_and_ports_4_out"
# set INGRESS_HOST, INGRESS_PORT, SECURE_INGRESS_PORT, and TCP_INGRESS_PORT environment variables
snip_determining_the_ingress_ip_and_ports_5
fi
# access the httpbin service
_verify_elided snip_accessing_ingress_services_1 "$snip_accessing_ingress_services_1_out"
# access the httpbin service
_verify_elided snip_accessing_ingress_services_2 "$snip_accessing_ingress_services_2_out"
if [ "$GATEWAY_API" == "true" ]; then
# configure for web browser
snip_accessing_ingress_services_using_a_browser_2
else
# configure for web browser
snip_accessing_ingress_services_using_a_browser_1
# wait for rules to propagate
_wait_for_istio gateway default httpbin-gateway
_wait_for_istio virtualservice default httpbin
fi
# helper function
curl_httpbin_headers() {
curl -s -I "http://$INGRESS_HOST:$INGRESS_PORT/headers"
}
# access httpbin without host header
_verify_contains curl_httpbin_headers "HTTP/1.1 200 OK"
# @cleanup
if [ "$GATEWAY_API" != "true" ]; then
snip_cleanup_1
kubectl label namespace default istio-injection-
fi