The C based gRPC (C++, Python, Ruby, Objective-C, PHP, C#) https://grpc.io/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

175 lines
7.4 KiB

# Copyright 2023 The gRPC 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.
"""
Contains macros used for running bazelified tests.
"""
load(":dockerimage_current_versions.bzl", "DOCKERIMAGE_CURRENT_VERSIONS")
load("@bazel_toolchains//rules/exec_properties:exec_properties.bzl", "create_rbe_exec_properties_dict")
def _dockerized_sh_test(name, srcs = [], args = [], data = [], size = "medium", timeout = None, tags = [], exec_compatible_with = [], flaky = None, docker_image_version = None, docker_run_as_root = False, env = {}):
"""Runs sh_test under docker either via RBE or via docker sandbox."""
if docker_image_version:
image_spec = DOCKERIMAGE_CURRENT_VERSIONS.get(docker_image_version, None)
if not image_spec:
fail("Version info for docker image '%s' not found in dockerimage_current_versions.bzl" % docker_image_version)
else:
fail("docker_image_version attribute not set for dockerized test '%s'" % name)
exec_properties = create_rbe_exec_properties_dict(
labels = {
"workload": "misc",
"machine_size": "misc_large",
},
docker_network = "standard",
container_image = image_spec,
# TODO(jtattermusch): note that docker sandbox doesn't currently support "docker_run_as_root"
docker_run_as_root = docker_run_as_root,
)
# since the tests require special bazel args, only run them when explicitly requested
tags = ["manual"] + tags
# TODO(jtattermusch): find a way to ensure that action can only run under docker sandbox or remotely
# to avoid running it outside of a docker container by accident.
test_args = {
"name": name,
"srcs": srcs,
"tags": tags,
"args": args,
"flaky": flaky,
"data": data,
"size": size,
"env": env,
"timeout": timeout,
"exec_compatible_with": exec_compatible_with,
"exec_properties": exec_properties,
}
native.sh_test(
**test_args
)
def grpc_run_tests_harness_test(name, args = [], data = [], size = "medium", timeout = None, tags = [], exec_compatible_with = [], flaky = None, docker_image_version = None, use_login_shell = None, prepare_script = None):
"""Execute an run_tests.py-harness style test under bazel.
Args:
name: The name of the test.
args: The args to supply to the test binary.
data: Data dependencies.
size: The size of the test.
timeout: The test timeout.
tags: The tags for the test.
exec_compatible_with: A list of constraint values that must be
satisifed for the platform.
flaky: Whether this test is flaky.
docker_image_version: The docker .current_version file to use for docker containerization.
use_login_shell: If True, the run_tests.py command will run under a login shell.
prepare_script: Optional script that will be sourced before run_tests.py runs.
"""
data = [
"//tools/bazelify_tests:grpc_repo_archive_with_submodules.tar.gz",
] + data
args = [
"$(location //tools/bazelify_tests:grpc_repo_archive_with_submodules.tar.gz)",
] + args
srcs = [
"//tools/bazelify_tests:grpc_run_tests_harness_test.sh",
]
env = {}
if use_login_shell:
env["GRPC_RUNTESTS_USE_LOGIN_SHELL"] = "1"
if prepare_script:
data = data + [prepare_script]
env["GRPC_RUNTESTS_PREPARE_SCRIPT"] = "$(location " + prepare_script + ")"
# Enable ccache by default. This is important for speeding up the C++ cmake build,
# which isn't very efficient and tends to recompile some source files multiple times.
# Even though only the local disk cache is enabled (local to the docker container,
# so will be thrown away after the bazel actions finishes), ccache still speeds up
# the C++ build significantly.
# TODO(jtattermusch): find a cleaner way to toggle ccache for builds.
env["GRPC_BUILD_ENABLE_CCACHE"] = "true"
_dockerized_sh_test(name = name, srcs = srcs, args = args, data = data, size = size, timeout = timeout, tags = tags, exec_compatible_with = exec_compatible_with, flaky = flaky, docker_image_version = docker_image_version, env = env)
def grpc_run_bazel_distribtest_test(name, args = [], data = [], size = "medium", timeout = None, tags = [], exec_compatible_with = [], flaky = None, docker_image_version = None):
"""Execute bazel distribtest under bazel (an entire bazel build/test will run in a container as a single bazel action)
Args:
name: The name of the test.
args: The args to supply to the test binary.
data: Data dependencies.
size: The size of the test.
timeout: The test timeout.
tags: The tags for the test.
exec_compatible_with: A list of constraint values that must be
satisifed for the platform.
flaky: Whether this test is flaky.
docker_image_version: The docker .current_version file to use for docker containerization.
"""
data = [
"//tools/bazelify_tests:grpc_repo_archive_with_submodules.tar.gz",
] + data
args = [
"$(location //tools/bazelify_tests:grpc_repo_archive_with_submodules.tar.gz)",
] + args
srcs = [
"//tools/bazelify_tests:grpc_run_bazel_distribtest_test.sh",
]
env = {}
_dockerized_sh_test(name = name, srcs = srcs, args = args, data = data, size = size, timeout = timeout, tags = tags, exec_compatible_with = exec_compatible_with, flaky = flaky, docker_image_version = docker_image_version, env = env)
def grpc_run_cpp_distribtest_test(name, args = [], data = [], size = "medium", timeout = None, tags = [], exec_compatible_with = [], flaky = None, docker_image_version = None):
"""Execute an C++ distribtest under bazel.
Args:
name: The name of the test.
args: The args to supply to the test binary.
data: Data dependencies.
size: The size of the test.
timeout: The test timeout.
tags: The tags for the test.
exec_compatible_with: A list of constraint values that must be
satisifed for the platform.
flaky: Whether this test is flaky.
docker_image_version: The docker .current_version file to use for docker containerization.
"""
data = [
"//tools/bazelify_tests:grpc_repo_archive_with_submodules.tar.gz",
] + data
args = [
"$(location //tools/bazelify_tests:grpc_repo_archive_with_submodules.tar.gz)",
] + args
srcs = [
"//tools/bazelify_tests:grpc_run_cpp_distribtest_test.sh",
]
# TODO(jtattermusch): revisit running docker as root (but currently some distribtests need to install stuff inside the docker container)
env = {}
_dockerized_sh_test(name = name, srcs = srcs, args = args, data = data, size = size, timeout = timeout, tags = tags, exec_compatible_with = exec_compatible_with, flaky = flaky, docker_image_version = docker_image_version, env = env, docker_run_as_root = True)