Skip to content

Commit

Permalink
[EXP] Bazel 8 support
Browse files Browse the repository at this point in the history
Update protobuf to v29 – see https://protobuf.dev/news/v29/

- Remove incompatible flag overrides that are now on-by-default in Bazel
  • Loading branch information
fhanau committed Dec 7, 2024
1 parent 03ea5e3 commit 892e95b
Show file tree
Hide file tree
Showing 17 changed files with 215 additions and 23 deletions.
19 changes: 10 additions & 9 deletions .bazelrc
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,7 @@ build --test_timeout=1,15,60,240
common --noenable_bzlmod

# bazel7 enables Build without the Bytes (BwoB) by default. This significantly speeds up builds
# using the remote cache since less data needs to be fetched. Set remote_cache_eviction_retries
# which is required to fully support a "dumb" cache. Bazel 8 already sets this value by default.
build --experimental_remote_cache_eviction_retries=5
# using the remote cache since less data needs to be fetched.
# Note that we use remote_download_minimal for test builds, which avoids fetching build outputs
# where possible. While several previous BwoB bugs have been fixed, this is slower than it could be
# due to https://github.com/bazelbuild/bazel/issues/20576.
Expand All @@ -33,12 +31,6 @@ import %workspace%/build/lint.bazelrc
# Enable webgpu
build --//src/workerd/io:enable_experimental_webgpu=True

# Avoid generating duplicate runfile trees. This will become the default in a future bazel version.
build --nolegacy_external_runfiles

# Flip this early to avoid breaking compatibility once it becomes the default.
build --incompatible_disallow_empty_glob

# Prevents bazel cache invalidation when switching terminals
build --incompatible_strict_action_env

Expand Down Expand Up @@ -383,3 +375,12 @@ build:windows --cxxopt='/Zc:__cplusplus' --host_cxxopt='/Zc:__cplusplus'
# enable clang coverage: https://clang.llvm.org/docs/SourceBasedCodeCoverage.html
build:clang-coverage --copt="-fprofile-instr-generate" --linkopt="-fprofile-instr-generate"
build:clang-coverage --copt="-fcoverage-mapping" --linkopt="-fcoverage-mapping"

build --enable_workspace
# As part of starlarkification, Bazel 8 removes a number of rules which now need to be imported from
# other repositories. In the long term, load() statements will be needed to import these rules. For
# now, we can still autoload the affected repositories when needed. Do this only for a few
# handpicked rules_python rules_shell, and protobuf components instead of the larger default
# autoload set – some dependencies aren't importing the required shell rules yet, but we don't want
# to accidentally rely on autoloading more dependencies.
build --incompatible_autoload_externally="+py_binary,+py_library,+py_test,+ProtoInfo,+sh_binary,+proto_library,+cc_proto_library"
2 changes: 1 addition & 1 deletion .bazelversion
Original file line number Diff line number Diff line change
@@ -1 +1 @@
7.4.1rc2
8.0.0rc8
1 change: 1 addition & 0 deletions MODULE.bazel
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# We don't use bzlmod at this time, but bazel 8 still expects us to have a MODULE.bazel file.
17 changes: 14 additions & 3 deletions WORKSPACE
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,11 @@ deps_gen()

load("@bazel_tools//tools/build_defs/repo:git.bzl", "git_repository")
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive", "http_file")
load("@rules_shell//shell:repositories.bzl", "rules_shell_dependencies", "rules_shell_toolchains")

rules_shell_dependencies()

rules_shell_toolchains()

NODE_VERSION = "22.11.0"

Expand Down Expand Up @@ -161,10 +166,14 @@ bind(
# OK, now we can bring in tcmalloc itself.
http_archive(
name = "com_google_tcmalloc",
sha256 = "81f285cb337f445276f37c308cb90120f8ba4311d1be9daf3b93dccf4bfdba7d",
strip_prefix = "google-tcmalloc-69c409c",
integrity = "sha256-mTDk4ij+KU0px7Mg4NSk15L9lD6RSIWuqZ7ILTkekb8=",
patch_args = ["-p1"],
patches = [
"//:patches/tcmalloc/0001-Support-Bazel-8.patch",
],
strip_prefix = "google-tcmalloc-4e8fcfc",
type = "tgz",
url = "https://github.com/google/tcmalloc/tarball/69c409c344bdf894fc7aab83e2d9e280b009b2f3",
url = "https://github.com/google/tcmalloc/tarball/4e8fcfc697761a2659fde4ecef15ac50cbc20784",
)

# ========================================================================================
Expand Down Expand Up @@ -277,6 +286,8 @@ esbuild_register_toolchains(
#
# There is an official mirror for V8 itself on GitHub, but not for dependencies like zlib (Chromium
# fork), icu (Chromium fork), and trace_event, so we still have to use git for them.
# TODO: Upstream 0021-bazel-Add-missing-imports-needed-with-Bazel-8.patch (currently unused here) to
# avoid needing to autoload py_test.

http_archive(
name = "v8",
Expand Down
24 changes: 22 additions & 2 deletions build/deps/build_deps.jsonc
Original file line number Diff line number Diff line change
Expand Up @@ -109,7 +109,10 @@
"type": "github_release",
"owner": "bazel-contrib",
"repo": "bazel-lib",
"file_regex": "^bazel-lib-"
"file_regex": "^bazel-lib-",
"patches": [
"//:patches/bazel-lib/0001-Support-Bazel-8.patch"
]
},
{
"name": "aspect_rules_js",
Expand All @@ -120,7 +123,10 @@
// TODO(cleanup): On latest version, Windows build fails with `tar.exe: Error opening archive:
// Can't initialize filter; unable to run program "gzip -d"`, likely due to
// https://github.com/aspect-build/rules_js/pull/1905/files. Develop a workaround.
"freeze_version": "v2.0.1"
"freeze_version": "v2.0.1",
"patches": [
"//:patches/rules_js/0001-Support-Bazel-8.patch"
]
},
{
"name": "aspect_rules_ts",
Expand All @@ -129,6 +135,20 @@
"repo": "rules_ts",
"file_regex": "^rules_ts-"
},
{
"name": "rules_shell",
"type": "github_release",
"owner": "bazelbuild",
"repo": "rules_shell",
"file_regex": "^rules_shell-"
},
{
"name": "rules_cc",
"type": "github_release",
"owner": "bazelbuild",
"repo": "rules_cc",
"file_regex": "^rules_cc-"
},
//buildifier
{
"name": "buildifier-linux-amd64",
Expand Down
4 changes: 4 additions & 0 deletions build/deps/gen/build_deps.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,12 @@ load("@//build/deps:gen/dep_cargo_bazel_macos_arm64.bzl", "dep_cargo_bazel_macos
load("@//build/deps:gen/dep_cargo_bazel_macos_x64.bzl", "dep_cargo_bazel_macos_x64")
load("@//build/deps:gen/dep_cargo_bazel_win_x64.bzl", "dep_cargo_bazel_win_x64")
load("@//build/deps:gen/dep_cxxbridge_cmd.bzl", "dep_cxxbridge_cmd")
load("@//build/deps:gen/dep_rules_cc.bzl", "dep_rules_cc")
load("@//build/deps:gen/dep_rules_nodejs.bzl", "dep_rules_nodejs")
load("@//build/deps:gen/dep_rules_pkg.bzl", "dep_rules_pkg")
load("@//build/deps:gen/dep_rules_python.bzl", "dep_rules_python")
load("@//build/deps:gen/dep_rules_rust.bzl", "dep_rules_rust")
load("@//build/deps:gen/dep_rules_shell.bzl", "dep_rules_shell")

def deps_gen():
dep_bazel_skylib()
Expand All @@ -39,6 +41,8 @@ def deps_gen():
dep_aspect_bazel_lib()
dep_aspect_rules_js()
dep_aspect_rules_ts()
dep_rules_shell()
dep_rules_cc()
dep_buildifier_linux_amd64()
dep_buildifier_linux_arm64()
dep_buildifier_darwin_amd64()
Expand Down
2 changes: 2 additions & 0 deletions build/deps/gen/dep_aspect_bazel_lib.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,6 @@ def dep_aspect_bazel_lib():
strip_prefix = STRIP_PREFIX,
type = TYPE,
sha256 = SHA256,
patches = ["//:patches/bazel-lib/0001-Support-Bazel-8.patch"],
patch_args = ["-p1"],
)
2 changes: 2 additions & 0 deletions build/deps/gen/dep_aspect_rules_js.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,6 @@ def dep_aspect_rules_js():
strip_prefix = STRIP_PREFIX,
type = TYPE,
sha256 = SHA256,
patches = ["//:patches/rules_js/0001-Support-Bazel-8.patch"],
patch_args = ["-p1"],
)
8 changes: 4 additions & 4 deletions build/deps/gen/dep_aspect_rules_ts.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,10 @@

load("@//:build/http.bzl", "http_archive")

TAG_NAME = "v3.3.1"
URL = "https://github.com/aspect-build/rules_ts/releases/download/v3.3.1/rules_ts-v3.3.1.tar.gz"
STRIP_PREFIX = "rules_ts-3.3.1"
SHA256 = "9acd128abe77397505148eaa6895faed57839560dbf2177dd6285e51235e2724"
TAG_NAME = "v3.3.2"
URL = "https://github.com/aspect-build/rules_ts/releases/download/v3.3.2/rules_ts-v3.3.2.tar.gz"
STRIP_PREFIX = "rules_ts-3.3.2"
SHA256 = "cff3137b043ff6bf1a2542fd9691dc762432370cd39eb4bb0756d288de52067d"
TYPE = "tgz"

def dep_aspect_rules_ts():
Expand Down
8 changes: 4 additions & 4 deletions build/deps/gen/dep_com_google_protobuf.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,10 @@

load("@//:build/http.bzl", "http_archive")

TAG_NAME = "v28.3"
URL = "https://github.com/protocolbuffers/protobuf/releases/download/v28.3/protobuf-28.3.tar.gz"
STRIP_PREFIX = "protobuf-28.3"
SHA256 = "7c3ebd7aaedd86fa5dc479a0fda803f602caaf78d8aff7ce83b89e1b8ae7442a"
TAG_NAME = "v29.1"
URL = "https://github.com/protocolbuffers/protobuf/releases/download/v29.1/protobuf-29.1.tar.gz"
STRIP_PREFIX = "protobuf-29.1"
SHA256 = "3d32940e975c4ad9b8ba69640e78f5527075bae33ca2890275bf26b853c0962c"
TYPE = "tgz"

def dep_com_google_protobuf():
Expand Down
18 changes: 18 additions & 0 deletions build/deps/gen/dep_rules_cc.bzl
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# WARNING: THIS FILE IS AUTOGENERATED BY update-deps.py DO NOT EDIT

load("@//:build/http.bzl", "http_archive")

TAG_NAME = "0.0.17"
URL = "https://github.com/bazelbuild/rules_cc/releases/download/0.0.17/rules_cc-0.0.17.tar.gz"
STRIP_PREFIX = "rules_cc-0.0.17"
SHA256 = "abc605dd850f813bb37004b77db20106a19311a96b2da1c92b789da529d28fe1"
TYPE = "tgz"

def dep_rules_cc():
http_archive(
name = "rules_cc",
url = URL,
strip_prefix = STRIP_PREFIX,
type = TYPE,
sha256 = SHA256,
)
18 changes: 18 additions & 0 deletions build/deps/gen/dep_rules_shell.bzl
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# WARNING: THIS FILE IS AUTOGENERATED BY update-deps.py DO NOT EDIT

load("@//:build/http.bzl", "http_archive")

TAG_NAME = "v0.3.0"
URL = "https://github.com/bazelbuild/rules_shell/releases/download/v0.3.0/rules_shell-v0.3.0.tar.gz"
STRIP_PREFIX = "rules_shell-0.3.0"
SHA256 = "d8cd4a3a91fc1dc68d4c7d6b655f09def109f7186437e3f50a9b60ab436a0c53"
TYPE = "tgz"

def dep_rules_shell():
http_archive(
name = "rules_shell",
url = URL,
strip_prefix = STRIP_PREFIX,
type = TYPE,
sha256 = SHA256,
)
41 changes: 41 additions & 0 deletions patches/bazel-lib/0001-Support-Bazel-8.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Felix Hanau <[email protected]>
Date: Sat, 23 Nov 2024 22:07:46 -0500
Subject: Support Bazel 8


diff --git a/lib/private/bats.bzl b/lib/private/bats.bzl
index 65de719a73114c24f837446d35c7a530adb47e94..c71aef825c5d020566abd800f77ab00fa335e200 100644
--- a/lib/private/bats.bzl
+++ b/lib/private/bats.bzl
@@ -102,7 +102,7 @@ bats_test = rule(
},
toolchains = [
"@aspect_bazel_lib//lib:bats_toolchain_type",
- "@bazel_tools//tools/sh:toolchain_type",
+ "@rules_shell//shell:toolchain_type",
],
test = True,
)
diff --git a/lib/windows_utils.bzl b/lib/windows_utils.bzl
index 30a81fed92d17d7eff4ddd0e96179f3001923712..f0af1fb8397f83773af8883049f093928323c668 100644
--- a/lib/windows_utils.bzl
+++ b/lib/windows_utils.bzl
@@ -70,7 +70,7 @@ exit /b 0
def create_windows_native_launcher_script(ctx, shell_script):
"""Create a Windows Batch file to launch the given shell script.

- The rule should specify @bazel_tools//tools/sh:toolchain_type as a required toolchain.
+ The rule should specify @rules_shell//shell:toolchain_type as a required toolchain.

Args:
ctx: Rule context
@@ -101,7 +101,7 @@ if defined args (
)
"{bash_bin}" -c "!run_script! !args!"
""".format(
- bash_bin = ctx.toolchains["@bazel_tools//tools/sh:toolchain_type"].path,
+ bash_bin = ctx.toolchains["@rules_shell//shell:toolchain_type"].path,
sh_script = paths.to_rlocation_path(ctx, shell_script),
rlocation_function = BATCH_RLOCATION_FUNCTION,
),
32 changes: 32 additions & 0 deletions patches/rules_js/0001-Support-Bazel-8.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Felix Hanau <[email protected]>
Date: Fri, 22 Nov 2024 19:19:24 -0500
Subject: Support Bazel 8


diff --git a/js/private/coverage/merger.bzl b/js/private/coverage/merger.bzl
index b41acfa6330e0b9dfcd71e83277275601ecd8a2a..08c82e0fff27014c5552af17a5423a6e8ca8cccf 100644
--- a/js/private/coverage/merger.bzl
+++ b/js/private/coverage/merger.bzl
@@ -68,7 +68,7 @@ coverage_merger = rule(
attrs = _ATTRS,
executable = True,
toolchains = [
- "@bazel_tools//tools/sh:toolchain_type",
+ "@rules_shell//shell:toolchain_type",
"@rules_nodejs//nodejs:toolchain_type",
],
)
diff --git a/js/private/js_binary.bzl b/js/private/js_binary.bzl
index 33e71d92adbd7d9a41575df815db59a1e97f33c2..72147c622ee95d8447ea4896cbf6fdb58149d3b8 100644
--- a/js/private/js_binary.bzl
+++ b/js/private/js_binary.bzl
@@ -614,7 +614,7 @@ js_binary_lib = struct(
implementation = _js_binary_impl,
toolchains = [
# TODO: on Windows this toolchain is never referenced
- "@bazel_tools//tools/sh:toolchain_type",
+ "@rules_shell//shell:toolchain_type",
"@rules_nodejs//nodejs:toolchain_type",
] + COPY_FILE_TO_BIN_TOOLCHAINS,
)
21 changes: 21 additions & 0 deletions patches/tcmalloc/0001-Support-Bazel-8.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Felix Hanau <[email protected]>
Date: Sat, 23 Nov 2024 22:27:27 -0500
Subject: Support Bazel 8


diff --git a/tcmalloc/internal/BUILD b/tcmalloc/internal/BUILD
index 3a6c0197d16112d2bc94789c7b9d4ed28f5303b8..66727b3a9fdf38f8b63202ecb550d91cf04100fd 100644
--- a/tcmalloc/internal/BUILD
+++ b/tcmalloc/internal/BUILD
@@ -14,8 +14,8 @@
#
# Internal libraries used for the implementation and testing of TCMalloc.

-load("@rules_cc//cc:defs.bzl", "cc_proto_library")
-load("@rules_proto//proto:defs.bzl", "proto_library")
+load("@com_google_protobuf//bazel:cc_proto_library.bzl", "cc_proto_library")
+load("@com_google_protobuf//bazel:proto_library.bzl", "proto_library")
load("//tcmalloc:copts.bzl", "TCMALLOC_DEFAULT_COPTS")
load("//tcmalloc:variants.bzl", "create_tcmalloc_benchmark")

Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
From c9688d31cd8e1e8cbb5624f9cee367029d5a728a Mon Sep 17 00:00:00 2001
From: Felix Hanau <[email protected]>
Date: Sun, 27 Oct 2024 16:49:31 +0000
Subject: [bazel] Add missing imports needed with Bazel 8


diff --git a/BUILD.bazel b/BUILD.bazel
index 3fa74551420b48f226553ddaa00eb9926a3b009f..5860920e592b2b22d44bbd6a62783fc472e4dcf7 100644
--- a/BUILD.bazel
+++ b/BUILD.bazel
@@ -3,7 +3,7 @@
# found in the LICENSE file.

load("@bazel_skylib//lib:selects.bzl", "selects")
-load("@rules_python//python:defs.bzl", "py_binary")
+load("@rules_python//python:defs.bzl", "py_binary", "py_test")
load("@v8_python_deps//:requirements.bzl", "requirement")
load(
"@v8//:bazel/defs.bzl",
2 changes: 2 additions & 0 deletions src/workerd/server/tests/compile-tests/BUILD.bazel
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
load("@rules_shell//shell:sh_test.bzl", "sh_test")

sh_test(
name = "helloworld_compile_test",
size = "medium",
Expand Down

0 comments on commit 892e95b

Please sign in to comment.