From e94209cd344c69a876c2feb05ba14bf1ee68e58b Mon Sep 17 00:00:00 2001 From: David Cheung Date: Tue, 10 Oct 2023 21:57:22 +0000 Subject: [PATCH] Add test for ingress internal and external. * Add genereate_config.sh to generate config for tests. It should be run before running tests. * Add tests for ingress internal and external. --- .gitignore | 3 +- .../ingress-external-basic/cleanup.sh | 14 +++++++- .../ingress-external-basic/run-test.sh | 12 ++++++- .../ingress-external-basic/setup.sh | 12 ++++++- .../ingress-internal-basic/cleanup.sh | 34 +++++++++++++++++++ .../ingress-internal-basic/run-test.sh | 32 +++++++++++++++++ .../ingress-internal-basic/setup.sh | 33 ++++++++++++++++++ test/README.md | 12 +++++++ test/generate_config.sh | 11 ++++++ test/helper.sh | 12 ++++--- 10 files changed, 166 insertions(+), 9 deletions(-) mode change 100644 => 100755 ingress/single-cluster/ingress-external-basic/run-test.sh create mode 100755 ingress/single-cluster/ingress-internal-basic/cleanup.sh create mode 100755 ingress/single-cluster/ingress-internal-basic/run-test.sh create mode 100755 ingress/single-cluster/ingress-internal-basic/setup.sh create mode 100755 test/generate_config.sh diff --git a/.gitignore b/.gitignore index 3ad42d50..185172ce 100644 --- a/.gitignore +++ b/.gitignore @@ -4,4 +4,5 @@ asm/ .crt .key .pem -certs/ \ No newline at end of file +certs/ +test/test.conf \ No newline at end of file diff --git a/ingress/single-cluster/ingress-external-basic/cleanup.sh b/ingress/single-cluster/ingress-external-basic/cleanup.sh index 18732a86..b6694c1a 100755 --- a/ingress/single-cluster/ingress-external-basic/cleanup.sh +++ b/ingress/single-cluster/ingress-external-basic/cleanup.sh @@ -19,4 +19,16 @@ set -o nounset; set -o pipefail; set -o xtrace; -echo "Running external basic cleanup." +source ./test/helper.sh +source ./test/test.conf +test_name="ingress-external-basic" +suffix=$(get_hash "${test_name}") +context=$(kubectl config view -o json | jq -r ".contexts[] | select(.name | test(\"-${suffix}\")).name") + +resource_yaml="ingress/single-cluster/ingress-external-basic/external-ingress-basic.yaml" + +kubectl --context "${context}" delete -f "${resource_yaml}" -n "${test_name}" || true +kubectl --context "${context}" delete namespace "${test_name}" || true +wait_for_glbc_deletion "foo-external" "${test_name}" + +cleanup_gke_basic "${test_name}" "${zone}" "${subnet_region}" diff --git a/ingress/single-cluster/ingress-external-basic/run-test.sh b/ingress/single-cluster/ingress-external-basic/run-test.sh old mode 100644 new mode 100755 index e472aaf4..ff50715f --- a/ingress/single-cluster/ingress-external-basic/run-test.sh +++ b/ingress/single-cluster/ingress-external-basic/run-test.sh @@ -19,4 +19,14 @@ set -o nounset; set -o pipefail; set -o xtrace; -echo "Running external basic test." +source ./test/helper.sh +source ./test/test.conf +test_name="ingress-external-basic" +suffix=$(get_hash "${test_name}") +context=$(kubectl config view -o json | jq -r ".contexts[] | select(.name | test(\"-${suffix}\")).name") + +vip=$(wait_for_ingress_ip "foo-external" "${test_name}" "${context}") +echo "Load balancer IP is ${vip}" + +check_http_status "${vip}" 200 "host: foo.example.com" +check_http_status "${vip}" 404 "host: bar.example.com" diff --git a/ingress/single-cluster/ingress-external-basic/setup.sh b/ingress/single-cluster/ingress-external-basic/setup.sh index 7d37fdfc..7a30a3c8 100755 --- a/ingress/single-cluster/ingress-external-basic/setup.sh +++ b/ingress/single-cluster/ingress-external-basic/setup.sh @@ -19,4 +19,14 @@ set -o nounset; set -o pipefail; set -o xtrace; -echo "Running external basic setup." +source ./test/helper.sh +source ./test/test.conf +test_name="ingress-external-basic" +setup_gke_basic "${test_name}" "${zone}" "${subnet_region}" +suffix=$(get_hash "${test_name}") +context=$(kubectl config view -o json | jq -r ".contexts[] | select(.name | test(\"-${suffix}\")).name") + +resource_yaml="ingress/single-cluster/ingress-external-basic/external-ingress-basic.yaml" +kubectl --context "${context}" create namespace "${test_name}" + +kubectl --context "${context}" apply -f "${resource_yaml}" -n "${test_name}" diff --git a/ingress/single-cluster/ingress-internal-basic/cleanup.sh b/ingress/single-cluster/ingress-internal-basic/cleanup.sh new file mode 100755 index 00000000..18c95eb6 --- /dev/null +++ b/ingress/single-cluster/ingress-internal-basic/cleanup.sh @@ -0,0 +1,34 @@ +#!/bin/bash + +# Copyright 2023 Google LLC +# +# 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 -o errexit; +set -o nounset; +set -o pipefail; +set -o xtrace; + +source ./test/helper.sh +source ./test/test.conf +test_name="ingress-internal-basic" +suffix=$(get_hash "${test_name}") +context=$(kubectl config view -o json | jq -r ".contexts[] | select(.name | test(\"-${suffix}\")).name") + +resource_yaml="ingress/single-cluster/ingress-internal-basic/internal-ingress-basic.yaml" + +kubectl --context "${context}" delete -f "${resource_yaml}" -n "${test_name}" || true +kubectl --context "${context}" delete namespace "${test_name}" || true +wait_for_glbc_deletion "foo-internal" "${test_name}" + +cleanup_gke_basic "${test_name}" "${zone}" "${subnet_region}" diff --git a/ingress/single-cluster/ingress-internal-basic/run-test.sh b/ingress/single-cluster/ingress-internal-basic/run-test.sh new file mode 100755 index 00000000..17a7630b --- /dev/null +++ b/ingress/single-cluster/ingress-internal-basic/run-test.sh @@ -0,0 +1,32 @@ +#!/bin/bash + +# Copyright 2023 Google LLC +# +# 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 -o errexit; +set -o nounset; +set -o pipefail; +set -o xtrace; + +source ./test/helper.sh +source ./test/test.conf +test_name="ingress-internal-basic" +suffix=$(get_hash "${test_name}") +context=$(kubectl config view -o json | jq -r ".contexts[] | select(.name | test(\"-${suffix}\")).name") + +vip=$(wait_for_ingress_ip "foo-internal" "${test_name}" "${context}") +echo "Load balancer IP is ${vip}" + +check_http_status "${vip}" 200 "host: foo.example.com" "${test_name}" "${zone}" +check_http_status "${vip}" 404 "host: bar.example.com" "${test_name}" "${zone}" diff --git a/ingress/single-cluster/ingress-internal-basic/setup.sh b/ingress/single-cluster/ingress-internal-basic/setup.sh new file mode 100755 index 00000000..989940ce --- /dev/null +++ b/ingress/single-cluster/ingress-internal-basic/setup.sh @@ -0,0 +1,33 @@ +#!/bin/bash + +# Copyright 2023 Google LLC +# +# 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 -o errexit; +set -o nounset; +set -o pipefail; +set -o xtrace; + +source ./test/helper.sh +source ./test/test.conf +test_name="ingress-internal-basic" +setup_gke_basic "${test_name}" "${zone}" "${subnet_region}" +setup_ilb "${test_name}" "${subnet_region}" +suffix=$(get_hash "${test_name}") +context=$(kubectl config view -o json | jq -r ".contexts[] | select(.name | test(\"-${suffix}\")).name") + +resource_yaml="ingress/single-cluster/ingress-internal-basic/internal-ingress-basic.yaml" +kubectl --context "${context}" create namespace "${test_name}" + +kubectl --context "${context}" apply -f "${resource_yaml}" -n "${test_name}" diff --git a/test/README.md b/test/README.md index e8cde78d..e3f130da 100644 --- a/test/README.md +++ b/test/README.md @@ -32,6 +32,18 @@ Make sure you are at the root directory of the repository. cd gke-networking-recipes ``` + +First, set ZONE and SUBNET_REGION environment variable, then run ./test/generate_config.sh to generate the testing config. +``` +export ZONE=zone +export SUBNET_REGION=subnet_region + +./test/generate_config.sh +``` + +To run ingress-https test, you need a special project($DNS_PROJECT) that has configured DNS domain, and make sure the current service account have role/dns_admin access to that project. Create a public DNS zone(DNS_ZONE). +Then set the environment variable for DNS_PROJECT, RECORD1, RECORD2, DNS_ZONE before running generate_env.sh. Make sure the two records that uses the DNS name of the created DNS zone as suffix. + To run a specific test, run the setup.sh, run-test.sh, and cleanup.sh in order in the recipe directory. ``` diff --git a/test/generate_config.sh b/test/generate_config.sh new file mode 100755 index 00000000..77a17976 --- /dev/null +++ b/test/generate_config.sh @@ -0,0 +1,11 @@ +testConf="test/test.conf" +echo "Writing to ${testConf}" +echo "----" +cat <