1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- #!/bin/bash
- # Copyright 2021 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.
- # Runs C# build in a docker container, but using the local workspace.
- # Example usage:
- # src/csharp/run_in_docker.sh tools/run_tests/run_tests.py -l csharp
- set -e
- # Environment variable used as inputs:
- # DOCKERFILE_DIR - Directory in which Dockerfile file is located.
- # DOCKER_EXTRA_ARGS - Extra arguments to pass to the "docker run" command.
- readonly grpc_rootdir="$(dirname "$(readlink -f "$0")")/../.."
- cd ${grpc_rootdir}
- if [ "${DOCKERFILE_DIR}" == "" ]
- then
- echo "You need to specify the docker image to use by setting DOCKERFILE_DIR env variable."
- echo "See docker image definitions under tools/dockerfile."
- echo ""
- echo "You likely want to set DOCKERFILE_DIR to one of these values:"
- find tools/dockerfile/test -name Dockerfile | xargs -n1 dirname
- exit 1
- fi
- # Use image name based on Dockerfile location checksum
- # For simplicity, currently only testing docker images that have already been pushed
- # to dockerhub are supported (see tools/dockerfile/push_testing_images.sh)
- # TODO(jtattermusch): add support for building dockerimages locally.
- DOCKER_IMAGE=grpctesting/$(basename "$DOCKERFILE_DIR"):$(sha1sum "$DOCKERFILE_DIR/Dockerfile" | cut -f1 -d\ )
- # TODO: support building dockerimage locally / pulling it from dockerhub
- # If TTY is available, the running container can be conveniently terminated with Ctrl+C.
- if [[ -t 0 ]]; then
- DOCKER_TTY_ARGS=("-it")
- else
- # The input device on kokoro is not a TTY, so -it does not work.
- DOCKER_TTY_ARGS=()
- fi
- # args required to be able to run gdb/strace under the docker container
- DOCKER_PRIVILEGED_ARGS=(
- "--privileged"
- "--cap-add=SYS_PTRACE"
- "--security-opt=seccomp=unconfined"
- )
- DOCKER_NETWORK_ARGS=(
- # enable IPv6
- "--sysctl=net.ipv6.conf.all.disable_ipv6=0"
- # use host network, required for the port server to work correctly
- "--network=host"
- )
- DOCKER_CLEANUP_ARGS=(
- # delete the container when the containers exits
- # (otherwise the container will not release the disk space it used)
- "--rm=true"
- )
- DOCKER_PROPAGATE_ENV_ARGS=(
- "--env-file=tools/run_tests/dockerize/docker_propagate_env.list" \
- )
- # Uncomment to run the docker container as current user's UID and GID.
- # That way, the files written by the container won't be owned by root (=you won't end up with polluted workspace),
- # but it can have some other disadvantages. E.g.:
- # - you won't be able install stuff inside the container
- # - the home directory inside the container will be broken (you won't be able to write in it).
- # That may actually break some language runtimes completely (e.g. grpc python might not build)
- # DOCKER_NONROOT_ARGS=(
- # # run under current user's UID and GID
- # "--user=$(id -u):$(id -g)"
- # )
- # Enable command echo just before running the final docker command to make the docker args visible.
- set -ex
- # Run command inside C# docker container.
- # - the local clone of grpc repository will be mounted as /workspace.
- exec docker run "${DOCKER_TTY_ARGS[@]}" "${DOCKER_PRIVILEGED_ARGS[@]}" "${DOCKER_NETWORK_ARGS[@]}" "${DOCKER_CLEANUP_ARGS[@]}" "${DOCKER_PROPAGATE_ENV_ARGS[@]}" ${DOCKER_EXTRA_ARGS} -v "${grpc_rootdir}":/workspace -w /workspace "${DOCKER_IMAGE}" bash -c "$*"
|