Fix a bug that `--remote_download_toplevel` doesn't download unused_inputs_list

When enabling remote caching with flag `--remote_download_toplevel`, Bazel only [downloads output directory metadata, stdout and stderr as well as the contents of `inMemoryOutputPath` if specified](https://github.com/bazelbuild/bazel/blob/master/src/main/java/com/google/devtools/build/lib/remote/RemoteCache.java#L522). However, file specified by`unused_inputs_list` of [`ctx.actions.run`](https://docs.bazel.build/versions/master/skylark/lib/actions.html#run) isn't downloaded in this case but is [required](https://github.com/bazelbuild/bazel/blob/master/src/main/java/com/google/devtools/build/lib/analysis/actions/StarlarkAction.java#L195) after starlark action execution.

This PR specify `inMemoryOutputPath` to the `unused_inputs_list` file by inserting `ExecutionRequirements.REMOTE_EXECUTION_INLINE_OUTPUTS` to `SpawnAction`'s `executionInfo`.

Fixes #11732.

Closes #11763.

RELNOTES: None.
PiperOrigin-RevId: 325402908
6 files changed
tree: 0ff81dc50d110f2d46ab4ade8e2ee6239ccdbb8e
  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. CODEOWNERS
  15. combine_distfiles.py
  16. combine_distfiles_to_tar.sh
  17. compile.sh
  18. CONTRIBUTING.md
  19. CONTRIBUTORS
  20. distdir.bzl
  21. ISSUE_TEMPLATE.md
  22. LICENSE
  23. README.md
  24. 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