Add useDummyBuiltinsBzl() to ConfiguredRuleClassProvider's builder

Thie method opts into using a minimalist builtins bzl environment containing no injected symbols. It is only intended for tests that don't use (directly or indirectly) any rules that could conceivably depend on builtins injection, e.g. tests of pure package loading machinery.

Other changes:
- Renamed getBuiltinsBzlRoot -> getBundledBuiltinsRoot, to distinguish it from non-bundled builtins roots (where the builtins root is overridden on the command line).
- The type of this value was changed from Path to Root since that's what we usually want.
- Added a getFileSystem() method to Root to avoid having to go through asPath(), which theoretically could be null.
- Friendlier error message when --experimental_builtins_bzl_path=%workspace% is used on a rule class provider that's not set up for it.
- Avoid requesting the repository mapping in BzlLoadFunction for builtins bzls. They don't need it, and it can create issues with Google-internal Skyframe heuristics.

Work toward #11437.

PiperOrigin-RevId: 363179217
6 files changed
tree: 0326f2816a36f7945d9ced70c7dd0a9528da71f8
  1. .bazelci/
  2. examples/
  3. scripts/
  4. site/
  5. src/
  6. third_party/
  7. tools/
  8. .bazelrc
  9. .gitattributes
  10. .gitignore
  11. AUTHORS
  12. BUILD
  13. CHANGELOG.md
  14. CODEBASE.md
  15. CODEOWNERS
  16. combine_distfiles.py
  17. combine_distfiles_to_tar.sh
  18. compile.sh
  19. CONTRIBUTING.md
  20. CONTRIBUTORS
  21. distdir.bzl
  22. distdir_deps.bzl
  23. ISSUE_TEMPLATE.md
  24. LICENSE
  25. README.md
  26. WORKSPACE
README.md

Bazel

{Fast, Correct} - Choose two

Build and test software of any size, quickly and reliably.

  • Speed up your builds and tests: Bazel rebuilds only what is necessary. With advanced local and distributed caching, optimized dependency analysis and parallel execution, you get fast and incremental builds.

  • One tool, multiple languages: Build and test Java, C++, Android, iOS, Go, and a wide variety of other language platforms. Bazel runs on Windows, macOS, and Linux.

  • Scalable: Bazel helps you scale your organization, codebase, and continuous integration solution. It handles codebases of any size, in multiple repositories or a huge monorepo.

  • Extensible to your needs: Easily add support for new languages and platforms with Bazel's familiar extension language. Share and re-use language rules written by the growing Bazel community.

Getting Started

Documentation

Contributing to Bazel

See CONTRIBUTING.md

Build status