From 2005ae1d4ea632fc592dcb260db12d098c18e040 Mon Sep 17 00:00:00 2001 From: Joe Neeman Date: Tue, 7 May 2024 16:19:27 -0500 Subject: [PATCH 1/2] Silence the warning about forgetting the vendoring --- src/cargo/sources/replaced.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/cargo/sources/replaced.rs b/src/cargo/sources/replaced.rs index 72b25596384..c64257908a6 100644 --- a/src/cargo/sources/replaced.rs +++ b/src/cargo/sources/replaced.rs @@ -152,7 +152,7 @@ impl<'gctx> Source for ReplacedSource<'gctx> { } fn is_replaced(&self) -> bool { - true + !self.is_builtin_replacement() } fn add_to_yanked_whitelist(&mut self, pkgs: &[PackageId]) { From 2f97a3b323044aa289127b499daddb96ac2cfcec Mon Sep 17 00:00:00 2001 From: Joe Neeman Date: Thu, 9 May 2024 14:09:13 -0500 Subject: [PATCH 2/2] Add a test and a comment --- src/cargo/sources/source.rs | 2 ++ tests/testsuite/registry.rs | 40 +++++++++++++++++++++++++++++++++++++ 2 files changed, 42 insertions(+) diff --git a/src/cargo/sources/source.rs b/src/cargo/sources/source.rs index b3dec06b435..14d3e0ac9ec 100644 --- a/src/cargo/sources/source.rs +++ b/src/cargo/sources/source.rs @@ -146,6 +146,8 @@ pub trait Source { fn describe(&self) -> String; /// Returns whether a source is being replaced by another here. + /// + /// Builtin replacement of `crates.io` doesn't count as replacement here. fn is_replaced(&self) -> bool { false } diff --git a/tests/testsuite/registry.rs b/tests/testsuite/registry.rs index 24c253c5504..63f318877a6 100644 --- a/tests/testsuite/registry.rs +++ b/tests/testsuite/registry.rs @@ -3833,3 +3833,43 @@ fn builtin_source_replacement() { ) .run(); } + +#[cargo_test] +fn builtin_source_replacement_no_vendor_error() { + // errors for builtin source replacement of crates.io + // should not mention outdated vendor dependencies + let server = RegistryBuilder::new().build(); + + let p = project() + .file( + "Cargo.toml", + r#" + [package] + name = "foo" + version = "0.0.1" + edition = "2021" + + [dependencies] + dep = "0.2.0" + "#, + ) + .file("src/main.rs", "fn main() {}") + .build(); + + let pkg = Package::new("dep", "0.1.0"); + pkg.publish(); + + p.cargo("check -v") + .replace_crates_io(&server.index_url()) + .with_status(101) + .with_stderr( + "\ +[UPDATING] [..] index +[ERROR] failed to select a version for the requirement `dep = \"^0.2.0\"` +candidate versions found which didn't match: 0.1.0 +location searched: crates.io index +required by package `foo v0.0.1 ([..])` +", + ) + .run(); +}