Backport 1/1 commits from #143169.
Release justification: Non-production code changes
This code previously assumed that go mod download -json
would not produce two different versions of the same dependency with the same path. This is typically a sensible assumption but no longer holds in some niche scenarios. We use replace in go.mod
to effectively import two different versions of the same dependency with the same path. This results in non-determinism in the mirroring code with respect to which version of the dependency we select.
We now disambiguate with a path/version pair, which will be unique. We also add some additional validation to check assumptions so if these assumptions are ever broken in the future, the tool will fail loudly instead of proceeding silently and performing a potentially harmful operation.
Fixes #143168
Epic: CRDB-17171
Release note: None
2 files2 files | ⊥ | r1 | ||
---|---|---|---|---|
Commits | ⊥ | r1 | ||
pkg/cmd/mirror/go/pkg/cmd/mirror/go/ | ||||
mirror.go | ⊥ | r1 |
+21 | |
---|---|
+21 | |
Bazel Extended CI (Cockroach) — TeamCity build failed 1 week ago
Next diffs to review (file selection:
Show other diffs: All changes Unreviewed by…
Commits | ⊥ | r1 |
…pkg/cmd/mirror/go/mirror.go | ⊥ | r1 |
Service Under Maintenance
(Reported by GitHub just now. See the status page for details.)
Thanks for opening a backport.
Please check the backport criteria before merging:
issues or test-only changes.
here).
policy.
If your backport adds new functionality, please ensure that the following additional criteria are satisfied:
channel (#db-backports-point-releases or #db-backports-XX-X-release) for awareness and discussion.
Also, please add a brief release justification to the body of your PR to justify this
backport.
It looks like your PR touches production code but doesn't add or edit any test code. Did you consider adding tests to your PR?
🦉 Hoot! I am a Blathers, a bot for CockroachDB. My owner is dev-inf.