-
Notifications
You must be signed in to change notification settings - Fork 2.4k
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
Cargo: produce deterministic filenames for build --test
and test --no-run
#1924
Comments
The problem Cargo has to deal with here is that you can test many targets which are all named the same. For example you could have a binary called I do agree though it's annoying to have to basically do a diff of the output directory before and after a test run to see what binaries were generated. |
Why not just put the test binaries in their own directory then, like |
The problem is that you can have multiple binaries called |
Which is a perfectly fine solution, no? |
Yet another solution would be to have the Cargo build targets all share the same namespace. Seems like a fine solution if Cargo was just starting out, but at this point it would be a breaking change - so not ideal, I reckon... |
There may be a more ergonomic possibility than |
Then how about just |
Hm actually now that I think about it we probably want to continue the pattern of |
Well, Rust may be 1.0, but Cargo is only version 0.2, so it can be argued that a minor breaking change would be acceptable. But I don't know how strict your policy aims to be with regards to breaking changes in Cargo. |
Despite Cargo's version it actually needs to be quite stable today, so I'd prefer to keep at least roughly the same pattern that we have today. |
How about (additionnally?) making cargo run --no-test output the name of the executables it builds on stdout? This way, |
@FlorentBecker my preference here would be to just have deterministic filenames for now, but that's a possible alternative if it doesn't work out! |
I'd have to say that I would prefer to have a way to get the file name from cargo instead of being able to guess it myself. |
I have to agree with @adrianheine and @FlorentBecker. It would be very nice to have cargo give the output of test discovery. To make the output parseable in scripts and the like, I would propose that something like a Currently, I am working on adding infrastructure to nix based on libc. Unlike libc, nix does not currently have most of its tests built separately in a single executable. Right now, after cross compiling the executables there is no great way to get the paths to the test executables and pass execute them in qemu. I can glob but even then it involves a repetition of the individual tests that are in the root Cargo.toml. |
@alexcrichton If compatibility with existing build scripts is important (implying the continuing of the pattern of @posborne 's additional suggestion of enabling Cargo to output the filenames is good as well. It enables tools to figure out the executables without having to be able to parse Cargo.toml and figure out the Cargo targets beforehand. But this suggestion should be an addition, not the main solution, there should still be a way to generate static/deterministic filenames. |
Yeah at this point I think that we should probably just invent some scheme that has predictable names but lacks hashes. Along those lines I'd be fine with basically anything that kept the convention of |
Hum, so like |
That sounds pretty reasonable to me, yeah! |
I would perhaps avoid the |
Unfortunately using |
Then The confusion under Windows I feared was that Windows by default hide the extension in various places and don't do it in a particularly consistent way. And because If you want to have |
Hm this actually gives me an idea! So I'd like to keep the same names we have today in case any scripts are relying on them, but we could perhaps do something like:
That way we could slowly phase out the old locations and we could continue to use the new ones today! |
If that's confusing, Windows users should disable the Windows Explorer option that hides file extensions. I suspect most Windows developers and power users do that already anyways (I certainly do). And IDEs certainly don't hide extensions. |
@alexcrichton Yeeeesh, hard links... you sure that's a good idea? Sounds like a really heavy handed solution. Do all the OSes that Rust targets have filesystems that support hard links? What if one wants to use a filesystem that doesn't support hard links? Imagine for example someone has a Rust project on a portable FAT32 USB stick or something like that. Or a network share? It's a really odd and rare scenario, but I think it might realistically happen. |
Re library to use, |
@kamalmarhubi Oh cool, didn't know about that. |
I haven't thought about if hardlinks are the right approach, but this is a real concern. I think between FS support and confusing Explorer defaults, I'd prefer the confusion over reduced FS support. |
This new class offer the capbility to build rust tests and find them correctly. Due to non deterministic name of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust project will generate a test binary even if there are not test defined in source code (the binary will just output that it ran 0 tests) (From OE-Core rev: eb4fbd360b7425c1959c05af289ee51ff1342145) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Luca Ceresoli <luca.ceresoli@bootlin.com>
This new class offer the capbility to build rust tests and find them correctly. Due to non deterministic name of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust project will generate a test binary even if there are not test defined in source code (the binary will just output that it ran 0 tests) (From OE-Core rev: eb4fbd360b7425c1959c05af289ee51ff1342145) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Luca Ceresoli <luca.ceresoli@bootlin.com>
This new class offer the capbility to build rust tests and find them correctly. Due to non deterministic name of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust project will generate a test binary even if there are not test defined in source code (the binary will just output that it ran 0 tests) (From OE-Core rev: eb4fbd360b7425c1959c05af289ee51ff1342145) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Luca Ceresoli <luca.ceresoli@bootlin.com>
This new class offer the capbility to build rust tests and find them correctly. Due to non deterministic name of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust project will generate a test binary even if there are not test defined in source code (the binary will just output that it ran 0 tests) (From OE-Core rev: b44f3ed1db1e06bdb0c243dcaaa11089754da859) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Luca Ceresoli <luca.ceresoli@bootlin.com>
This new class offer the capbility to build rust tests and find them correctly. Due to non deterministic name of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust project will generate a test binary even if there are not test defined in source code (the binary will just output that it ran 0 tests) (From OE-Core rev: 1bbabd12d996eb477a9efd839e2d0445f9cf4e8c) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Luca Ceresoli <luca.ceresoli@bootlin.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: 5106382d1aba25db190f61a8026df593a24c2991) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: 5106382d1aba25db190f61a8026df593a24c2991) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: 5106382d1aba25db190f61a8026df593a24c2991) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: 5106382d1aba25db190f61a8026df593a24c2991) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: 6050107d5209a623126936edfc34f10fce9f0d2a) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: 0878719eb008308fce6768bb85dbc47968fbe154) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: 30cb3b37653bf11913e7f9ce3f740d58a4b6e90e) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: 30cb3b37653bf11913e7f9ce3f740d58a4b6e90e) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: 2978b58bb2a0cf8734b9be6881339cce214fc1fc) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: 2978b58bb2a0cf8734b9be6881339cce214fc1fc) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: 2978b58bb2a0cf8734b9be6881339cce214fc1fc) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: dad9bad239d757ae0b159fe5f1276b6856547b4c) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
I am looking for something like this, so on macos I can code-sign the test binaries created (to avoid the network access permission modal dialog that stops my build) before they are run (from a Makefile). But it looks like this conversation petered out and wasn't concluded in 2016-2018!! I'd like:
|
@andrewdavidmackenzie For your specific problem you could probably use
The path to the test exectuable is passed as an argument to the runner script. |
Thanks for the suggestion. Trying it now. It looks like I can't set in my workspace Cargo.toml and will need to add to each member Cargo.toml? I'm struggling with the format:
causes
|
@andrewdavidmackenzie this configuration option needs to be set in a .cargo/config.toml, not in a Cargo.toml. you can place this configuration file in your workspace root. (The .cargo folder must be a parent directory of the folder cargo was invoked from.) |
Got it working - thanks for your help! |
Hi all, adding this would be great for Meson users. The tests' building step could be decoupled and kept away from |
Same here, I spent quite some time figuring out how to generate Meson tests from the produced test binaries, but it's really dirty and frankly unreliable. It's needed so I can make my Cargo-powered tests live with all the other tests of my project, like my app's metadata checkers, and so they can all integrate well with IDE and my CI. |
This new class offers the possibility to build rust unit tests (and integration tests) and find them correctly. Due to non deterministic names of generated binaries, a custom parsing of build result must be performed. See rust-lang/cargo#1924 All rust projects will generate a test binary with "cargo build --tests" command, even if there are no test defined in source code. The binary will just output that it ran 0 tests. (From OE-Core rev: dad9bad239d757ae0b159fe5f1276b6856547b4c) Signed-off-by: Frederic Martinsons <frederic.martinsons@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
I'm doing IDE integration, and I want my IDE to be able to debug the test binaries - for which the IDE has to launch those programs itself, it shouldn't use
cargo test
. However (unlike--bin
for example) neitherbuild --test
nortest --no-run
produce a deterministic filename, but something random liketest1-748b2ca97d589628.exe
.The text was updated successfully, but these errors were encountered: