- 
                Notifications
    You must be signed in to change notification settings 
- Fork 2.7k
Open
Labels
A-crate-typesArea: crate-type declaration (lib, staticlib, dylib, cdylib, etc.)Area: crate-type declaration (lib, staticlib, dylib, cdylib, etc.)C-bugCategory: bugCategory: bugCommand-buildCommand-testS-triageStatus: This issue is waiting on initial triage.Status: This issue is waiting on initial triage.
Description
Problem
The minimal repro project https://github.com/Firestar99/cargo_dylib_dev_dep_fail can be cargo build normally, but building tests with cargo test --no-run fails:
   Compiling liba v0.1.0 (/home/firestar99/workspace/bla/cargo_dylib_dev_dep_fail/liba)
   Compiling libb v0.1.0 (/home/firestar99/workspace/bla/cargo_dylib_dev_dep_fail/libb)
   Compiling libc v0.1.0 (/home/firestar99/workspace/bla/cargo_dylib_dev_dep_fail/libc)
error: cannot satisfy dependencies so `std` only shows up once
  |
  = help: having upstream crates all available in one format will likely make this go away
[... Repeat the error above for the dependencies core, alloc, compiler_builtins, libc, rustc_std_workspace_core, unwind, cfg_if, miniz_oxide, adler2, hashbrown, rustc_std_workspace_alloc, std_detect, rustc_demangle, addr2line, gimli, object, memchr and panic_unwind]
error: could not compile `libb` (lib test) due to 19 previous errors
warning: build failed, waiting for other jobs to finish...
The workspace consists out of these crates:
- liba- lib with crate-type = ["rlib", "dylib"]
- exports SymbolLibA
 
- lib with 
- libb- a proc-macrocrate declaring a trivial proc macro
- dev-dependencyon- libc- uses SymbolLibCfromlibcin tests and doctests
 
- uses 
 
- a 
- libc- standard lib
- depends on libaandlibb
- exports SymbolLibC, which usesSymbolLibAinternally
 
For some reason, the combination of liba having the additional crate-type dylib (next to lib) and the proc-macro crate libb having a dev-dependency on libc causes cargo test to fail building. I'd be fine with liba being imported as a lib crate-type on the CPU, I only need liba to have the option of being dylib for the rust-gpu custom codegen backend.
Steps
git clone https://github.com/Firestar99/cargo_dylib_dev_dep_fail
cd cargo_dylib_dev_dep_fail
cargo test --no-runobserve failure
Possible Solution(s)
No response
Notes
This is a minimized version of #15890
- both cargo bandcargo b --profile testwork, it seems thatcargo test --no-runpasses something extra that causes it to fail
- crate-type libandrlibseem to be interchangeable
- crates seem to be lazy-imported, so libbmust use a symbol fromlibcit must use a symbol fromliba
Version
cargo 1.89.0 (c24e10642 2025-06-23)
Metadata
Metadata
Assignees
Labels
A-crate-typesArea: crate-type declaration (lib, staticlib, dylib, cdylib, etc.)Area: crate-type declaration (lib, staticlib, dylib, cdylib, etc.)C-bugCategory: bugCategory: bugCommand-buildCommand-testS-triageStatus: This issue is waiting on initial triage.Status: This issue is waiting on initial triage.
Type
Projects
Status
No status