-
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
[WIP] parallel test crates #10052
[WIP] parallel test crates #10052
Conversation
r? @Eh2406 (rust-highfive has picked a reviewer for you, use r? to override) |
☔ The latest upstream changes (presumably #10051) made this pull request unmergeable. Please resolve the merge conflicts. |
c3e2d69
to
7b5d94b
Compare
worse: no progress reporting as it goes.
Wow - a green build with parallel turned on. That's super nice. |
So if this goes green, the outstanding issues before this is a MVP:
|
(but maximum is not yet limited to this)
Todo: we can do better than that sleep with some signaling. |
c4c7c46
to
f899d0c
Compare
Wondering how much of the existing jobserver infrastructure I can reuse - jobstate and job I think are ok. I had better stay away from the rest as it worries about dependencies which we don't have to worry about at this point (from what I can see). |
@Eh2406 feel free to opine :-) |
The end game is probably to use jobserver to balance job tokens between libtest processes... that feels like an extension PR, not a MVP. |
Hmm job queue looks a little too tied into rustc. I think I'm better off not trying to tie that all together. |
I would say a few words of caution before implementing this feature. I believe there are two critical features about running subprocesses in parallel which Cargo isn't really in a position to handle today:
These points can be solved if Cargo controlled the test harness, but it doesn't in general, so I don't think this is really an implementable feature in Cargo. Also as a side note it looks like you're using the exising job queueing infrastructure to implement this but there are no dependencies between tests so I don't think that this is necessary, it can be done with something much more lightweight most likely. |
Good points. While we can't control the amount of parallelism automatically, people can set --test-jobs and --test-threads manually. I do accept that they multiply and could in theory mean that you get slower overall results. That said I have been using substrate as a benchmark (which is a pretty large project) and this feature makes a huge difference to test runtimes. Given how much time this saves on 32 core boxes (which will become more usual) I don't think this is something large projects would want to be without. On the output front at the moment it is using the progress bar from compiling which helps give a bit more feedback. It is a little jumpy in that once it has finished tracking a crate's test output it might dump a couple more test outputs that have finished before catching onto another test crate that is in progress, but this way seems as close to the single threaded test experience as possible. There's two other directions I would like to explore but maybe better as followup prs:
|
Thinking further on the controlling parallism front: Can one assume that |
While I understand this works for your project that's not necessarily enough to land in Cargo itself. The issues I mentioned are pretty fundamental and I think would block inclusion into Cargo. In the meantime for your use case I'd recommend something like |
If I may, I'd prefer to attempt to solve the general case. I've added control for parallism - worst case it has the same performance as before. As long as one test can be assumed to take no more than one thread, then parallelism is limited. I suspect that's as much of a guarentee as On the UI front it does stream test crate results (and buffers the non-current crate so as not to interleave results). If a test takes longer than 60 seconds, that will still be seen in the console because we'd be tracking that test suite if its the last one running. There's also more of an indication of how many crates have been tested (before there was no Progress support). To me the test UI now seems on a par with the compilation UI. Will take this version for a spin and see how it handles a few different projects. |
I'm wondering on the impact on this when running |
For some reason I thought x.py test didn’t use cargo test. Hmm, worth
checking out.
…On Sun, 28 Nov 2021 at 16:53, Matthias Krüger ***@***.***> wrote:
I'm wondering on the impact on this when running x.py test on rustc
itself. 🙂 Have you done some before/after benchmarks by any chance?
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#10052 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAGEJCGZVWHX6NTRGA2WQE3UOJNALANCNFSM5HQCLZBQ>
.
|
Came across this. I'm really close to releasing cargo-nextest which runs test crates in parallel -- it's available at https://nexte.st/ and will be installable from crates.io some time early next week. Hope that helps! |
Excellent - will be sure to give it a go.
…On Sat, 12 Feb 2022 at 00:41, Rain ***@***.***> wrote:
Came across this. I'm really close to releasing cargo-nextest which runs
test crates in parallel -- it's available at https://nexte.st/ and will
be installable from crates.io some time early next week. Hope that helps!
—
Reply to this email directly, view it on GitHub
<#10052 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAGEJCEALILX44PJ4TO5ZYTU2WUD3ANCNFSM5HQCLZBQ>
.
You are receiving this because you authored the thread.Message ID:
***@***.***>
|
nextest is now generally available at https://nexte.st. For the reasons mentioned in the thread I think it would be pretty hard to do this sort of behavior change in cargo test itself, but nextest provides a good alternative for people who need it. |
☔ The latest upstream changes (presumably #10346) made this pull request unmergeable. Please resolve the merge conflicts. |
Let's get behind https://nexte.st/ - closing this for now. |
Fixes: #5609