Convert Figma logo to code with AI

bazelbuild logobazelisk

A user-friendly launcher for Bazel.

2,104
322
2,104
101

Top Related Projects

123,517

The Go programming language

165,325

Visual Studio Code

99,547

Empowering everyone to build reliable and efficient software.

8,560

A fast build system that encourages the creation of small, reusable modules over a variety of platforms and languages.

3,294

The Pants Build System

16,773

Adaptable, fast automation for all

Quick Overview

Bazelisk is a user-friendly launcher for Bazel, the open-source build and test tool. It automatically downloads and runs the correct version of Bazel for your project, simplifying version management and ensuring consistency across different environments.

Pros

  • Automatic version management: Bazelisk detects and uses the appropriate Bazel version for each project
  • Cross-platform compatibility: Works on Windows, macOS, and Linux
  • Easy installation and setup: Can be installed via various package managers or as a standalone binary
  • Supports multiple version specification methods: .bazelversion file, USE_BAZEL_VERSION environment variable, or command-line flags

Cons

  • Adds an extra layer of complexity to the build process
  • May introduce a slight overhead in build time due to version checking and potential downloads
  • Requires internet access for initial setup and version downloads
  • Limited customization options compared to managing Bazel versions manually

Getting Started

  1. Install Bazelisk:

    # macOS (Homebrew)
    brew install bazelisk
    
    # Linux/macOS (npm)
    npm install -g @bazel/bazelisk
    
    # Windows (Chocolatey)
    choco install bazelisk
    
  2. Use Bazelisk as a drop-in replacement for Bazel:

    bazelisk build //my:target
    
  3. Specify a Bazel version for your project (optional): Create a .bazelversion file in your project root with the desired Bazel version:

    echo "5.3.0" > .bazelversion
    

Bazelisk will now automatically use the specified Bazel version for this project.

Competitor Comparisons

123,517

The Go programming language

Pros of Go

  • Comprehensive standard library and ecosystem for general-purpose programming
  • Faster compilation and execution times for large-scale projects
  • Extensive documentation and community support

Cons of Go

  • Steeper learning curve for beginners compared to Bazelisk
  • Larger codebase and more complex project structure
  • Not specifically designed for build tool version management

Code Comparison

Go:

package main

import "fmt"

func main() {
    fmt.Println("Hello, World!")
}

Bazelisk:

import subprocess

def run_bazel(args):
    subprocess.run(["bazel"] + args)

run_bazel(["build", "//..."])

Summary

Go is a general-purpose programming language with a rich ecosystem, while Bazelisk is a specialized tool for managing Bazel versions. Go offers more flexibility and performance for large-scale projects, but Bazelisk provides a simpler solution for Bazel-specific tasks. The code comparison illustrates the difference in complexity and focus between the two projects.

165,325

Visual Studio Code

Pros of VS Code

  • Extensive feature set: VS Code is a full-fledged IDE with a wide range of built-in features and extensions
  • Large community and ecosystem: Vast number of extensions, themes, and active user base
  • Cross-platform support: Available on Windows, macOS, and Linux

Cons of VS Code

  • Resource-intensive: Can be heavy on system resources, especially with multiple extensions
  • Complexity: May have a steeper learning curve for new users due to its extensive features

Code Comparison

VS Code (settings.json):

{
  "editor.fontSize": 14,
  "editor.tabSize": 2,
  "files.autoSave": "afterDelay",
  "workbench.colorTheme": "Monokai"
}

Bazelisk (bazelisk.yml):

use_bazel_version: latest
bazel_binary: /path/to/bazel
bazel_version_fallback: 4.0.0

Summary

VS Code is a versatile, feature-rich IDE with broad language support and a vast ecosystem. Bazelisk, on the other hand, is a specialized tool for managing Bazel versions, offering a simpler, more focused functionality. While VS Code provides a comprehensive development environment, Bazelisk streamlines Bazel version management for build processes.

99,547

Empowering everyone to build reliable and efficient software.

Pros of Rust

  • Comprehensive programming language with a robust ecosystem
  • Strong focus on memory safety and concurrency
  • Large and active community with extensive documentation

Cons of Rust

  • Steeper learning curve compared to Bazelisk
  • Larger codebase and more complex project structure
  • Longer compilation times for large projects

Code Comparison

Rust example:

fn main() {
    println!("Hello, world!");
}

Bazelisk example:

func main() {
    fmt.Println("Hello, world!")
}

Summary

Rust is a full-fledged programming language with a focus on safety and performance, while Bazelisk is a version management tool for Bazel. Rust offers a more comprehensive development environment but requires more time to master. Bazelisk, being a specialized tool, is simpler to use but has a narrower scope.

Rust's ecosystem is vast, with numerous libraries and frameworks available. Bazelisk, on the other hand, serves a specific purpose within the Bazel build system ecosystem.

The code examples demonstrate the simplicity of both languages for basic tasks, but Rust's syntax emphasizes its focus on memory safety with features like the println! macro.

8,560

A fast build system that encourages the creation of small, reusable modules over a variety of platforms and languages.

Pros of Buck

  • More comprehensive build system with support for multiple languages and platforms
  • Offers advanced features like distributed caching and build artifact sharing
  • Provides a powerful query language for introspecting the build graph

Cons of Buck

  • Steeper learning curve due to its complexity and extensive feature set
  • Requires more setup and configuration compared to Bazelisk's simplicity
  • Less frequent updates and potentially slower community support

Code Comparison

Buck build file example:

android_binary(
    name = 'app',
    manifest = 'AndroidManifest.xml',
    keystore = ':debug_keystore',
    deps = [
        ':app-lib',
    ],
)

Bazelisk usage example:

bazelisk build //my:target
bazelisk test //tests:all
bazelisk run //cmd:tool

While Buck uses its own build file format with specific rules, Bazelisk is a version manager for Bazel and uses Bazel's BUILD files. The code comparison shows the difference in syntax and usage between the two systems.

3,294

The Pants Build System

Pros of Pants

  • More comprehensive build system with built-in support for multiple languages and tools
  • Offers fine-grained caching and incremental builds for faster execution
  • Provides a plugin system for easy extensibility

Cons of Pants

  • Steeper learning curve due to its more complex architecture
  • May be overkill for smaller projects or monorepos
  • Less widespread adoption compared to Bazel ecosystem

Code Comparison

Pants build file example:

python_sources(
    name="my_app",
    dependencies=[
        "3rdparty/python:requests",
    ],
)

Bazelisk (used with Bazel) BUILD file example:

py_binary(
    name = "my_app",
    srcs = ["main.py"],
    deps = ["@requests"],
)

Both examples define a Python target, but Pants uses a more concise syntax and automatically infers source files, while Bazel requires explicit source file declarations.

16,773

Adaptable, fast automation for all

Pros of Gradle

  • More mature and widely adopted build system with extensive plugin ecosystem
  • Supports multiple programming languages and platforms
  • Offers powerful dependency management and customization options

Cons of Gradle

  • Steeper learning curve, especially for complex builds
  • Can be slower for large projects compared to Bazel
  • Groovy-based DSL may be less familiar to some developers

Code Comparison

Gradle build script (build.gradle):

plugins {
    id 'java'
}

dependencies {
    implementation 'com.example:library:1.0.0'
}

Bazel BUILD file:

java_library(
    name = "my_lib",
    srcs = glob(["src/main/java/**/*.java"]),
    deps = ["@maven//:com_example_library"],
)

Both Gradle and Bazelisk serve different purposes in the build ecosystem. Gradle is a full-featured build automation system, while Bazelisk is a version management tool for Bazel. Gradle offers more flexibility and language support, but Bazel (used with Bazelisk) provides better scalability for large monorepos and faster incremental builds. The choice between them depends on project requirements, team expertise, and specific use cases.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

Bazelisk

A user-friendly launcher for Bazel.

About Bazelisk

Bazelisk is a wrapper for Bazel written in Go. It automatically picks a good version of Bazel given your current working directory, downloads it from the official server (if required) and then transparently passes through all command-line arguments to the real Bazel binary. You can call it just like you would call Bazel.

Installation

On macOS: brew install bazelisk.

On Windows: choco install bazelisk.

Each adds bazelisk to the PATH as both bazelisk and bazel.

On Linux: You can download Bazelisk binary on our Releases page and add it to your PATH manually, which also works on macOS and Windows.

Bazelisk is also published to npm. Frontend developers may want to install it with npm install -g @bazel/bazelisk.

You will notice that it serves an analogous function for Bazel as the nvm utility which manages your version of Node.js.

Some ideas how to use it:

  • Install it as the bazel binary in your PATH (e.g. copy it to /usr/local/bin/bazel). Never worry about upgrading Bazel to the latest version again.
  • Check it into your repository and recommend users to build your software via ./bazelisk build //my:software. That way, even someone who has never used Bazel or doesn't have it installed can build your software.
  • As a company using Bazel or as a project owner, add a .bazelversion file to your repository. This will tell Bazelisk to use the exact version specified in the file when running in your workspace. The fact that it's versioned inside your repository will then allow for atomic upgrades of Bazel including all necessary changes. If you install Bazelisk as bazel on your CI machines, too, you can even test Bazel upgrades via a normal presubmit / pull request. It will also ensure that users will not try to build your project with an incompatible version of Bazel, which is often a cause for frustration and failing builds. (But see the note below about ensuring your developers install Bazelisk.)

Before Bazelisk was rewritten in Go, it was a Python script. This still works and has the advantage that you can run it on any platform that has a Python interpreter, but is currently unmaintained and it doesn't support as many features. The documentation below describes the newer Go version only.

How does Bazelisk know which Bazel version to run?

It uses a simple algorithm:

  • If the environment variable USE_BAZEL_VERSION is set, it will use the version specified in the value.
  • Otherwise, if a .bazeliskrc file exists in the workspace root and contains the USE_BAZEL_VERSION variable, this version will be used.
  • Otherwise, if a .bazelversion file exists in the current directory or recursively any parent directory, it will read the file and use the version specified in it.
  • Otherwise, if the environment variable USE_BAZEL_FALLBACK_VERSION is set to one of the following formats:
    • If set to a value starting with error:, it will report an error and version detection will fail.
    • If set to a value starting with warn:, it will report a warning and use the version specified after the prefix.
    • If set to a value starting with silent:, it will use the version specified after the prefix.
  • Otherwise, it will use the official latest Bazel release.

A version can optionally be prefixed with a fork name. The fork and version should be separated by slash: <FORK>/<VERSION>. Please see the next section for how to work with forks.

Bazelisk currently understands the following formats for version labels:

  • latest means the latest stable (LTS) version of Bazel as released on GitHub. Previous releases can be specified via latest-1, latest-2 etc.
  • A version number like 0.17.2 means that exact version of Bazel. It can also be a release candidate version like 0.20.0rc3, or a rolling release version like 5.0.0-pre.20210317.1.
  • A floating version identifier like 4.x that returns the latest release from the LTS series started by Bazel 4.0.0.
  • A wildcard version identifier like 4.* that returns the latest release or candidate from the LTS series started by Bazel 4.0.0.
  • The hash of a Git commit. Please note that Bazel binaries are only available for commits that passed Bazel CI.

Additionally, a few special version names are supported for our official releases only (these formats do not work when using a fork):

  • last_green refers to the Bazel binary that was built at the most recent commit that passed Bazel CI. Ideally this binary should be very close to Bazel-at-head.
  • last_rc points to the most recent release candidate. If there is no active release candidate, Bazelisk uses the latest Bazel release instead.
  • rolling refers to the latest rolling release (even if there is a newer LTS release).

Note: last_downstream_green support has been removed, please use last_green instead.

Where does Bazelisk get Bazel from?

By default Bazelisk retrieves Bazel releases, release candidates and binaries built at green commits from Google Cloud Storage. The downloaded artifacts are validated against the SHA256 value recorded in BAZELISK_VERIFY_SHA256 if this variable is set in the configuration file.

As mentioned in the previous section, the <FORK>/<VERSION> version format allows you to use your own Bazel fork hosted on GitHub:

If you want to create a fork with your own releases, you should follow the naming conventions that we use in bazelbuild/bazel for the binary file names as this results in predictable URLs that are similar to the official ones. The URL format looks like https://github.com/<FORK>/bazel/releases/download/<VERSION>/<FILENAME>.

You can also override the URL by setting the environment variable $BAZELISK_BASE_URL. Bazelisk will then append /<VERSION>/<FILENAME> to the base URL instead of using the official release server. Bazelisk will read file ~/.netrc for credentials for Basic authentication.

If for any reason none of this works, you can also override the URL format altogether by setting the environment variable $BAZELISK_FORMAT_URL. This variable takes a format-like string with placeholders and performs the following replacements to compute the download URL:

  • %e: Extension suffix, such as the empty string or .exe.
  • %h: Value of BAZELISK_VERIFY_SHA256, respecting uppercase/lowercase characters.
  • %m: Machine architecture name, such as arm64 or x86_64.
  • %o: Operating system name, such as darwin or linux.
  • %v: Bazel version as determined by Bazelisk.
  • %%: Literal % for escaping purposes.
  • All other characters after % are reserved for future use and result in a processing error.

Environment variables set by Bazelisk

Bazelisk prepends a directory to PATH that contains the downloaded Bazel binary. This ensures that Bazel targets that invoke bazel will use the same Bazel binary as the outer invocation.

Bazelisk also sets the environment variable BAZELISK to its own path. This can be useful for scripts that want to know if they are running under Bazelisk and can also be used to run specific Bazel versions from within a Bazel run, e.g. to generate version-specific test data.

Ensuring that your developers use Bazelisk rather than Bazel

Bazel installers typically provide Bazel's shell wrapper script as the bazel on the PATH.

When installed this way, Bazel checks the .bazelversion file itself, but the failure when it mismatches with the actual version of Bazel can be quite confusing to developers. You may find yourself having to explain the difference between Bazel and Bazelisk (especially when you upgrade the pinned version). To avoid this, you can add a check in your tools/bazel wrapper. Since Bazelisk is careful to avoid calling itself in a loop, it always calls the wrapper with the environment variable BAZELISK_SKIP_WRAPPER set to `true'. You can check for the presence of that variable, and when not found, report a useful error to your users about how to install Bazelisk.

Note that if users directly downloaded a Bazel binary and put it in their PATH, rather than running an installer, then tools/bazel and .bazelversion are not checked. You could call the versions.check starlark module from the beginning of your WORKSPACE to require users update their bazel.

Other features

The Go version of Bazelisk offers three new flags.

--strict

--strict expands to the set of incompatible flags which may be enabled for the given version of Bazel.

bazelisk --strict build //...

--migrate

--migrate will run Bazel multiple times to help you identify compatibility issues. If the code fails with --strict, the flag --migrate will run Bazel with each one of the flag separately, and print a report at the end. This will show you which flags can safely enabled, and which flags require a migration.

--bisect

--bisect flag allows you to bisect Bazel versions to find which version introduced a build failure. You can specify the range of versions to bisect with --bisect=<GOOD>..<BAD>, where GOOD is the last known working Bazel version and BAD is the first known non-working Bazel version. Bazelisk uses GitHub's compare API to get the list of commits to bisect. When GOOD is not an ancestor of BAD, GOOD is reset to their merge base commit. The meaning of GOOD and BAD can be reversed by prefixing the range with ~, e.g. --bisect=~6.0.0..HEAD will find the first version 6.0.0 and HEAD that fixes the build.

Examples:

# Bisect between 6.0.0 and Bazel at HEAD to find the first commit that breaks the build.
bazelisk --bisect=6.0.0..HEAD test //foo:bar_test

# Bisect between 6.1.0 and the second release candidate of Bazel 6.2.0
bazelisk --bisect=6.1.0..release-6.2.0rc2 test //foo:bar_test

# Bisect between two commits on the main branch (or branches with `release-` prefix) of the Bazel GitHub repository.
bazelisk --bisect=<good commit hash>..<bad commit hash> test //foo:bar_test

# Bisect between 6.0.0 and Bazel at HEAD to find the first commit that *fixes* the build.
bazelisk --bisect=~6.0.0..HEAD test //foo:bar_test

Note that, Bazelisk uses prebuilt Bazel binaries at commits on the main and release branches, therefore you cannot bisect your local commits.

Useful environment variables for --migrate and --bisect

You can set BAZELISK_INCOMPATIBLE_FLAGS to set a list of incompatible flags (separated by ,) to be tested, otherwise Bazelisk tests all flags starting with --incompatible_.

You can set BAZELISK_GITHUB_TOKEN to set a GitHub access token to use for API requests to avoid rate limiting when on shared networks.

You can set BAZELISK_SHUTDOWN to run shutdown between builds when migrating or bisecting if you suspect this affects your results.

You can set BAZELISK_CLEAN to run clean --expunge between builds when migrating or bisecting if you suspect this affects your results.

tools/bazel

If tools/bazel exists in your workspace root and is executable, Bazelisk will run this file, instead of the Bazel version it downloaded. It will set the environment variable BAZEL_REAL to the path of the downloaded Bazel binary. This can be useful, if you have a wrapper script that e.g. ensures that environment variables are set to known good values. This behavior can be disabled by setting the environment variable BAZELISK_SKIP_WRAPPER to any value (except the empty string) before launching Bazelisk.

You can control the user agent that Bazelisk sends in all HTTP requests by setting BAZELISK_USER_AGENT to the desired value.

.bazeliskrc configuration file

A .bazeliskrc file in the root directory of a workspace or the user home directory allows users to set environment variables persistently. (The Python implementation of Bazelisk doesn't check the user home directory yet, only the workspace directory.)

Example file content:

USE_BAZEL_VERSION=0.19.0
BAZELISK_GITHUB_TOKEN=abc

The following variables can be set:

  • BAZELISK_BASE_URL
  • BAZELISK_FORMAT_URL
  • BAZELISK_NOJDK
  • BAZELISK_CLEAN
  • BAZELISK_GITHUB_TOKEN
  • BAZELISK_HOME_DARWIN
  • BAZELISK_HOME_LINUX
  • BAZELISK_HOME_WINDOWS
  • BAZELISK_HOME
  • BAZELISK_INCOMPATIBLE_FLAGS
  • BAZELISK_SHOW_PROGRESS
  • BAZELISK_SHUTDOWN
  • BAZELISK_SKIP_WRAPPER
  • BAZELISK_USER_AGENT
  • BAZELISK_VERIFY_SHA256
  • USE_BAZEL_VERSION

Configuration variables are evaluated with precedence order. The preferred values are derived in order from highest to lowest precedence as follows:

  • Variables defined in the environment
  • Variables defined in the workspace root .bazeliskrc
  • Variables defined in the user home .bazeliskrc

Additionally, the Bazelisk home directory is also evaluated in precedence order. The preferred value is OS-specific e.g. BAZELISK_HOME_LINUX, then we fall back to BAZELISK_HOME.

Requirements

For ease of use, the Python version of Bazelisk is written to work with Python 2.7 and 3.x and only uses modules provided by the standard library.

The Go version can be compiled to run natively on Linux, macOS and Windows.

To install it, run:

go install github.com/bazelbuild/bazelisk@latest

To add it to your PATH:

export PATH=$PATH:$(go env GOPATH)/bin

For more information, you may read about the GOPATH environment variable.

Ideas for the future

  • Add support for checked-in Bazel binaries.
  • When the version label is set to a commit hash, first download a matching binary version of Bazel, then build Bazel automatically at that commit and use the resulting binary.

FAQ

Where does Bazelisk store the downloaded versions of Bazel?

It creates a directory called "bazelisk" inside your user cache directory and will store them there. Feel free to delete this directory at any time, as it can be regenerated automatically when required.

NPM DownloadsLast 30 Days