| # Copyright 2015 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. |
| |
| # Pinned version of the base image is used to avoid regressions caused |
| # by rebuilding of this docker image. To see available versions, you can run |
| # "gcloud container images list-tags gcr.io/oss-fuzz-base/base-builder" |
| # This base image is built on Mar 12, 2024 |
| FROM gcr.io/oss-fuzz-base/base-builder@sha256:c3581153788bc49f3634fec3cd36a5d6dfd26632c4afc157fb6faf8ce3af732e |
| |
| # -------------------------- WARNING -------------------------------------- |
| # If you are making changes to this file, consider changing |
| # https://github.com/google/oss-fuzz/blob/master/projects/grpc/Dockerfile |
| # accordingly. |
| # ------------------------------------------------------------------------- |
| |
| # Install basic packages |
| RUN apt-get update && apt-get -y install \ |
| autoconf \ |
| build-essential \ |
| curl \ |
| libtool \ |
| make \ |
| vim \ |
| wget |
| |
| #======================== |
| # Bazel installation |
| |
| # Must be in sync with tools/bazel |
| ENV BAZEL_VERSION 7.1.0 |
| |
| # The correct bazel version is already preinstalled, no need to use //tools/bazel wrapper. |
| ENV DISABLE_BAZEL_WRAPPER 1 |
| |
| # Download the correct bazel version and make sure it's on path. |
| RUN BAZEL_ARCH_SUFFIX="$(uname -m | sed s/aarch64/arm64/)" \ |
| && curl -sSL --fail -o /usr/local/bin/bazel "https://github.com/bazelbuild/bazel/releases/download/$BAZEL_VERSION/bazel-$BAZEL_VERSION-linux-$BAZEL_ARCH_SUFFIX" \ |
| && chmod a+x /usr/local/bin/bazel |
| |
| # Normally we would run "bazel --version" here to make sure bazel |
| # was correctly installed, but we can't do that because |
| # of # https://github.com/bazelbuild/bazel/issues/11379. |
| # We want to keep the arm64 version of the image buildable |
| # on x64 with use of qemu-user-static & binfmt emulation, |
| # but the self-extraction is broken for bazel currently. |
| # The binary will work correctly when run on real arm64 |
| # hardware, when qemu-user-static isn't getting into the way. |
| |
| #================= |
| # Setup git to access working directory across docker boundary. |
| # This avoids the "fatal: detected dubious ownership in repository XYZ" |
| # git error. |
| |
| RUN git config --global --add safe.directory '*' |
| RUN git config --global protocol.file.allow always |
| |
| #================= |
| # Setup git to access working directory across docker boundary. |
| # This avoids the "fatal: detected dubious ownership in repository XYZ" |
| # git error. Using "--system" makes the setting work |
| # for all users or even current user is not properly defined |
| # (which can happen e.g. inside execution environment |
| # of a bazel action) |
| |
| RUN git config --system --add safe.directory '*' |
| RUN git config --system protocol.file.allow always |
| |
| |
| RUN apt-get install -y gdb |
| |
| RUN mkdir -p /var/local/jenkins |
| |
| # Define the default command. |
| CMD ["bash"] |