blob: e8352365e2170dc78fd7f9f0aee522e744324485 [file] [log] [blame]
#!/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.
set -ex
# change to grpc repo root
cd "$(dirname "$0")/../../.."
# Use the docker image used as the default for C++ by run_tests.py
# To use the correct docker image for your experiments,
# note that every invocation of run_tests.py with "--use_docker"
# prints the docker image used as a debug message at the end of the run.
# This is expecially important when --compiler/--arch params are
# use, since they usually influence with docker image will be used
# by run_tests.py
export DOCKERFILE_DIR=tools/dockerfile/test/cxx_debian11_x64
# "--privileged" docker arg is required to be able to update /proc/sys/kernel/core_pattern
export DOCKER_EXTRA_ARGS="--privileged"
# start the docker container with interactive shell
tools/docker_runners/run_in_docker.sh bash
# Run these commands under the docker container
#
# Install gdb (or similar command for non-debian based distros)
# $ apt-get update && apt-get install -y gdb
#
# No limit for coredump size
# $ ulimit -c unlimited
#
# Coredumps will be stored to /tmp/coredumps (inside the docker container)
# mkdir /tmp/coredumps
# echo "/tmp/coredumps/core.%p" | tee /proc/sys/kernel/core_pattern
#
# Build e.g. the C tests
# $ ./tools/run_tests/run_tests.py -l c -c dbg --build_only
#
# Run a test that crashes, it will create a coredump.
# $ cmake/build/foo_bar_test
#
# Open coredump under gdb
# $ gdb cmake/build/foo_bar_test /tmp/coredumps/core.XYZ