Bug: 237403158

Clone this repo:
  1. e24e8ba [automerger skipped] Empty merge of Android 24Q2 Release (ab/11526283) to aosp-main-future am: 129f2136e3 -s ours by Xin Li · 9 months ago android15-automotiveos-dev android15-qpr1-release android15-qpr1-s3-release android15-qpr1-s4-release android15-qpr1-s5-release android15-tests-dev main master android-15.0.0_r10 android-15.0.0_r11 android-15.0.0_r12 android-15.0.0_r13 android-15.0.0_r6 android-15.0.0_r7 android-15.0.0_r8 android-15.0.0_r9
  2. 129f213 Empty merge of Android 24Q2 Release (ab/11526283) to aosp-main-future by Xin Li · 9 months ago
  3. 4274fbd Update bazel android tools to 0.31.0 am: dc84f05a70 am: bd1843d3dd by Colin Cross · 11 months ago
  4. bd1843d Update bazel android tools to 0.31.0 am: dc84f05a70 by Colin Cross · 11 months ago
  5. dc84f05 Update bazel android tools to 0.31.0 by Colin Cross · 11 months ago

Updating the Bazel prebuilts in AOSP

Instructions

First, decide which version of Bazel you need.

  • A Bazel release (e.g. Bazel 3.7.0)
  • A Bazel nightly
  • A Bazel per-commit build

Whichever of these you use, you will need to use official nojdk x86-64 versions of Bazel, for Linux and macOS (Darwin).

Run the release_bazel.py script in the root repository to download and verify the binaries from the trusted Bazel CI pipeline:

python /prebuilts/bazel/common/release_bazel.py --commit <commit>

To get the commit hash for builds, see the [Bazel releases], [Bazel nightlies] or [Bazel per-commit builds] sections below.

this will run update.sh which will also:

  • Download the remote_java_tools prebuilts corresponding to the downloaded Bazel binary
  • verify that the downloaded binary has the correct SHA-256 checksum as provided from Bazel CI metadata.

Once you have the binaries, you will need to create and send up to three CLs, to update the Linux, macOS, and platform-agnostic prebuilts that live in separate Git repositories, i.e.

The update script does not automatically create CLs, so you need to create them manually. In each CL description, mention the testing you did, which should at least include:

  • For release builds only: Verifying the file signature, e.g.
  • Verifying that Bazel starts, on Linux and on macOS, e.g.
    • source build/envsetup.sh
    • bazel info

Ensure that the CLs are set to the same Gerrit topic so they are submitted together.

Obtaining Bazel binaries

The update.sh script automates downloading Bazel binaries. The next sections describe how the different Bazel binaries (release, nightly, per-commit) can be manually downloaded from the Bazel CI.

Bazel releases

The commit hash for linux and darwin nojdk x86-64 binaries are available from https://github.com/bazelbuild/bazel/releases

Bazel nightlies

The commit hash and urls for linux and macOS nojdk x86-64 binaries are available in https://storage.googleapis.com/bazel-builds/metadata/latest.json

Bazel per-commit builds

You need to know the GitHub commit that contains your change, e.g. https://github.com/bazelbuild/bazel/commit/364a867df255c57c8edc4a8aae8f78cb54900a54

And the linux and macOS nojdk x86-64 binaries are available from: