Add retry for git fetch failures in CARGO_NET_GIT_FETCH_WITH_CLI path#16016
Merged
weihanglo merged 1 commit intorust-lang:masterfrom Sep 30, 2025
Merged
Conversation
Collaborator
weihanglo
reviewed
Sep 28, 2025
32bfdb2 to
1596c35
Compare
1596c35 to
2abb59a
Compare
0xPoe
reviewed
Sep 28, 2025
Member
0xPoe
left a comment
There was a problem hiding this comment.
Thanks!
I guess it would be great if we could introduce a cargo test for it.
For example:
#[cargo_test(public_network_test, requires = "git")]
fn git_spurious_error_message() {
let p = project()
.file(
"Cargo.toml",
r#"
[package]
name = "foo"
version = "0.1.0"
edition = "2015"
[dependencies]
my-dep = { git = "http://localhost:9999" }
"#,
)
.file("src/lib.rs", "")
.build();
p.cargo("fetch")
.env("CARGO_NET_GIT_FETCH_WITH_CLI", "true")
.with_status(101)
.with_stderr_data(str![[r#"
[UPDATING] git repository `http://localhost:9999/`
fatal: unable to access 'http://localhost:9999/': Failed to connect to localhost port 9999 after 0 ms: Couldn't connect to server
[WARNING] spurious network error (3 tries remaining): process didn't exit successfully: `git fetch --no-tags --force --update-head-ok 'http://localhost:9999/' '+HEAD:refs/remotes/origen/HEAD'` ([EXIT_STATUS]: 128)
fatal: unable to access 'http://localhost:9999/': Failed to connect to localhost port 9999 after 0 ms: Couldn't connect to server
[WARNING] spurious network error (2 tries remaining): process didn't exit successfully: `git fetch --no-tags --force --update-head-ok 'http://localhost:9999/' '+HEAD:refs/remotes/origen/HEAD'` ([EXIT_STATUS]: 128)
fatal: unable to access 'http://localhost:9999/': Failed to connect to localhost port 9999 after 0 ms: Couldn't connect to server
[WARNING] spurious network error (1 try remaining): process didn't exit successfully: `git fetch --no-tags --force --update-head-ok 'http://localhost:9999/' '+HEAD:refs/remotes/origen/HEAD'` ([EXIT_STATUS]: 128)
fatal: unable to access 'http://localhost:9999/': Failed to connect to localhost port 9999 after 0 ms: Couldn't connect to server
[ERROR] failed to get `my-dep` as a dependency of package `foo v0.1.0 ([ROOT]/foo)`
Caused by:
failed to load source for dependency `my-dep`
Caused by:
Unable to update http://localhost:9999/
Caused by:
failed to clone into: [ROOT]/home/.cargo/git/db/_empty-[HASH]
Caused by:
process didn't exit successfully: `git fetch --no-tags --force --update-head-ok 'http://localhost:9999/' '+HEAD:refs/remotes/origen/HEAD'` ([EXIT_STATUS]: 128)
"#]])
.run();
}
Contributor
Author
|
|
Member
|
Either works, but don't over match GitHub specific error messages |
2abb59a to
2e5c6c2
Compare
Mark `git fetch` (in the `CARGO_NET_GIT_FETCH_WITH_CLI` path) as a command whose failure may be considered spurious, and enable retry logic when such a failure occurs. This helps reduce intermittent errors in situations where `git fetch` fails due to transient network or server issues.
2e5c6c2 to
fd69670
Compare
Member
|
Thank you for working on this! I will let Weihang take another look before we merge it! Looks great for me. |
weihanglo
approved these changes
Sep 30, 2025
bors
added a commit
to rust-lang/rust
that referenced
this pull request
Oct 3, 2025
Update cargo submodule 24 commits in f2932725b045d361ff5f18ba02b1409dd1f44e71..2394ea6cea8b26d717aa67eb1663a2dbf2d26078 2025-09-24 11:31:26 +0000 to 2025-10-03 14:13:01 +0000 - Recommend `package.rust-version` in the Rust version section of `reference/semver.md`. (rust-lang/cargo#15806) - fix(toml): Prevent non-script fields in Cargo scripts (rust-lang/cargo#16026) - chore(ci): unpin libc (rust-lang/cargo#16044) - chore: Update dependencies (rust-lang/cargo#16034) - Fix FileLock path tracking after rename in package operation (rust-lang/cargo#16036) - Lockfile schemas error cleanup (rust-lang/cargo#16039) - Convert a multi-part diagnostic to a report (rust-lang/cargo#16035) - fix(run): Override arg0 for cargo scripts (rust-lang/cargo#16027) - Public in private manifest errors (rust-lang/cargo#16002) - chore(deps): update actions/checkout action to v5 (rust-lang/cargo#16031) - fix: remove FIXME comment that's no longer a problem (rust-lang/cargo#16025) - Add retry for `git fetch` failures in `CARGO_NET_GIT_FETCH_WITH_CLI` path (rust-lang/cargo#16016) - Added better filesystem layout testing harness (rust-lang/cargo#15874) - Small cleanup to normalize_dependencies (rust-lang/cargo#16022) - fix: better error message for rust version incompatibility (rust-lang/cargo#16021) - fix(shell): Use a distinct style for transient status (rust-lang/cargo#16019) - chore(deps): Depend on `serde_core` in `cargo-platform` (rust-lang/cargo#15992) - Remove package-workspace from unstable doc index (rust-lang/cargo#16014) - fix(shell): Switch to annotate snippets for notes (rust-lang/cargo#15945) - docs: update changelog (rust-lang/cargo#15986) - chore(ci): add rustfmt for docs job (rust-lang/cargo#16013) - chore: bump to 0.93.0 (rust-lang/cargo#16009) - fix(config): combine key error context into one (rust-lang/cargo#16004) - test(docker): openssh requires a newer libcrypto3 (rust-lang/cargo#16010) r? ghost
Kobzol
pushed a commit
to Kobzol/rustc_codegen_gcc
that referenced
this pull request
Dec 21, 2025
Update cargo submodule 24 commits in f2932725b045d361ff5f18ba02b1409dd1f44e71..2394ea6cea8b26d717aa67eb1663a2dbf2d26078 2025-09-24 11:31:26 +0000 to 2025-10-03 14:13:01 +0000 - Recommend `package.rust-version` in the Rust version section of `reference/semver.md`. (rust-lang/cargo#15806) - fix(toml): Prevent non-script fields in Cargo scripts (rust-lang/cargo#16026) - chore(ci): unpin libc (rust-lang/cargo#16044) - chore: Update dependencies (rust-lang/cargo#16034) - Fix FileLock path tracking after rename in package operation (rust-lang/cargo#16036) - Lockfile schemas error cleanup (rust-lang/cargo#16039) - Convert a multi-part diagnostic to a report (rust-lang/cargo#16035) - fix(run): Override arg0 for cargo scripts (rust-lang/cargo#16027) - Public in private manifest errors (rust-lang/cargo#16002) - chore(deps): update actions/checkout action to v5 (rust-lang/cargo#16031) - fix: remove FIXME comment that's no longer a problem (rust-lang/cargo#16025) - Add retry for `git fetch` failures in `CARGO_NET_GIT_FETCH_WITH_CLI` path (rust-lang/cargo#16016) - Added better filesystem layout testing harness (rust-lang/cargo#15874) - Small cleanup to normalize_dependencies (rust-lang/cargo#16022) - fix: better error message for rust version incompatibility (rust-lang/cargo#16021) - fix(shell): Use a distinct style for transient status (rust-lang/cargo#16019) - chore(deps): Depend on `serde_core` in `cargo-platform` (rust-lang/cargo#15992) - Remove package-workspace from unstable doc index (rust-lang/cargo#16014) - fix(shell): Switch to annotate snippets for notes (rust-lang/cargo#15945) - docs: update changelog (rust-lang/cargo#15986) - chore(ci): add rustfmt for docs job (rust-lang/cargo#16013) - chore: bump to 0.93.0 (rust-lang/cargo#16009) - fix(config): combine key error context into one (rust-lang/cargo#16004) - test(docker): openssh requires a newer libcrypto3 (rust-lang/cargo#16010) r? ghost
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
What does this PR try to resolve?
#15856
This PR addresses transient failures when using the
CARGO_NET_GIT_FETCH_WITH_CLIpath by adding support for marking process failures as spurious and enabling
retries for
git fetch.Changes
GitCliErrorwithis_spuriousmeta information.CARGO_NET_GIT_FETCH_WITH_CLIcode path to markgit fetchasspurious and retry on failure
How to test and review this PR?
A test project: