Project: /_project.yaml Book: /_book.yaml
Guide for Bazel Maintainers
{% include “_buttons.html” %}
This is a guide for the maintainers of the Bazel open source project.
If you are looking to contribute to Bazel, please read Contributing to Bazel instead.
The objectives of this page are to:
- Serve as the maintainers' source of truth for the project’s contribution process.
- Set expectations between the community contributors and the project maintainers.
Bazel's core group of contributors has dedicated subteams to manage aspects of the open source project. These are:
- Release Process: Manage Bazel's release process.
- Green Team: Grow a healthy ecosystem of rules and tools.
- Developer Experience Gardeners: Encourage external contributions, review issues and pull requests, and make our development workflow more open.
Releases {:#releases}
Continuous Integration {:#integration}
Read the Green team‘s guide to Bazel’s CI infrastructure on the bazelbuild/continuous-integration{: .external} repository.
Lifecycle of an Issue {:#lifecycle-issue}
- A user creates an issue by choosing one of the issue templates{: .external} and it enters the pool of unreviewed open issues{: .external}.
- A member on the Developer Experience (DevEx) subteam rotation reviews the issue.- If the issue is not a bug or a feature request, the DevEx member will usually close the issue and redirect the user to StackOverflow{: .external} and bazel-discuss{: .external} for higher visibility on the question.
- If the issue belongs in one of the rules repositories owned by the community, like rules_apple{: .external}, the DevEx member will transfer this issue{: .external} to the correct repository.
- If the issue is vague or has missing information, the DevEx member will assign the issue back to the user to request for more information before continuing. This usually occurs when the user does not choose the right issue template {: .external} or provides incomplete information.
 
- After reviewing the issue, the DevEx member decides if the issue requires immediate attention. If it does, they will assign the P0 priority label and an owner from the list of team leads.
- The DevEx member assigns the untriagedlabel and exactly one team label for routing.
- The DevEx member also assigns exactly one type:label, such astype: bugortype: feature request, according to the type of the issue.
- For platform-specific issues, the DevEx member assigns one platform:label, such asplatform:applefor Mac-specific issues.
- If the issue is low priority and can be worked on by a new community contributor, the DevEx member assigns the good first issuelabel. At this stage, the issue enters the pool of untriaged open issues.
Each Bazel subteam will triage all issues under labels they own, preferably on a weekly basis. The subteam will review and evaluate the issue and provide a resolution, if possible. If you are an owner of a team label, see this section  for more information.
When an issue is resolved, it can be closed.
Lifecycle of a Pull Request {:#lifecycle-pull-request}
- A user creates a pull request.
- If you a member of a Bazel team and sending a PR against your own area, you are responsible for assigning your team label and finding the best reviewer.
- Otherwise, during daily triage, a DevEx member assigns one team label and the team's technical lead (TL) for routing.- The TL may optionally assign someone else to review the PR.
 
- The assigned reviewer reviews the PR and works with the author until it is approved or dropped.
- If approved, the reviewer imports the PR‘s commit(s) into Google’s internal version control system for further tests. As Bazel is the same build system used internally at Google, we need to test all PR commits against the internal test suite. This is the reason why we do not merge PRs directly.
- If the imported commit passes all internal tests, the commit will be squashed and exported back out to GitHub.
- When the commit merges into master, GitHub automatically closes the PR.
My team owns a label. What should I do? {:#label-own}
Subteams need to triage all issues in the labels they own, preferably on a weekly basis.
Issues {:#issues}
- Filter the list of issues by your team label and the untriagedlabel.
- Review the issue.
- Identify a priority level and assign the label.
- The issue may have already been prioritized by the DevEx subteam if it's a P0. Re-prioritize if needed.
- Each issue needs to have exactly one priority label. If an issue is either P0 or P1 we assume that is actively worked on.
- Remove the untriagedlabel.
Note that you need to be in the bazelbuild organization{: .external} to be able to add or remove labels.
Pull Requests {:#pull-requests}
- Filter the list of pull requests by your team label.
- Review open pull requests.
- Optional: If you are assigned for the review but is not the right fit for it, re-assign the appropriate reviewer to perform a code review.
- Work with the pull request creator to complete a code review.
- Approve the PR.
- Ensure that all tests pass.
- Import the patch to the internal version control system and run the internal presubmits.
- Submit the internal patch. If the patch submits and exports successfully, the PR will be closed automatically by GitHub.
Priority {:#priority}
The following definitions for priority will be used by the maintainers to triage issues.
- P0{: .external} - Major broken functionality that causes a Bazel release (minus release candidates) to be unusable, or a downed service that severely impacts development of the Bazel project. This includes regressions introduced in a new release that blocks a significant number of users, or an incompatible breaking change that was not compliant to the Breaking Change{: .external} policy. No practical workaround exists.
- P1{: .external} - Critical defect or feature which should be addressed in the next release, or a serious issue that impacts many users (including the development of the Bazel project), but a practical workaround exists. Typically does not require immediate action. In high demand and planned in the current quarter's roadmap.
- P2{: .external} - Defect or feature that should be addressed but we don't currently work on. Moderate live issue in a released Bazel version that is inconvenient for a user that needs to be addressed in an future release and/or an easy workaround exists.
- P3{: .external} - Desirable minor bug fix or enhancement with small impact. Not prioritized into Bazel roadmaps or any imminent release, however community contributions are encouraged.
- P4{: .external} - Low priority defect or feature request that is unlikely to get closed. Can also be kept open for a potential re-prioritization if more users are impacted.
Team labels {:#team-labels}
- team-Android{: .external}: Issues for Android team
- team-Bazel{: .external}: General Bazel product/strategy issues
- team-CLI{: .external}: Console UI
- team-Configurability{: .external}: Issues for Configurability team. Includes: Core build configuration and transition system. Does not include: Changes to new or existing flags
- team-Core{: .external}: Skyframe, bazel query, BEP, options parsing, bazelrc
- team-Documentation{: .external}: Issues for Documentation team
- team-ExternalDeps{: .external}: External dependency handling, Bzlmod, remote repositories, WORKSPACE file
- team-Loading-API{: .external}: BUILD file and macro processing: labels, package(), visibility, glob
- team-Local-Exec{: .external}: Issues for Execution (Local) team
- team-OSS{: .external}: Issues for Bazel OSS team: installation, release process, Bazel packaging, website, docs infrastructure
- team-Performance{: .external}: Issues for Bazel Performance team
- team-Remote-Exec{: .external}: Issues for Execution (Remote) team
- team-Rules-API{: .external}: API for writing rules/aspects: providers, runfiles, actions, artifacts
- team-Rules-CPP{: .external} /- team-Rules-ObjC{: .external}: Issues for C++/Objective-C rules, including native Apple rule logic
- team-Rules-Java{: .external}: Issues for Java rules
- team-Rules-Python{: .external}: Issues for the native Python rules
- team-Rules-Server{: .external}: Issues for server-side rules included with Bazel
- team-Starlark-Integration{: .external}: Non-API Bazel + Starlark integration. Includes: how Bazel triggers the Starlark interpreter, Stardoc, builtins injection, character encoding.  Does not include: BUILD or .bzl language issues.
- team-Starlark-Interpreter{: .external}: Issues for the Starlark interpreter (anything in java.net.starlark). BUILD and .bzl API issues (which represent Bazel's integration with Starlark) go in- team-Build-Language.
For new issues, we deprecated the category: * labels in favor of the team labels.
See the full list of labels here{: .external}.