Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Consider skipping bazel_tools@_ from lockfile #19971

Open
layus opened this issue Oct 29, 2023 · 6 comments
Open

Consider skipping bazel_tools@_ from lockfile #19971

layus opened this issue Oct 29, 2023 · 6 comments
Labels
more data needed stale Issues or PRs that are stale (no activity for 30 days) team-ExternalDeps External dependency handling, remote repositiories, WORKSPACE file. type: bug

Comments

@layus
Copy link
Contributor

layus commented Oct 29, 2023

Description of the bug:

MODULE.bazel.lock files contain entries for bazel_tools builtin module, as well as all its dependencies. Because that module is builtin, its version changes with bazel releases, meaning that the lockfile gets invalidated when built with a different bazel version. Meaning that the bazel version is an integral part of the build dependencies.

It makes sense to keep bazel_tools and its dependencies in the lockfile if they take part of the modules version resolution. But maybe it would be better to keep them out of the modules version selection.

Overall, the question is maybe about compatibility between bazel versions. Are projects supposed to build only with a single bazel version as .bazelversion suggests ? In my context, being able to build a bazel project with different bazel versions makes things simpler.

Is there an official policy about bazel versions compatibility ?

Which category does this issue belong to?

Core, Documentation

What's the simplest, easiest way to reproduce this bug? Please provide a minimal example if possible.

No response

Which operating system are you running Bazel on?

NixOS

What is the output of bazel info release?

7.0.0rc2

If bazel info release returns development version or (@non-git), tell us how you built Bazel.

NixOS/nixpkgs#262152

What's the output of git remote get-url origin; git rev-parse master; git rev-parse HEAD ?

No response

Is this a regression? If yes, please try to identify the Bazel commit where the bug was introduced.

No response

Have you found anything relevant by searching the web?

No response

Any other information, logs, or outputs that you want to share?

No response

@fmeum
Copy link
Collaborator

fmeum commented Nov 7, 2023

@Pavank1992 Could you reassign to team External-Deps?

@sgowroji sgowroji added team-ExternalDeps External dependency handling, remote repositiories, WORKSPACE file. and removed team-Core Skyframe, bazel query, BEP, options parsing, bazelrc labels Nov 7, 2023
@meteorcloudy
Copy link
Member

meteorcloudy commented Nov 7, 2023

Meaning that the bazel version is an integral part of the build dependencies.

This is true and exactly the reason why those builtin dependencies have to be recorded in the lockfile to ensure correctness. If you change Bazel version without making sure those builtin dependencies are in sync, it may produce unexpected build failures.

But I don't think this will break compatibilities for building with different Bazel versions, it just means the lockfile could be updated if you change the bazel version (unless if you enable --lockfile_mode=error).

As the starlarkification of native build rules progresses, we should be able to reduce the dependencies required by the @bazel_tools builtin modules. And hopefully one day, we won't need the builtin module at all.

For keeping Bazel compatibilities:

@meteorcloudy
Copy link
Member

Do you actually need to switch Bazel versions frequently? If so, we would like to understand why.

@layus
Copy link
Contributor Author

layus commented Nov 7, 2023

When packaging bazel for nix, it is right now quite complex, and nix does not provide all the released bazel versions.
At a given point in time (or rater, in git history), there is only one bazel package for each major release. More generally, nix has such a packaging model that most packages should be able to rebuild when their dependencies are updated. Bazel assumes the same for module versions.

In most cases, building with a different, or at least close bazel release works though. And that is what nixpkgs (the main source of package definitions for nix) does. Bazel dependency is pinned on the major version (like bazel_5).

A pain point in nix packaging of bazel-built applications is to provide external dependencies in a sandboxed build. This was done by running some python scripts in a separate package to extract all the http files that bazel needs, and providing a pre-populated outputBase. Now, with MODULE.bazel.lock, it is easy to load the JSON file and extract all the dependencies in nix langauge itself (Like when you can do something directly in starlark instead of having to use an external repo for it).
Sadly, I have discovered that this method does not work when I build with a bazel version different from the one used to compute the lockfile. bazel_tools dependencies required are not the ones locked by the lockfile, and are thus missing.

My next idea is to have two sources of external packages, the ones derived from the lockfile, and the ones derived from the bazel install. By merging these sources in a --repository_cache structure, I get all the external dependencies required to build a given project with my any nix-provided bazel.

At this stage, I realized there was redundancy in the lockfile and .bazelversion. The lockfile does not contain the bazelversion, but the version impacts the content of the lockfile. The lockfile does not specify all the needed information for offline builds (because it does not say anything about the bazel version).

I have not implemented the double source of external dependencies described here, because I was not sure it would work. It relies on the property that dependency resolution between two sets of constraints (MODULE.bazel and bazel_tools from bazel binary) will always result in versions that come from either one or the other. I think it is true, but it needs to be extensively checked.

To be honnest, at that time I was struggling with the newly added id- files, and lost interest in packaging anything else than bazel_7.0.0 itself.

See also NixOS/nixpkgs#262152 for the related work.

@meteorcloudy
Copy link
Member

Oh, that is interesting. We kind of have to solve similar problems for running integration tests on Bazel CI. We want to make sure we can run Bazel integration tests without internet access, therefore we need to provide a pre-populated repository cache for the inner Bazel inside the test by building the //src:test_repos in advance in the build step.

You might also be interested in #20042

Some links:

  • - "//src:test_repos"
  • bazel/.bazelrc

    Lines 71 to 73 in f898da5

    build:ci-linux --repository_cache=/var/lib/buildkite-agent/bazeltest/repo_cache
    test:ci-linux --test_env=TEST_INSTALL_BASE=/var/lib/buildkite-agent/bazeltest/install_base
    test:ci-linux --test_env=REPOSITORY_CACHE=/var/lib/buildkite-agent/bazeltest/repo_cache
  • if [[ -n ${REPOSITORY_CACHE:-} ]]; then
    echo "testenv.sh: Using repository cache at $REPOSITORY_CACHE."
    echo "common --repository_cache=$REPOSITORY_CACHE" >> $TEST_TMPDIR/bazelrc
    if is_darwin; then

Copy link

Thank you for contributing to the Bazel repository! This issue has been marked as stale since it has not had any activity in the last 1+ years. It will be closed in the next 90 days unless any other activity occurs. If you think this issue is still relevant and should stay open, please post any comment here and the issue will no longer be marked as stale.

@github-actions github-actions bot added the stale Issues or PRs that are stale (no activity for 30 days) label Jan 11, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
more data needed stale Issues or PRs that are stale (no activity for 30 days) team-ExternalDeps External dependency handling, remote repositiories, WORKSPACE file. type: bug
Projects
None yet
Development

No branches or pull requests

7 participants