From 2b7414a7b483bea8b152c7d6fdfb84c9a742ead5 Mon Sep 17 00:00:00 2001 From: Ed Page Date: Wed, 30 Oct 2024 10:55:58 -0500 Subject: [PATCH] download transitive deps of artifact deps on target platform --- src/cargo/core/package.rs | 22 ++++++++++++++++++++-- tests/testsuite/artifact_dep.rs | 23 ++++++++++++----------- 2 files changed, 32 insertions(+), 13 deletions(-) diff --git a/src/cargo/core/package.rs b/src/cargo/core/package.rs index f4198cc068e8..d4315197bbe9 100644 --- a/src/cargo/core/package.rs +++ b/src/cargo/core/package.rs @@ -519,7 +519,7 @@ impl<'gctx> PackageSet<'gctx> { target_data, force_all_targets, ); - for (pkg_id, _dep) in filtered_deps { + for (pkg_id, deps) in filtered_deps { collect_used_deps( used, resolve, @@ -529,6 +529,24 @@ impl<'gctx> PackageSet<'gctx> { target_data, force_all_targets, )?; + let artifact_kinds = deps.iter().filter_map(|dep| { + Some( + dep.artifact()? + .target()? + .to_resolved_compile_kind(*requested_kinds.iter().next().unwrap()), + ) + }); + for artifact_kind in artifact_kinds { + collect_used_deps( + used, + resolve, + pkg_id, + has_dev_units, + artifact_kind, + target_data, + force_all_targets, + )?; + } } Ok(()) } @@ -551,7 +569,7 @@ impl<'gctx> PackageSet<'gctx> { )?; } } - let mut to_download = to_download + let to_download = to_download .into_iter() .map(|(p, _)| p) .collect::>(); diff --git a/tests/testsuite/artifact_dep.rs b/tests/testsuite/artifact_dep.rs index 6d8c309c9a45..f84786b4b8f4 100644 --- a/tests/testsuite/artifact_dep.rs +++ b/tests/testsuite/artifact_dep.rs @@ -1646,16 +1646,17 @@ fn dep_of_artifact_dep_same_target_specified() { .with_status(0) .run(); - // TODO This command currently fails due to a bug in cargo but it should be fixed so that it succeeds in the future. p.cargo("tree -Z bindeps") .masquerade_as_nightly_cargo(&["bindeps"]) - .with_stderr_data( + .with_stdout_data( r#"... -no entry found for key +foo v0.1.0 ([ROOT]/foo) +└── bar v0.1.0 ([ROOT]/foo/bar) + └── baz v0.1.0 ([ROOT]/foo/baz) ... "#, ) - .with_status(101) + .with_status(0) .run(); } @@ -1827,17 +1828,17 @@ fn proc_macro_in_artifact_dep() { p.cargo("check -Z bindeps") .masquerade_as_nightly_cargo(&["bindeps"]) - .with_stderr_data(str![[r#" + .with_stderr_data( + r#"... [UPDATING] `dummy-registry` index [LOCKING] 2 packages to latest compatible versions [DOWNLOADING] crates ... -[DOWNLOADED] bin-uses-pm v1.0.0 (registry `dummy-registry`) -[DOWNLOADING] crates ... -thread 'main' panicked at src/cargo/core/compiler/unit_dependencies.rs:1035:33: -expected pm v1.0.0 to be downloaded -[NOTE] run with `RUST_BACKTRACE=1` environment variable to display a backtrace +[ERROR] failed to download from `[ROOTURL]/dl/pm/1.0.0/download` -"#]]) +Caused by: + [37] Could not read a file:// file (Couldn't open file [ROOT]/dl/pm/1.0.0/download) +"#, + ) .with_status(101) .run(); }