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.
 
 
 
 
 
 
Craig Tiller 2bcca66712
[fuzzing] Roll forward dep on fuzztest (#32667)
2 years ago
..
distribtest Update all Debian:9 to Debian:10 (#31917) 2 years ago
grpc_artifact_centos6_x64
grpc_artifact_centos6_x86
grpc_artifact_protoc_aarch64
grpc_artifact_python_linux_armv7 Support Python 3.11 (#30818) 2 years ago
grpc_artifact_python_manylinux2014_aarch64 Support python 3.11 on aarch64 (#32270) 2 years ago
grpc_artifact_python_manylinux2014_x64 Support Python 3.11 (#30818) 2 years ago
grpc_artifact_python_manylinux2014_x86 Support Python 3.11 (#30818) 2 years ago
grpc_artifact_python_musllinux_1_1_x64 Support Python 3.11 (#30818) 2 years ago
grpc_artifact_python_musllinux_1_1_x86 Support Python 3.11 (#30818) 2 years ago
grpc_clang_format Update Clang 15 (#31518) 2 years ago
grpc_clang_tidy Update Clang 15 (#31518) 2 years ago
grpc_dist_proto
grpc_iwyu [fuzzing] Roll forward dep on fuzztest (#32667) 2 years ago
grpc_scan_build
interoptest xDS Interop: Update tracers (#32352) 2 years ago
observability-test/cpp Observability Testing: Pass interop parameters to each lang's run.sh script as-is (#32586) 2 years ago
test [fork] Generate GDB backtraces in fork tests on Kokoro (#32535) 2 years ago
OWNERS
README.md tools/dockerfile: Document how to configure pkg.dev authentication (#31746) 2 years ago
grpc_artifact_centos6_x64.current_version Move docker images from dockerhub to artifact registry. (#31591) 2 years ago
grpc_artifact_centos6_x86.current_version Move docker images from dockerhub to artifact registry. (#31591) 2 years ago
grpc_artifact_protoc_aarch64.current_version Move docker images from dockerhub to artifact registry. (#31591) 2 years ago
grpc_artifact_python_linux_armv7.current_version Move docker images from dockerhub to artifact registry. (#31591) 2 years ago
grpc_artifact_python_manylinux2014_aarch64.current_version Support python 3.11 on aarch64 (#32270) 2 years ago
grpc_artifact_python_manylinux2014_x64.current_version Move docker images from dockerhub to artifact registry. (#31591) 2 years ago
grpc_artifact_python_manylinux2014_x86.current_version Move docker images from dockerhub to artifact registry. (#31591) 2 years ago
grpc_artifact_python_musllinux_1_1_x64.current_version Move docker images from dockerhub to artifact registry. (#31591) 2 years ago
grpc_artifact_python_musllinux_1_1_x86.current_version Move docker images from dockerhub to artifact registry. (#31591) 2 years ago
push_testing_images.sh More cleanup after moving testing docker images to artifact registry. (#31689) 2 years ago

README.md

Docker images used for gRPC testing

Most of our linux tests on the CI run under a docker container, since that makes it easier to maintain the test environment and the dependencies. Having an easily reproducible test environment also make it easier to reproduce issues we see on CI locally.

The docker image definitions we use live under tools/dockerfile directory (with the exception of third_party/rake-compiler-dock docker images).

Version management

The docker images we use for testing evolve over time (and newer/older versions of it might not work with newer/older revisions of our code).

For each dockerfile (which is identified by the directory in which is it located), the "current version" that's being used by testing is determined by the corresponding .current_version file, which contains the full docker image name, including artifact registry location, docker image name, the current tag and the SHA256 image digest.

Example: For tools/dockerfile/test/cxx_debian11_x64/Dockerfile, there is a tools/dockerfile/test/cxx_debian11_x64.current_version file which contains info as follows:

us-docker.pkg.dev/grpc-testing/testing-images-public/cxx_debian11_x64:[CURRENT_CHECKSUM]@sha256:[CURRENT_SHA256_DIGEST]

This info can be passed directly to docker run command to get an environment that's identical what what we use when testing on CI.

Updating the images

The authoritative version of docker images we use for testing is stored in artifact registry, under the repository us-docker.pkg.dev/grpc-testing/testing-images-public.

If you've made modifications to a dockerfile, you can upload the new version of the artifact registry as follows:

If you haven't configured authentication in Docker for us-docker.pkg.dev previously, run:

gcloud auth configure-docker us-docker.pkg.dev
gcloud auth login

Rebuild the docker images that have been modified locally and upload the docker images to artifact registry (note that this won't overwrite the "old" versions of the docker image that are already in artifact registry)

tools/dockerfile/push_testing_images.sh

Build modified docker images locally and don't push to artifact registry. This option is very useful for quick local experiments. The script is much faster if it doesn't have to interact with artifact registry:

# very useful for local experiments
LOCAL_ONLY_MODE=true tools/dockerfile/push_testing_images.sh

Migrating from dockerhub

In the past, our testing docker images were hosted on dockerhub, but we are in the process of migrating them artifact registry now.

This temporary feature might simplify the migration:

# try pull existing images from dockerhub instead of building the from scratch locally.
TRANSFER_FROM_DOCKERHUB=true tools/dockerfile/push_testing_images.sh