| #!/usr/bin/env bash |
| set -eo pipefail |
| |
| # Constants |
| readonly GITHUB_REPOSITORY_NAME="grpc-java" |
| readonly TEST_DRIVER_INSTALL_SCRIPT_URL="https://raw.githubusercontent.com/${TEST_DRIVER_REPO_OWNER:-grpc}/grpc/${TEST_DRIVER_BRANCH:-master}/tools/internal_ci/linux/grpc_xds_k8s_install_test_driver.sh" |
| ## xDS test server/client Docker images |
| readonly SERVER_IMAGE_NAME="gcr.io/grpc-testing/xds-interop/java-server" |
| readonly CLIENT_IMAGE_NAME="gcr.io/grpc-testing/xds-interop/java-client" |
| readonly FORCE_IMAGE_BUILD="${FORCE_IMAGE_BUILD:-0}" |
| readonly BUILD_APP_PATH="interop-testing/build/install/grpc-interop-testing" |
| |
| ####################################### |
| # Builds the test app using gradle and smoke-checks its binaries |
| # Globals: |
| # SRC_DIR |
| # BUILD_APP_PATH |
| # Arguments: |
| # None |
| # Outputs: |
| # Writes the output of xds-test-client and xds-test-server --help to stderr |
| ####################################### |
| build_java_test_app() { |
| echo "Building Java test app" |
| cd "${SRC_DIR}" |
| GRADLE_OPTS="-Dorg.gradle.jvmargs='-Xmx1g'" \ |
| ./gradlew --no-daemon grpc-interop-testing:installDist -x test \ |
| -PskipCodegen=true -PskipAndroid=true --console=plain |
| |
| # Test-run binaries |
| run_ignore_exit_code "${SRC_DIR}/${BUILD_APP_PATH}/bin/xds-test-client" --help |
| run_ignore_exit_code "${SRC_DIR}/${BUILD_APP_PATH}/bin/xds-test-server" --help |
| } |
| |
| ####################################### |
| # Builds test app Docker images and pushes them to GCR |
| # Globals: |
| # BUILD_APP_PATH |
| # SERVER_IMAGE_NAME: Test server Docker image name |
| # CLIENT_IMAGE_NAME: Test client Docker image name |
| # GIT_COMMIT: SHA-1 of git commit being built |
| # TESTING_VERSION: version branch under test, f.e. v1.42.x, master |
| # Arguments: |
| # None |
| # Outputs: |
| # Writes the output of `gcloud builds submit` to stdout, stderr |
| ####################################### |
| build_test_app_docker_images() { |
| echo "Building Java xDS interop test app Docker images" |
| local docker_dir="${SRC_DIR}/buildscripts/xds-k8s" |
| local build_dir |
| build_dir="$(mktemp -d)" |
| # Copy Docker files, log properties, and the test app to the build dir |
| cp -v "${docker_dir}/"*.Dockerfile "${build_dir}" |
| cp -v "${docker_dir}/"*.properties "${build_dir}" |
| cp -rv "${SRC_DIR}/${BUILD_APP_PATH}" "${build_dir}" |
| # Pick a branch name for the built image |
| local branch_name='experimental' |
| if is_version_branch "${TESTING_VERSION}"; then |
| branch_name="${TESTING_VERSION}" |
| fi |
| # Run Google Cloud Build |
| gcloud builds submit "${build_dir}" \ |
| --config "${docker_dir}/cloudbuild.yaml" \ |
| --substitutions "_SERVER_IMAGE_NAME=${SERVER_IMAGE_NAME},_CLIENT_IMAGE_NAME=${CLIENT_IMAGE_NAME},COMMIT_SHA=${GIT_COMMIT},BRANCH_NAME=${branch_name}" |
| # TODO(sergiitk): extra "cosmetic" tags for versioned branches, e.g. v1.34.x |
| # TODO(sergiitk): do this when adding support for custom configs per version |
| } |
| |
| ####################################### |
| # Builds test app and its docker images unless they already exist |
| # Globals: |
| # SERVER_IMAGE_NAME: Test server Docker image name |
| # CLIENT_IMAGE_NAME: Test client Docker image name |
| # GIT_COMMIT: SHA-1 of git commit being built |
| # FORCE_IMAGE_BUILD |
| # Arguments: |
| # None |
| # Outputs: |
| # Writes the output to stdout, stderr |
| ####################################### |
| build_docker_images_if_needed() { |
| # Check if images already exist |
| server_tags="$(gcloud_gcr_list_image_tags "${SERVER_IMAGE_NAME}" "${GIT_COMMIT}")" |
| printf "Server image: %s:%s\n" "${SERVER_IMAGE_NAME}" "${GIT_COMMIT}" |
| echo "${server_tags:-Server image not found}" |
| |
| client_tags="$(gcloud_gcr_list_image_tags "${CLIENT_IMAGE_NAME}" "${GIT_COMMIT}")" |
| printf "Client image: %s:%s\n" "${CLIENT_IMAGE_NAME}" "${GIT_COMMIT}" |
| echo "${client_tags:-Client image not found}" |
| |
| # Build if any of the images are missing, or FORCE_IMAGE_BUILD=1 |
| if [[ "${FORCE_IMAGE_BUILD}" == "1" || -z "${server_tags}" || -z "${client_tags}" ]]; then |
| build_java_test_app |
| build_test_app_docker_images |
| else |
| echo "Skipping Java test app build" |
| fi |
| } |
| |
| ####################################### |
| # Executes the test case |
| # Globals: |
| # TEST_DRIVER_FLAGFILE: Relative path to test driver flagfile |
| # KUBE_CONTEXT: The name of kubectl context with GKE cluster access |
| # TEST_XML_OUTPUT_DIR: Output directory for the test xUnit XML report |
| # SERVER_IMAGE_NAME: Test server Docker image name |
| # CLIENT_IMAGE_NAME: Test client Docker image name |
| # GIT_COMMIT: SHA-1 of git commit being built |
| # TESTING_VERSION: version branch under test: used by the framework to |
| # determine the supported PSM features. |
| # Arguments: |
| # Test case name |
| # Outputs: |
| # Writes the output of test execution to stdout, stderr |
| # Test xUnit report to ${TEST_XML_OUTPUT_DIR}/${test_name}/sponge_log.xml |
| ####################################### |
| run_test() { |
| # Test driver usage: |
| # https://github.com/grpc/grpc/tree/master/tools/run_tests/xds_k8s_test_driver#basic-usage |
| local test_name="${1:?Usage: run_test test_name}" |
| local out_dir="${TEST_XML_OUTPUT_DIR}/${test_name}" |
| mkdir -pv "${out_dir}" |
| set -x |
| python -m "tests.${test_name}" \ |
| --flagfile="${TEST_DRIVER_FLAGFILE}" \ |
| --kube_context="${KUBE_CONTEXT}" \ |
| --server_image="${SERVER_IMAGE_NAME}:${GIT_COMMIT}" \ |
| --client_image="${CLIENT_IMAGE_NAME}:${GIT_COMMIT}" \ |
| --testing_version="${TESTING_VERSION}" \ |
| --force_cleanup \ |
| --collect_app_logs \ |
| --log_dir="${out_dir}" \ |
| --xml_output_file="${out_dir}/sponge_log.xml" \ |
| |& tee "${out_dir}/sponge_log.log" |
| } |
| |
| ####################################### |
| # Main function: provision software necessary to execute tests, and run them |
| # Globals: |
| # KOKORO_ARTIFACTS_DIR |
| # GITHUB_REPOSITORY_NAME |
| # SRC_DIR: Populated with absolute path to the source repo |
| # TEST_DRIVER_REPO_DIR: Populated with the path to the repo containing |
| # the test driver |
| # TEST_DRIVER_FULL_DIR: Populated with the path to the test driver source code |
| # TEST_DRIVER_FLAGFILE: Populated with relative path to test driver flagfile |
| # TEST_XML_OUTPUT_DIR: Populated with the path to test xUnit XML report |
| # GIT_ORIGIN_URL: Populated with the origin URL of git repo used for the build |
| # GIT_COMMIT: Populated with the SHA-1 of git commit being built |
| # GIT_COMMIT_SHORT: Populated with the short SHA-1 of git commit being built |
| # KUBE_CONTEXT: Populated with name of kubectl context with GKE cluster access |
| # Arguments: |
| # None |
| # Outputs: |
| # Writes the output of test execution to stdout, stderr |
| ####################################### |
| main() { |
| local script_dir |
| script_dir="$(dirname "$0")" |
| |
| # Source the test driver from the master branch. |
| echo "Sourcing test driver install script from: ${TEST_DRIVER_INSTALL_SCRIPT_URL}" |
| source /dev/stdin <<< "$(curl -s "${TEST_DRIVER_INSTALL_SCRIPT_URL}")" |
| |
| activate_gke_cluster GKE_CLUSTER_PSM_SECURITY |
| |
| set -x |
| if [[ -n "${KOKORO_ARTIFACTS_DIR}" ]]; then |
| kokoro_setup_test_driver "${GITHUB_REPOSITORY_NAME}" |
| else |
| local_setup_test_driver "${script_dir}" |
| fi |
| build_docker_images_if_needed |
| # Run tests |
| cd "${TEST_DRIVER_FULL_DIR}" |
| local failed_tests=0 |
| test_suites=("baseline_test" "security_test" "authz_test") |
| for test in "${test_suites[@]}"; do |
| run_test $test || (( ++failed_tests )) |
| done |
| echo "Failed test suites: ${failed_tests}" |
| } |
| |
| main "$@" |