Skip to content

Commit

Permalink
fix ci for bazel 8.x
Browse files Browse the repository at this point in the history
  • Loading branch information
jsharpe committed Dec 17, 2024
1 parent 21e463e commit 654fcd4
Show file tree
Hide file tree
Showing 12 changed files with 163 additions and 104 deletions.
70 changes: 43 additions & 27 deletions .bazelci/config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,12 @@ tasks:
- "//..."
test_targets:
- "//..."
macos_arm64:
platform: macos_arm64
build_targets:
- "//..."
test_targets:
- "//..."
windows:
platform: windows
build_targets:
Expand All @@ -28,10 +34,8 @@ tasks:
- "-//test:shell_method_symlink_contents_to_dir_test"
- "-//test:shell_script_inner_fun_test"
build_flags:
- "--noenable_bzlmod"
- "--enable_workspace"
test_flags:
- "--noenable_bzlmod"
- "--enable_workspace"
ubuntu1804_examples_standalone:
name: Examples (spawn_strategy=standalone)
Expand All @@ -45,14 +49,12 @@ tasks:
- "-c"
- "dbg"
- "--spawn_strategy=standalone"
- "--noenable_bzlmod"
- "--enable_workspace"
test_targets: *linux_targets_standalone
test_flags:
- "-c"
- "dbg"
- "--spawn_strategy=standalone"
- "--noenable_bzlmod"
- "--enable_workspace"
ubuntu2004_examples:
name: Examples
Expand All @@ -64,24 +66,9 @@ tasks:
build_targets: *linux_targets
test_targets: *linux_targets
build_flags:
- "--noenable_bzlmod"
- "--enable_workspace"
test_flags:
- "--noenable_bzlmod"
- "--enable_workspace"
ubuntu2004_examples_bzlmod:
name: Examples (bzlmod)
platform: ubuntu2004
working_directory: examples
linux_targets: &linux_targets_bzlmod
- "//..."
- "//:third_party_examples_linux_tests"
# gives error '//external:databinding_annotation_processor': target 'databinding_annotation_processor' not declared in package 'external' defined by /workdir/examples/WORKSPACE.bazel (Tip: use `query "//external:*"` to see all the targets in that package) and referenced by '@bazel_tools//tools/android:databinding_annotation_processor'
- "-//cmake_android/..."
build_targets: *linux_targets_bzlmod
test_targets: *linux_targets_bzlmod
build_flags:
- "--enable_bzlmod"
rbe_ubuntu2004_examples:
name: Examples
platform: rbe_ubuntu2004
Expand All @@ -91,10 +78,12 @@ tasks:
- "//:third_party_examples_linux_rbe_tests"
# Gives error: zipalign: error while loading shared libraries: /usr/local/lib/libc++.so: file too short
- "-//cmake_android/..."
# Python requirements not supported on Ubuntu 16.04
- "-//:requirements_test"
build_targets: *rbe_targets
test_targets: *rbe_targets
build_flags:
- "--enable_workspace"
test_flags:
- "--enable_workspace"
macos_examples_standalone:
name: Examples (spawn_strategy=standalone)
platform: macos
Expand All @@ -112,15 +101,13 @@ tasks:
- "dbg"
- "--spawn_strategy=standalone"
- "--noincompatible_enable_cc_toolchain_resolution"
- "--noenable_bzlmod"
- "--enable_workspace"
test_targets: *macos_targets_standalone
test_flags:
- "-c"
- "dbg"
- "--spawn_strategy=standalone"
- "--noincompatible_enable_cc_toolchain_resolution"
- "--noenable_bzlmod"
- "--enable_workspace"
macos_examples:
name: Examples
Expand All @@ -136,12 +123,10 @@ tasks:
build_targets: *macos_targets
build_flags:
- "--noincompatible_enable_cc_toolchain_resolution"
- "--noenable_bzlmod"
- "--enable_workspace"
test_targets: *macos_targets
test_flags:
- "--noincompatible_enable_cc_toolchain_resolution"
- "--noenable_bzlmod"
- "--enable_workspace"
windows_examples:
name: Examples
Expand Down Expand Up @@ -172,10 +157,8 @@ tasks:
build_targets: *windows_targets
test_targets: *windows_targets
build_flags:
- "--noenable_bzlmod"
- "--enable_workspace"
test_flags:
- "--noenable_bzlmod"
- "--enable_workspace"
rbe_ubuntu2004_flags:
name: Flags
Expand All @@ -195,6 +178,12 @@ tasks:
working_directory: test/standard_cxx_flags_test
test_targets:
- "//:flags_test"
macos_arm64_flags:
name: Flags (arm64)
platform: macos_arm64
working_directory: test/standard_cxx_flags_test
test_targets:
- "//:flags_test"
windows_flags:
name: Flags
platform: windows
Expand All @@ -207,26 +196,53 @@ tasks:
working_directory: test/detect_root_test
test_targets:
- "//:tests"
build_flags:
- "--enable_workspace"
test_flags:
- "--enable_workspace"
ubuntu2004_detect_root:
name: Detect root
platform: ubuntu2004
working_directory: test/detect_root_test
test_targets:
- "//:tests"
build_flags:
- "--enable_workspace"
test_flags:
- "--enable_workspace"
macos_detect_root:
name: Detect root
platform: macos
working_directory: test/detect_root_test
test_targets:
- "//:tests"
build_flags:
- "--enable_workspace"
test_flags:
- "--enable_workspace"
macos_oarm64_detect_root:
name: Detect root (arm64)
platform: macos_arm64
working_directory: test/detect_root_test
test_targets:
- "//:tests"
build_flags:
- "--enable_workspace"
test_flags:
- "--enable_workspace"
windows_detect_root:
name: Detect root
platform: windows
working_directory: test/detect_root_test
test_targets:
- "//:tests"
build_flags:
- "--enable_workspace"
test_flags:
- "--enable_workspace"
docs_linux:
name: Docs
bazel: "7.4.1"
platform: ubuntu2004
working_directory: docs
build_targets:
Expand Down
20 changes: 15 additions & 5 deletions MODULE.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,9 @@ module(
)

bazel_dep(name = "bazel_features", version = "1.15.0")
bazel_dep(name = "bazel_skylib", version = "1.3.0")
bazel_dep(name = "bazel_skylib", version = "1.7.1")
bazel_dep(name = "platforms", version = "0.0.5")
bazel_dep(name = "rules_python", version = "0.23.1")
bazel_dep(name = "rules_python", version = "1.0.0")
bazel_dep(name = "rules_shell", version = "0.3.0")

# Dev dependencies
Expand All @@ -22,9 +22,19 @@ bazel_dep(name = "bazel_ci_rules", version = "1.0.0", dev_dependency = True)
# depends on it. If you are not using bazel_ci_rules; ideally we'd be able to remove this.
bazel_dep(name = "rules_cc", version = "0.0.9", dev_dependency = True)

rbe_preconfig = use_repo_rule(
"@bazel_ci_rules//:rbe_repo.bzl",
"rbe_preconfig",
)

rbe_preconfig(
name = "buildkite_config",
toolchain = "ubuntu2004",
)

python = use_extension("@rules_python//python/extensions:python.bzl", "python")
python.toolchain(python_version = "3.9")
use_repo(python, "python_3_9")
python.toolchain(python_version = "3.12")
use_repo(python, "python_3_12")

tools = use_extension("@rules_foreign_cc//foreign_cc:extensions.bzl", "tools")
use_repo(
Expand All @@ -46,6 +56,6 @@ register_toolchains(
"@rules_foreign_cc_framework_toolchains//:all",
"@cmake_3.23.2_toolchains//:all",
"@ninja_1.12.1_toolchains//:all",
"@python_3_9//:all",
"@python_3_12//:all",
"@rules_foreign_cc//toolchains:all",
)
Empty file added REPO.bazel
Empty file.
10 changes: 0 additions & 10 deletions WORKSPACE.bzlmod
Original file line number Diff line number Diff line change
@@ -1,11 +1 @@
workspace(name = "rules_foreign_cc")

load("@bazel_ci_rules//:rbe_repo.bzl", "rbe_preconfig")

# Creates a default toolchain config for RBE.
# Use this as is if you are using the rbe_ubuntu16_04 container,
# otherwise refer to RBE docs.
rbe_preconfig(
name = "buildkite_config",
toolchain = "ubuntu1804-bazel-java11",
)
1 change: 1 addition & 0 deletions docs/.bazelrc
Original file line number Diff line number Diff line change
Expand Up @@ -4,4 +4,5 @@
common --incompatible_allow_tags_propagation

common --noenable_bzlmod
common --enable_workspace
build --workspace_status_command=tools/workspace_status.sh
62 changes: 39 additions & 23 deletions examples/MODULE.bazel
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
bazel_dep(name = "rules_foreign_cc", version = "0.0.0")
bazel_dep(name = "rules_foreign_cc")
local_path_override(
module_name = "rules_foreign_cc",
path = "..",
Expand All @@ -13,12 +13,15 @@ use_repo(
)

bazel_dep(name = "platforms", version = "0.0.6")
bazel_dep(name = "rules_swift", version = "1.6.0", repo_name = "build_bazel_rules_swift")
bazel_dep(name = "rules_apple", version = "3.4.0", repo_name = "build_bazel_rules_apple")
bazel_dep(name = "apple_support", version = "1.12.0", repo_name = "build_bazel_apple_support")
bazel_dep(name = "bazel_skylib", version = "1.7.1")
bazel_dep(name = "rules_swift", version = "2.1.1", repo_name = "build_bazel_rules_swift")
bazel_dep(name = "rules_apple", version = "3.16.1", repo_name = "build_bazel_rules_apple")
bazel_dep(name = "apple_support", version = "1.17.1", repo_name = "build_bazel_apple_support")
bazel_dep(name = "rules_python", version = "0.23.0")
bazel_dep(name = "rules_cc", version = "0.0.9")
bazel_dep(name = "rules_shell", version = "0.3.0")
bazel_dep(name = "rules_java", version = "8.6.2")
bazel_dep(name = "rules_perl", version = "0.2.4")

python = use_extension("@rules_python//python/extensions:python.bzl", "python")
python.toolchain(
Expand All @@ -30,26 +33,39 @@ python.toolchain(

pip = use_extension("@rules_python//python/extensions:pip.bzl", "pip")
pip.parse(
name = "pip",
hub_name = "pip",
python_version = "3.10",
requirements_lock = "//:requirements_lock.txt",
requirements_windows = "//:requirements_windows.txt",
)
use_repo(pip, "pip")

# bazel_dep(name = "rules_android", version = "0.1.1")
# bazel_dep(name = "rules_jvm_external", version = "5.1")
#
# maven = use_extension("@rules_jvm_external//:extensions.bzl", "maven")
#
# maven.install(
# name = "maven_deps",
# artifacts = [
# "com.android.support.constraint:constraint-layout:aar:1.1.2",
# "com.android.support:appcompat-v7:aar:26.1.0",
# ],
# repositories = [
# "https://jcenter.bintray.com/",
# "https://maven.google.com",
# "https://repo1.maven.org/maven2",
# ],
# )
bazel_dep(name = "rules_android", version = "0.6.0-alpha1.bcr.1")
bazel_dep(name = "rules_android_ndk", version = "0.1.2")
bazel_dep(name = "rules_jvm_external", version = "5.1")

maven = use_extension("@rules_jvm_external//:extensions.bzl", "maven")
maven.install(
name = "maven",
artifacts = [
"com.android.support.constraint:constraint-layout:aar:1.1.2",
"com.android.support:appcompat-v7:aar:26.1.0",
],
repositories = [
"https://jcenter.bintray.com/",
"https://maven.google.com",
"https://repo1.maven.org/maven2",
],
)
use_repo(maven, "maven")

bazel_dep(name = "bazel_ci_rules", version = "1.0.0", dev_dependency = True)

rbe_preconfig = use_repo_rule(
"@bazel_ci_rules//:rbe_repo.bzl",
"rbe_preconfig",
)

rbe_preconfig(
name = "buildkite_config",
toolchain = "ubuntu2004",
)
35 changes: 0 additions & 35 deletions examples/WORKSPACE.bzlmod
Original file line number Diff line number Diff line change
@@ -1,17 +1,5 @@
workspace(name = "rules_foreign_cc_examples")

load("//deps:repositories.bzl", "repositories")

repositories()

load("//deps:deps_android.bzl", "deps_android")

deps_android()

load("//deps:deps_jvm_external.bzl", "deps_jvm_external")

deps_jvm_external()

local_repository(
name = "rules_foreign_cc_examples_third_party",
path = "third_party",
Expand All @@ -20,26 +8,3 @@ local_repository(
load("@rules_foreign_cc_examples_third_party//:repositories.bzl", examples_third_party_repositories = "repositories")

examples_third_party_repositories()

load("@rules_foreign_cc_examples_third_party//:setup.bzl", examples_third_party_setup = "setup")

examples_third_party_setup()

load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")

http_archive(
name = "bazelci_rules",
sha256 = "eca21884e6f66a88c358e580fd67a6b148d30ab57b1680f62a96c00f9bc6a07e",
strip_prefix = "bazelci_rules-1.0.0",
url = "https://github.com/bazelbuild/continuous-integration/releases/download/rules-1.0.0/bazelci_rules-1.0.0.tar.gz",
)

load("@bazelci_rules//:rbe_repo.bzl", "rbe_preconfig")

# Creates a default toolchain config for RBE.
# Use this as is if you are using the rbe_ubuntu16_04 container,
# otherwise refer to RBE docs.
rbe_preconfig(
name = "buildkite_config",
toolchain = "ubuntu1804-bazel-java11",
)
18 changes: 15 additions & 3 deletions examples/third_party/gn/gn_repositories.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,21 @@ def gn_repositories():
name = "gn",
build_file = Label("//gn:BUILD.gn.bazel"),
commit = "dfcbc6fed0a8352696f92d67ccad54048ad182b3",
patch_args = [],
patch_tool = "bash",
patches = [Label("//gn:patch.gen_ninja.sh")],
patch_cmds = [
"python3 build/gen.py --no-last-commit-position",
"cat > out/last_commit_position.h <<EOF\n" +
"// This file is generated by the build system. Do not edit.\n" +
"\n" +
"#ifndef OUT_LAST_COMMIT_POSITION_H_\n" +
"#define OUT_LAST_COMMIT_POSITION_H_\n" +
"\n" +
"#define LAST_COMMIT_POSITION_NUM 1891\n" +
"#define LAST_COMMIT_POSITION \"1891 (dfcbc6fe)\"\n" +
"\n" +
"#endif // OUT_LAST_COMMIT_POSITION_H_\n" +
"\n" +
"EOF",
],
remote = "https://gn.googlesource.com/gn",
shallow_since = "1612864120 +0000",
)
Loading

0 comments on commit 654fcd4

Please sign in to comment.