Skip to content

Commit 2719daa

Browse files
committed
Support building android/ with Bazel (bzlmod only)
1 parent 2f12772 commit 2719daa

6 files changed

Lines changed: 102 additions & 4 deletions

File tree

.bazelrc

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1 +1,3 @@
11
build --cxxopt=-std=c++17 --host_cxxopt=-std=c++17
2+
3+
common:skip_android --deleted_packages=android

.github/workflows/testing.yml

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -100,10 +100,10 @@ jobs:
100100
key: ${{ runner.os }}-bazel-${{ env.USE_BAZEL_VERSION }}-${{ hashFiles('WORKSPACE', 'repositories.bzl') }}
101101

102102
- name: Run bazel build
103-
run: bazelisk build //... --enable_bzlmod=${{ matrix.bzlmod }} --enable_workspace=${{ !matrix.bzlmod }}
103+
run: bazelisk build //... --config=skip_android --enable_bzlmod=${{ matrix.bzlmod }} --enable_workspace=${{ !matrix.bzlmod }}
104104

105105
- name: Run bazel test
106-
run: bazelisk test //... --enable_bzlmod=${{ matrix.bzlmod }} --enable_workspace=${{ !matrix.bzlmod }}
106+
run: bazelisk test //... --config=skip_android --enable_bzlmod=${{ matrix.bzlmod }} --enable_workspace=${{ !matrix.bzlmod }}
107107

108108
- name: Run example bazel build
109109
run: bazelisk build //... --enable_bzlmod=${{ matrix.bzlmod }} --enable_workspace=${{ !matrix.bzlmod }}

COMPILING.md

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -163,4 +163,13 @@ to ensure you're always building using the latest supported version, then try:
163163
$ bazelisk build //...
164164
```
165165

166+
Some parts of grpc-java depend on Android. Bazel can build these parts too but,
167+
for size, licensing and maintenance reasons, it requires a locally installed
168+
Android SDK. If you don't have the SDK and/or don't care about Android, use the
169+
`skip_android` configuration to skip building the Android parts:
170+
171+
```sh
172+
$ bazelisk build //... --config=skip_android
173+
```
174+
166175
You cannot run the tests from Bazel at this time.

MODULE.bazel

Lines changed: 49 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -49,16 +49,31 @@ IO_GRPC_GRPC_JAVA_ARTIFACTS = [
4949
]
5050
# GRPC_DEPS_END
5151

52+
ANDROID_ARTIFACTS = [
53+
"androidx.annotation:annotation:1.6.0",
54+
"androidx.annotation:annotation-jvm:1.6.0",
55+
"androidx.core:core:1.13.1",
56+
"androidx.lifecycle:lifecycle-common:2.6.2",
57+
]
58+
5259
bazel_dep(name = "abseil-cpp", version = "20250512.1")
5360
bazel_dep(name = "bazel_jar_jar", version = "0.1.11.bcr.1")
5461
bazel_dep(name = "bazel_skylib", version = "1.7.1")
5562
bazel_dep(name = "googleapis", version = "0.0.0-20260514-1dbb1a14", repo_name = "com_google_googleapis")
5663
bazel_dep(name = "grpc-proto", version = "0.0.0-20240627-ec30f58.bcr.1", repo_name = "io_grpc_grpc_proto")
5764
bazel_dep(name = "protobuf", version = "33.4", repo_name = "com_google_protobuf")
65+
bazel_dep(name = "rules_android", version = "0.7.2")
5866
bazel_dep(name = "rules_cc", version = "0.0.9")
5967
bazel_dep(name = "rules_java", version = "9.1.0")
6068
bazel_dep(name = "rules_jvm_external", version = "6.0")
6169

70+
android_sdk_repository_extension = use_extension(
71+
"@rules_android//rules/android_sdk_repository:rule.bzl",
72+
"android_sdk_repository_extension",
73+
)
74+
use_repo(android_sdk_repository_extension, "androidsdk")
75+
register_toolchains("@androidsdk//:sdk-toolchain", "@androidsdk//:all")
76+
6277
maven = use_extension("@rules_jvm_external//:extensions.bzl", "maven")
6378
maven.install(
6479
artifacts = IO_GRPC_GRPC_JAVA_ARTIFACTS,
@@ -67,7 +82,36 @@ maven.install(
6782
],
6883
strict_visibility = True,
6984
)
70-
use_repo(maven, "maven")
85+
86+
# We isolate Android-specific deps in this separate repo ('grpc_android_maven') instead of the one
87+
# above (having default name 'maven').
88+
#
89+
# Under bzlmod, rules_jvm_external merges all contributions to the same named repository (like the
90+
# default 'maven' repo) across the entire dependency graph. If we put Android dependencies there,
91+
# then *every* downstream consumer's merged 'maven' repository would include these Android
92+
# artifacts.
93+
#
94+
# Because merged repositories are resolved using only the root module's (the consumer's)
95+
# repository list, any consumer without 'maven.google.com' configured in their root module
96+
# would fail to resolve these artifacts, breaking their build even if they don't use Android.
97+
#
98+
# By using a distinct name ('grpc_android_maven'), we prevent merging. This repository is resolved
99+
# independently, allowing it to use grpc-java's own repository config (which includes
100+
# maven.google.com) without affecting downstream consumers' default 'maven' repo.
101+
maven.install(
102+
name = "grpc_android_maven",
103+
artifacts = ANDROID_ARTIFACTS,
104+
repositories = [
105+
"https://repo.maven.apache.org/maven2/",
106+
"https://maven.google.com", # for androidx.*
107+
],
108+
strict_visibility = True,
109+
# Enable Starlark Android rules in rules_jvm_external for Bazel 8+ compatibility.
110+
use_starlark_android_rules = True,
111+
# Explicitly set the label for aar_import since the default guess is incorrect under Bzlmod.
112+
aar_import_bzl_label = "@rules_android//rules:rules.bzl",
113+
)
114+
use_repo(maven, "maven", "grpc_android_maven")
71115

72116
maven.override(
73117
coordinates = "com.google.protobuf:protobuf-java",
@@ -161,3 +205,7 @@ maven.override(
161205
coordinates = "io.grpc:grpc-util",
162206
target = "@io_grpc_grpc_java//util",
163207
)
208+
maven.override(
209+
coordinates = "io.grpc:grpc-binder",
210+
target = "@io_grpc_grpc_java//binder",
211+
)

android/BUILD.bazel

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
load("@rules_android//rules:rules.bzl", "android_library")
2+
load("@rules_jvm_external//:defs.bzl", "artifact")
3+
4+
licenses(["notice"])
5+
6+
android_library(
7+
name = "android",
8+
srcs = glob([
9+
"src/main/java/**/*.java",
10+
]),
11+
manifest = "src/main/AndroidManifest.xml",
12+
custom_package = "io.grpc.android",
13+
visibility = ["//visibility:public"],
14+
deps = [
15+
"//api",
16+
"//core:internal",
17+
artifact("com.google.code.findbugs:jsr305"),
18+
artifact("com.google.errorprone:error_prone_annotations"),
19+
artifact("com.google.guava:guava"),
20+
],
21+
)

buildscripts/kokoro/android.sh

Lines changed: 19 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -19,14 +19,32 @@ cat <<EOF >> gradle.properties
1919
org.gradle.jvmargs=-Xmx2048m -XX:MaxMetaspaceSize=1024m
2020
EOF
2121

22-
export ANDROID_HOME=/tmp/Android/Sdk
22+
export ANDROID_HOME=$HOME/Android/Sdk
2323
mkdir -p "${ANDROID_HOME}/cmdline-tools"
2424
curl -Ls -o cmdline.zip \
2525
"https://dl.google.com/android/repository/commandlinetools-linux-9477386_latest.zip"
2626
unzip -qd "${ANDROID_HOME}/cmdline-tools" cmdline.zip
2727
rm cmdline.zip
2828
mv "${ANDROID_HOME}/cmdline-tools/cmdline-tools" "${ANDROID_HOME}/cmdline-tools/latest"
2929
(yes || true) | "${ANDROID_HOME}/cmdline-tools/latest/bin/sdkmanager" --licenses
30+
31+
# Bazel/android_rules requires build-tools at least version 35.0.0 and, unlike
32+
# gradle, won't download anything for itself.
33+
# TODO(jdcormie): Keep this version in sync with AGP's default and any
34+
# `buildToolsVersion` config.
35+
"${ANDROID_HOME}/cmdline-tools/latest/bin/sdkmanager" --install "build-tools;35.0.1"
36+
37+
# Bazelisk takes care of installing the proper version(s) of Bazel.
38+
mkdir -p /tmp/bazelisk
39+
curl -Ls -o /tmp/bazelisk/bazelisk https://github.com/bazelbuild/bazelisk/releases/download/v1.19.0/bazelisk-linux-amd64
40+
chmod +x /tmp/bazelisk/bazelisk
41+
export PATH=/tmp/bazelisk:$PATH
42+
43+
# TODO(jdcormie): Use the same SDK version as build.gradle's compileSdkVersion.
44+
"${ANDROID_HOME}/cmdline-tools/latest/bin/sdkmanager" --install "platforms;android-34"
45+
bazelisk build \
46+
//android
47+
3048
curl -Ls https://github.com/Kitware/CMake/releases/download/v3.26.3/cmake-3.26.3-linux-x86_64.tar.gz | \
3149
tar xz -C /tmp
3250
export PATH=/tmp/cmake-3.26.3-linux-x86_64/bin:$PATH

0 commit comments

Comments
 (0)