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

Fix edge cases in lockfile handling #24754

Closed
wants to merge 4 commits into from

Conversation

fmeum
Copy link
Collaborator

@fmeum fmeum commented Dec 19, 2024

  • Don't run the core logic when --lockfile_mode is off or error but the command doesn't forward options to Skyframe.
  • Honor reproducible per extension eval factor, not per extension.
  • Fix encoding conflict between isolation key and use_repo_rule's fake extension names

This doesn't require a lockfile version bump as use_repo_rule's fake extension (so far) isn't included in the lockfile.

Work towards #24723

* Don't run the core logic when `--lockfile_mode` is `off` or `error` but the command doesn't forward options to Skyframe.
* Honor `reproducible` per extension eval factor, not per extension.
@github-actions github-actions bot added team-ExternalDeps External dependency handling, remote repositiories, WORKSPACE file. awaiting-review PR is awaiting review from an assigned reviewer labels Dec 19, 2024
@fmeum
Copy link
Collaborator Author

fmeum commented Dec 19, 2024

@bazel-io fork 8.0.1

@fmeum
Copy link
Collaborator Author

fmeum commented Dec 19, 2024

@bazel-io fork 7.5.0

@fmeum fmeum changed the title Fix edge cases in BazelLockFileModule Fix edge cases in lockfile handling Dec 19, 2024
@fmeum fmeum force-pushed the 24723-preparations branch from 0bd9c35 to 97bcb7a Compare December 19, 2024 12:18
@fmeum fmeum force-pushed the 24723-preparations branch from 97bcb7a to 9c03c55 Compare December 19, 2024 13:53
@fmeum
Copy link
Collaborator Author

fmeum commented Dec 19, 2024

@meteorcloudy Tests are passing now.

@@ -80,7 +80,7 @@ public static ModuleExtensionId create(
}

public boolean isInnate() {
return extensionName().contains("%");
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why do we need this change?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is for the third point in the description: module extension IDs with an isolation key and those for repo rules would conflict after serialization into a string (for the lockfile), which results in a crash when parsing them back.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this seems dangerous to me. Changing the separator to + here would mean that (IIUC) we can't have it in the .bzl file label, so essentially using any repo rule from a non-main repo would fail (because that would result in an extension name like @@foo++foo_ext+foo_repo//:bar.bzl+my_repo_rule). In fact I'm surprised all tests passed -- maybe we never use_repo_rule from non-main repos in our tests?

(and yes, I understand that this also means % was never allowed to show up in the .bzl file label, but this was also true of aspects etc.)

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm, why exactly would this fail? The synthetic extension name as passed in by module file evaluation is "prettified" to just _repo_rules for the purpose of generating the extension unique prefix: https://cs.opensource.google/bazel/bazel/+/master:src/main/java/com/google/devtools/build/lib/bazel/bzlmod/BazelDepGraphFunction.java;l=186?q=_repo_rules&ss=bazel%2Fbazel&start=41.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, the repos generated by an innate extension have the form of module+_repo_rulesN+repo_name. But the name of the extension corresponding to the repo name prefix module+_repo_rulesN is currently <bzl_file_label>%<rule_name> (code). This PR is changing that line to split on +, which should result in errors.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm now using a space instead of a plus and am also only splitting on the last occurrence of the separator.

I don't think this was an issue in practice though as the bzl file label is the one specified in a module file and thus uses apparent rather than canonical repo names (I don't think we ever intentionally supported the latter and even prohibited them at some point).

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ah, I see! That's indeed why everything was actually okay.

Yeah, as long as the separator is not a valid Starlark identifier character and we split by the last occurrence only, we should be all good in all cases. This LGTM now, thanks!

Copy link
Member

@meteorcloudy meteorcloudy left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks!

@meteorcloudy meteorcloudy added awaiting-PR-merge PR has been approved by a reviewer and is ready to be merge internally and removed awaiting-review PR is awaiting review from an assigned reviewer labels Dec 19, 2024
@copybara-service copybara-service bot closed this in cfda178 Jan 6, 2025
@github-actions github-actions bot removed the awaiting-PR-merge PR has been approved by a reviewer and is ready to be merge internally label Jan 6, 2025
@fmeum fmeum deleted the 24723-preparations branch January 7, 2025 08:11
fmeum added a commit to fmeum/bazel that referenced this pull request Jan 7, 2025
* Don't run the core logic when `--lockfile_mode` is `off` or `error` but the command doesn't forward options to Skyframe.
* Honor `reproducible` per extension eval factor, not per extension.
* Fix encoding conflict between isolation key and `use_repo_rule`'s fake extension names

This doesn't require a lockfile version bump as `use_repo_rule`'s fake extension (so far) isn't included in the lockfile.

Work towards bazelbuild#24723

Closes bazelbuild#24754.

PiperOrigin-RevId: 712623562
Change-Id: I61fd439539031a01ddec4488276ff2d0484849f2
(cherry picked from commit cfda178)
fmeum pushed a commit to fmeum/bazel that referenced this pull request Jan 7, 2025
Currently `ModuleExtensionId#toString()` uses the default Java record repr, which isn't very user-friendly. There's really no reason not to use the `asTargetString()` method instead. This PR just renames `asTargetString()` to `toString()` and updates all call sites.

Closes bazelbuild#24450.

PiperOrigin-RevId: 700050362
Change-Id: I82238d2134e1642694f0b20235fcfe9307ceaa7d
(cherry picked from commit d23421a)

Fix edge cases in lockfile handling

* Don't run the core logic when `--lockfile_mode` is `off` or `error` but the command doesn't forward options to Skyframe.
* Honor `reproducible` per extension eval factor, not per extension.
* Fix encoding conflict between isolation key and `use_repo_rule`'s fake extension names

This doesn't require a lockfile version bump as `use_repo_rule`'s fake extension (so far) isn't included in the lockfile.

Work towards bazelbuild#24723

Closes bazelbuild#24754.

PiperOrigin-RevId: 712623562
Change-Id: I61fd439539031a01ddec4488276ff2d0484849f2
(cherry picked from commit cfda178)
meteorcloudy pushed a commit that referenced this pull request Jan 8, 2025
… lockfile handling (#24845)

### Streamline `ModuleExtensionId#toString()`

Currently `ModuleExtensionId#toString()` uses the default Java record
repr, which isn't very user-friendly. There's really no reason not to
use the `asTargetString()` method instead. This PR just renames
`asTargetString()` to `toString()` and updates all call sites.

Closes #24450.

PiperOrigin-RevId: 700050362
Change-Id: I82238d2134e1642694f0b20235fcfe9307ceaa7d 
(cherry picked from commit d23421a)

### Fix edge cases in lockfile handling

* Don't run the core logic when `--lockfile_mode` is `off` or `error`
but the command doesn't forward options to Skyframe.
* Honor `reproducible` per extension eval factor, not per extension.
* Fix encoding conflict between isolation key and `use_repo_rule`'s fake
extension names

This doesn't require a lockfile version bump as `use_repo_rule`'s fake
extension (so far) isn't included in the lockfile.

Work towards #24723

Closes #24754.

PiperOrigin-RevId: 712623562
Change-Id: I61fd439539031a01ddec4488276ff2d0484849f2 
(cherry picked from commit cfda178)

Fixes #24754

Co-authored-by: Xdng Yng <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
team-ExternalDeps External dependency handling, remote repositiories, WORKSPACE file.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants