-
Notifications
You must be signed in to change notification settings - Fork 2.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow crates to be published with cyclic dev-dependencies #4242
Comments
Yeah in general I think we should basically ignore dev-dependencies when we publish. We shouldn't attempt to resolve them, verify they're already published, etc. |
Maybe dev-dependencies don't have to be shown in the crate's page too. |
I bumped into this issue as well. From what I can tell the workaround above gets us by this for now. 👍 |
+1 to this-- it now affects the futures crate. |
While preparing for publication, I realized I cannot publish crates with cyclic dev-dependencies. That's an interesting issue, and a work-around is currently used: rust-lang/cargo#4242 Another issue: it seems "imgui-glium-renderer" requires the "glutin" feature of "glium". However it was not enabled. So I enabled it.
While preparing for publication, I realized I cannot publish crates with cyclic dev-dependencies. That's an interesting issue, and a work-around is currently used: rust-lang/cargo#4242 Another issue: it seems "imgui-glium-renderer" requires the "glutin" feature of "glium". However it was not enabled. So I enabled it.
While preparing for publication, I realized I cannot publish crates with cyclic dev-dependencies. That's an interesting issue, and a work-around is currently used: rust-lang/cargo#4242 Another issue: it seems "imgui-glium-renderer" requires the "glutin" feature of "glium". However it was not enabled. So I enabled it.
While preparing for publication, I realized I cannot publish crates with cyclic dev-dependencies. That's an interesting issue, and a work-around is currently used: rust-lang/cargo#4242
While preparing for publication, I realized I cannot publish crates with cyclic dev-dependencies. That's an interesting issue, and a work-around is currently used: rust-lang/cargo#4242
While preparing for publication, I realized I cannot publish crates with cyclic dev-dependencies. That's an interesting issue, and a work-around is currently used: rust-lang/cargo#4242
While preparing for publication, I realized I cannot publish crates with cyclic dev-dependencies. That's an interesting issue, and a work-around is currently used: rust-lang/cargo#4242
This affects a lot of crates, what do we need to do to fix this? Isn't there a check somewhere that checks for the dependencies before publishing, where we can just filter dev-dependencies away and call it a day? [0] I mean, this would even affect core and std, where std could depend on core to build, but core would depend on std for tests. The check is spurious anyways, because this sort of dependencies are not circular: build core -> build std -> build core tests is ok. Tests and "dev-only" artifacts are their own crates (core+tests is a different crate than core, and so are every test/foo.rs in core, and core/examples, etc.). I'll admit that the core/std analogy is imperfect because these crates are too magical, but when something wouldn't be correct for the std library, chances are it won't be correct for users either. FWIW I just tried to prepare coresimd/stdsimd for a quick crates.io release, and ran into this, where coresimd builds standalone and stdsimd depends on coresimd, but coresimd depends on stdsimd for testing. The only solution I came up with is the same that gluon uses which is insane: publish coresimd prunning dev-dependencies, publish stdsimd, re-publish coresimd with a minor version update to use the newly publish stdsimd as dev-dependencies. Which is a lot of effort, for.. what exactly? Is it possible for users to execute [0] cc @matklad, are you willing to mentor this? It might be enough to just skip dev dependencies here: cargo/src/cargo/ops/registry.rs Line 110 in af3f1cd
and also in packaging: https://github.com/rust-lang/cargo/blob/0e7a46e3276f56822b6ef48e341c522be27db17e/src/cargo/ops/cargo_package.rs |
Hm, I think a simpler work-around is possible? Just comment-out For mentoring instructions, I believe you've basically nailed it :) The only thing I have to add is that the test should go to this file, and it probably makes sense to start with a test and work through all errors. For the tests, I think we should cover at least two scenarios:
|
Hm I'm actually not sure that the fix would go in that location nor that we could easily write a test for this. AFAIK the check for "does this dependency exist" is done on crates.io, not locally in Cargo. In that sense we'd need to test with crates.io, not with just local Cargo test suite business. I also think the "fix" for this is to basically stop informing crates.io about dev-dependencies. Although we did that initially I'm not really sure why we need to do that, as they're never used and are otherwise just bloating the index. The fix for that would go around here by filtering out dev-dependencies. Cargo would then also need to be updated to not verify that dev-dependencies have versions (allowing This would be a relatively large change though (and somewhat of a policy shift) so it would likely need some more scrutiny and discussion before happening. |
Hm, probably a crazy idea, but, given that we already modify Cargo.toml on publishing to rewrite path dependencies (source), could we, at the same step, just drop dev-deps altogether as well? |
Yes I think such a fix would work, but it alone wouldn't be 100% sufficient because crates.io doesn't actually parse the manifest for dependency information (it only uses what was sent in JSON) |
While preparing for publication, I realized I cannot publish crates with cyclic dev-dependencies. That's an interesting issue, and a work-around is currently used: rust-lang/cargo#4242
I guess the proposed change would also now allow |
PR #7333 added auto-stripping of dev-dependencies that do not have a However, people using this, especially with One idea is to completely ignore dev-dependencies at each stage of the publish process. At minimum, we need to ensure the |
btw rust-lang/rfcs#3452 could allow nesting dev dependencies as another way of breaking cycles. |
This wasn't meant to be committed, cargo-smart-release. Commenting is needed to fix the cyclic dep aya-ebpf-macros -> aya-ebpf -> aya-ebpf-macros. See rust-lang/cargo#4242 (comment)
Most of the time I see this discussed, it is in the context where a path dependency exists to a package that might not be published yet. There are cases, like async-stream and tokio-test (see tokio-rs/async-stream#102) where path dependencies are not involved because its cross-repo. This simplifies the problem because the cyclic dev-dependencies have to be published for any of this to work. As mentioned earlier in this thread and again in https://rust-lang.zulipchat.com/#narrow/stream/246057-t-cargo/topic/Is.20dev-dependency.20information.20from.20the.20index.20used.3F, dev-dependencies don't matter for the index, so we could strip them from the Summary we upload. We could even keep them in the |
1. This looks like caused by rust-lang/cargo#4242 ## Ref 1. rust-lang/futures-rs#2305
1. This looks like caused by rust-lang/cargo#4242 1. rust-lang/futures-rs#2305
1. This looks like caused by rust-lang/cargo#4242 1. rust-lang/futures-rs#2305
We're running into this when trying to So |
The standard solution is to only use
Any
I don't see this being resolved by just "removing a check". |
Due to rust-lang/cargo#4242, `cargo package` is considering dev-dependencies when trying to package and there's a cyclic dependency only when doing that. This works around that cycle while retaining the ability to doctest.
Due to rust-lang/cargo#4242, `cargo package` is considering dev-dependencies when trying to package and there's a cyclic dependency only when doing that. This works around that cycle while retaining the ability to doctest.
It's worth noting that this means crater will no longer be able to test your crate. If you're confident in your testing and pre-declared dependency requirements my preference is to |
If its on github, crater will still test it, right? As I said, I also don't know if relying on |
I'm not sure how crater decides which github repos to test, querying a random report I see there's a bunch of mine included, but also some I would expect to be aren't (including a personal fork of an org project is being tested, but the upstream project isn't, so it's only testing my very outdated main branch). |
In gluon I have the project split up into multiple crates with the intent that users can include only the crates they need if they desire a smaller binary footprint. For convenience I provide a main
gluon
crate which provides an easy to use interface when one uses all the crates.While this split works fine for mostly everything I want to use the easy interface when writing documentation tests so I added the
gluon
crate as a dev-dependency in gluon_vm and this compiles without issue since a little bit back. It does however break when trying to publishgluon_vm
as thegluon
dev-dependency has not been published yet!Currently I managed to work around it by specifying a version range but it would be nice if there was a way to publish a group of crates as a whole or to ignore the version check if a dev-dependency does not exist on crates.io (yet).
The text was updated successfully, but these errors were encountered: