blob: 77d25d8f8109e26e92fb3255ffbdacce20b6af82 [file] [log] [blame]
Tim Windelschmidt6c851e22024-01-11 15:23:48 +01001# Import Aspect bazelrc presets
2import %workspace%/third_party/bazelrc/aspect/bazel7.bazelrc
3import %workspace%/third_party/bazelrc/aspect/convenience.bazelrc
4import %workspace%/third_party/bazelrc/aspect/correctness.bazelrc
5import %workspace%/third_party/bazelrc/aspect/performance.bazelrc
6
Tim Windelschmidtd7f59932024-07-24 23:37:03 +02007# Actually make the lock file a lock file by not updating it without any
8# request to do so.
9common --lockfile_mode=error
10
Tim Windelschmidt6c851e22024-01-11 15:23:48 +010011# Allow empty globs as there are a lot until we replace our rust toolchain and
12# qemu BUILD files.
13common --noincompatible_disallow_empty_glob
14
15# Don't warn about too high test timeout as these can vary a lot.
16test --notest_verbose_timeout_warnings
17
Leopold Schabel8661db32024-07-24 16:28:27 +000018# Set compilation mode (-c) to debug when running with --config dbg.
Lorenz Brun65702192023-08-31 16:27:38 +020019build:dbg --compilation_mode=dbg
20
Leopoldbc93c2b2023-01-14 13:12:23 +010021# Run all spawns in our own hermetic sandbox sysroot.
Leopold Schabel9508b122023-07-14 17:54:17 +020022build --experimental_use_hermetic_linux_sandbox
Tim Windelschmidt6c851e22024-01-11 15:23:48 +010023build --sandbox_fake_hostname
24build --sandbox_fake_username
Leopold7fbf1042023-01-06 19:57:37 +010025build --action_env=MONOGON_SANDBOX_DIGEST
26import %workspace%/.bazelrc.sandbox
27
Tim Windelschmidt6c851e22024-01-11 15:23:48 +010028# Enable revised output directory hash suffix computation
29build --experimental_output_directory_naming_scheme=diff_against_dynamic_baseline
30build --experimental_exec_configuration_distinguisher=off
31
Leopold Schabel9508b122023-07-14 17:54:17 +020032# Hardwire all action envs to just use /usr/bin from the above sandbox. This is
33# necessary on NixOS Bazel builds, as they really like to inject /nix/store/*
34# paths otherwise. We also explicitly set it to /usr/bin only (no /bin) as
35# otherwise calling gcc from /bin/gcc breaks its own resolution of subordinate
36# commands (like cc1, as, etc.).
37build --action_env=PATH=/usr/bin
38build --host_action_env=PATH=/usr/bin
39
40# Make all shell run actions use /bin/bash instead of whatever the host might
41# have set. Again, looking at you, Bazel-on-NixOS.
42build --shell_executable=/bin/bash
43
Leopoldbc93c2b2023-01-14 13:12:23 +010044# No local CPP toolchain resolution. In our sandbox root, it doesn't make sense -
45# anything auto-detected during analysis stage is on the host instead of the sandbox.
46# Sysroot rebuild is pure Go and doesn't need it either.
47# The flag ensures we fail early if we somehow depend on the host toolchain,
48# and do not spend unnecessary time on autodiscovery.
49build --action_env=BAZEL_DO_NOT_DETECT_CPP_TOOLCHAIN=1
50
51# Use new-style C++ toolchain resolution.
52build --incompatible_enable_cc_toolchain_resolution
53
54# In our monorepo, we mostly ignore the host platform since we bring our own
55# execution environment. However, we still need to run a small number of tools
56# such as gazelle. We can just use rules_go's pure-Go platform. Attempting to
57# build CGO binaries for the host will fail (and does not make sense).
58# The host is lava - it could be NixOS (or even potentially macOS/Windows).
59build --host_platform=@io_bazel_rules_go//go/toolchain:linux_amd64
60
61# Target platform for the monorepo is currently the same as the host platform,
62# but we'll support cross-compilation at some point. Do not rely on it.
63build --platforms=//build/platforms:linux_amd64
64# Make sure our platform is picked instead of the --host_platform.
65build --extra_execution_platforms=//build/platforms:linux_amd64
66
Leopoldeb2fb7b2022-06-08 13:18:51 +020067# Build resources
Leopold Schabel5c80aca2019-10-22 15:48:58 +020068startup --batch_cpu_scheduling --io_nice_level 7
Leopoldafb925b2023-01-08 16:57:28 +010069test --test_output=errors
Lorenz Brun5d7d2a42020-04-06 14:11:02 +020070
Leopold96b03c72022-06-08 12:59:58 +020071# selinux:
72# build with SELinux (containerd, kubelet)
73# no_zfs,no_aufs,no_devicemapper:
74# disable containerd features we don't need
75# providerless,dockerless:
76# build k8s without cloud provider and docker support
Serge Bazanski46e72ab2022-09-05 15:13:22 +020077# nowasm:
78# disable wasm plugin support in sqlc
Tim Windelschmidtd8a3fa22023-11-24 23:14:09 +010079# nobtrfs,nozfs,notapestats,norapl:
80# disable node_exporter features we don't need
81build --@io_bazel_rules_go//go/config:tags=selinux,seccomp,no_zfs,no_aufs,no_devicemapper,providerless,dockerless,nowasm,netgo,osusergo,nobtrfs,nozfs,notapestats,norapl
Serge Bazanskibb7db922020-04-30 12:43:10 +020082
Lorenz Brun65702192023-08-31 16:27:38 +020083# kvm_debug:
84# prevent stackoverflows for gvisor
Tim Windelschmidtd8a3fa22023-11-24 23:14:09 +010085build:dbg --@io_bazel_rules_go//go/config:tags=selinux,seccomp,no_zfs,no_aufs,no_devicemapper,providerless,dockerless,nowasm,netgo,osusergo,nobtrfs,nozfs,notapestats,norapl,kvm_debug
Lorenz Brun65702192023-08-31 16:27:38 +020086
Serge Bazanskibb7db922020-04-30 12:43:10 +020087# Build with C++17.
88build --cxxopt=-std=c++17
89
Lorenz Brunf6402112020-05-04 16:50:31 +020090# Set workspace status file and stamp
Serge Bazanskia6a03922023-11-13 19:57:48 +010091build --stamp --workspace_status_command=./build/print-workspace-status.py
Serge Bazanski385c12f2020-06-17 12:12:42 +020092
Serge Bazanski99b02142024-04-17 16:33:28 +020093test --experimental_allow_tags_propagation
94# Assume a 10k IOPS device (average NVMe) and 64GiB of RAM for test scheduling.
Tim Windelschmidt5be299e2024-07-13 02:59:52 +020095test --local_resources=iops=10000 --local_resources=ram=64000
Tim Windelschmidtf1e0fa12024-07-17 21:28:23 +020096
97# Load custom per-user settings.
98try-import %workspace%/.bazelrc.user