diff --git a/tests/testsuite/bench.rs b/tests/testsuite/bench.rs index 1cb3f8c19a0a..58b2f262f3f3 100644 --- a/tests/testsuite/bench.rs +++ b/tests/testsuite/bench.rs @@ -1,9 +1,8 @@ //! Tests for the `cargo bench` command. -#![allow(deprecated)] - use cargo_test_support::paths::CargoPathExt; -use cargo_test_support::{basic_bin_manifest, basic_lib_manifest, basic_manifest, project}; +use cargo_test_support::prelude::*; +use cargo_test_support::{basic_bin_manifest, basic_lib_manifest, basic_manifest, project, str}; #[cargo_test(nightly, reason = "bench")] fn cargo_bench_simple() { @@ -35,16 +34,29 @@ fn cargo_bench_simple() { p.cargo("build").run(); assert!(p.bin("foo").is_file()); - p.process(&p.bin("foo")).with_stdout("hello\n").run(); + p.process(&p.bin("foo")) + .with_stdout_data(str![[r#" +hello + +"#]]) + .run(); p.cargo("bench") - .with_stderr( - "\ -[COMPILING] foo v0.5.0 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] -[RUNNING] [..] (target/release/deps/foo-[..][EXE])", - ) - .with_stdout_contains("test bench_hello ... bench: [..]") + .with_stderr_data(str![[r#" +[COMPILING] foo v0.5.0 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] unittests src/main.rs (target/release/deps/foo-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test bench_hello ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -80,15 +92,28 @@ fn bench_bench_implicit() { .build(); p.cargo("bench --benches") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [RUNNING] [..] (target/release/deps/foo-[..][EXE]) [RUNNING] [..] (target/release/deps/mybench-[..][EXE]) -", - ) - .with_stdout_contains("test run2 ... bench: [..]") + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test run1 ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test run2 ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -124,14 +149,21 @@ fn bench_bin_implicit() { .build(); p.cargo("bench --bins") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [RUNNING] [..] (target/release/deps/foo-[..][EXE]) -", - ) - .with_stdout_contains("test run1 ... bench: [..]") + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test run1 ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -157,14 +189,21 @@ fn bench_tarname() { .build(); p.cargo("bench --bench bin2") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [RUNNING] [..] (target/release/deps/bin2-[..][EXE]) -", - ) - .with_stdout_contains("test run2 ... bench: [..]") + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test run2 ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -197,10 +236,15 @@ fn bench_multiple_targets() { ) .build(); + // This should not have anything about `run3` in it. p.cargo("bench --bench bin1 --bench bin2") - .with_stdout_contains("test run1 ... bench: [..]") - .with_stdout_contains("test run2 ... bench: [..]") - .with_stdout_does_not_contain("[..]run3[..]") + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] benches/bin1.rs (target/release/deps/bin1-[..][EXE]) +[RUNNING] benches/bin2.rs (target/release/deps/bin2-[..][EXE]) + +"#]]) .run(); } @@ -221,14 +265,22 @@ fn cargo_bench_verbose() { .build(); p.cargo("bench -v hello") - .with_stderr( - "\ -[COMPILING] foo v0.5.0 ([CWD]) + .with_stderr_data(str![[r#" +[COMPILING] foo v0.5.0 ([ROOT]/foo) [RUNNING] `rustc [..] src/main.rs [..]` -[FINISHED] `bench` profile [optimized] target(s) in [..] -[RUNNING] `[..]target/release/deps/foo-[..][EXE] hello --bench`", - ) - .with_stdout_contains("test bench_hello ... bench: [..]") +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] `[..]target/release/deps/foo-[..][EXE] hello --bench` + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test bench_hello ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -269,9 +321,27 @@ fn many_similar_names() { .build(); p.cargo("bench") - .with_stdout_contains("test bin_bench ... bench:[..]") - .with_stdout_contains("test lib_bench ... bench:[..]") - .with_stdout_contains("test bench_bench ... bench:[..]") + .with_stdout_data(str![[r#" + +running 1 test +test lib_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bin_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bench_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -304,22 +374,44 @@ fn cargo_bench_failing_test() { p.cargo("build").run(); assert!(p.bin("foo").is_file()); - p.process(&p.bin("foo")).with_stdout("hello\n").run(); + p.process(&p.bin("foo")) + .with_stdout_data(str![[r#" +hello + +"#]]) + .run(); // Force libtest into serial execution so that the test header will be printed. p.cargo("bench -- --test-threads=1") - .with_stdout_contains("test bench_hello ...[..]") - .with_stderr_contains( - "\ -[COMPILING] foo v0.5.0 ([CWD])[..] -[FINISHED] `bench` profile [optimized] target(s) in [..] -[RUNNING] [..] (target/release/deps/foo-[..][EXE])", - ) - .with_stdout_contains("[..]thread '[..]' panicked at[..]") - .with_stdout_contains("[..]assertion [..]failed[..]") - .with_stdout_contains("[..]left: [..]\"hello\"[..]") - .with_stdout_contains("[..]right: [..]\"nope\"[..]") - .with_stdout_contains("[..]src/main.rs:15[..]") + .with_stderr_data(str![[r#" +[COMPILING] foo v0.5.0 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] [..] (target/release/deps/foo-[..][EXE]) +[ERROR] bench failed, to rerun pass `--bin foo` + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test bench_hello ... FAILED + +failures: + +---- bench_hello stdout ---- +thread 'main' panicked at src/main.rs:15:17: +assertion `left == right` failed + left: "hello" + right: "nope" +[NOTE] run with `RUST_BACKTRACE=1` environment variable to display a backtrace + + +failures: + bench_hello + +test result: FAILED. 0 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .with_status(101) .run(); } @@ -377,15 +469,28 @@ fn bench_with_lib_dep() { .build(); p.cargo("bench") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [RUNNING] [..] (target/release/deps/foo-[..][EXE]) -[RUNNING] [..] (target/release/deps/baz-[..][EXE])", - ) - .with_stdout_contains("test lib_bench ... bench: [..]") - .with_stdout_contains("test bin_bench ... bench: [..]") +[RUNNING] [..] (target/release/deps/baz-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test lib_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bin_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -438,15 +543,23 @@ fn bench_with_deep_lib_dep() { .build(); p.cargo("bench") - .with_stderr( - "\ + .with_stderr_data(str![[r#" [LOCKING] 2 packages to latest compatible versions -[COMPILING] foo v0.0.1 ([..]) -[COMPILING] bar v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] -[RUNNING] [..] (target/release/deps/bar-[..][EXE])", - ) - .with_stdout_contains("test bar_bench ... bench: [..]") +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[COMPILING] bar v0.0.1 ([ROOT]/bar) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] [..] (target/release/deps/bar-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test bar_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -494,15 +607,28 @@ fn external_bench_explicit() { .build(); p.cargo("bench") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [RUNNING] [..] (target/release/deps/foo-[..][EXE]) -[RUNNING] [..] (target/release/deps/bench-[..][EXE])", - ) - .with_stdout_contains("test internal_bench ... bench: [..]") - .with_stdout_contains("test external_bench ... bench: [..]") +[RUNNING] [..] (target/release/deps/bench-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test internal_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test external_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -537,15 +663,28 @@ fn external_bench_implicit() { .build(); p.cargo("bench") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [RUNNING] [..] (target/release/deps/foo-[..][EXE]) -[RUNNING] [..] (target/release/deps/external-[..][EXE])", - ) - .with_stdout_contains("test internal_bench ... bench: [..]") - .with_stdout_contains("test external_bench ... bench: [..]") +[RUNNING] [..] (target/release/deps/external-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test internal_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test external_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -597,9 +736,8 @@ fn bench_autodiscover_2015() { .build(); p.cargo("bench bench_basic") - .with_stderr( - "warning: \ -An explicit [[bench]] section is specified in Cargo.toml which currently + .with_stderr_data(str![[r#" +[WARNING] An explicit [[bench]] section is specified in Cargo.toml which currently disables Cargo from automatically inferring other benchmark targets. This inference behavior will change in the Rust 2018 edition and the following files will be included as a benchmark target: @@ -614,11 +752,11 @@ automatically infer them to be a target, such as in subfolders. For more information on this warning you can consult https://github.com/rust-lang/cargo/issues/5330 -[COMPILING] foo v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [RUNNING] [..] (target/release/deps/foo-[..][EXE]) -", - ) + +"#]]) .run(); } @@ -651,21 +789,38 @@ fn pass_through_command_line() { .build(); p.cargo("bench bar") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] -[RUNNING] [..] (target/release/deps/foo-[..][EXE])", - ) - .with_stdout_contains("test bar ... bench: [..]") + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] [..] (target/release/deps/foo-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test bar ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 1 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); p.cargo("bench foo") - .with_stderr( - "[FINISHED] `bench` profile [optimized] target(s) in [..] -[RUNNING] [..] (target/release/deps/foo-[..][EXE])", - ) - .with_stdout_contains("test foo ... bench: [..]") + .with_stderr_data(str![[r#" +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] [..] (target/release/deps/foo-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test foo ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 1 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -737,14 +892,28 @@ fn lib_bin_same_name() { .build(); p.cargo("bench") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [RUNNING] [..] (target/release/deps/foo-[..][EXE]) -[RUNNING] [..] (target/release/deps/foo-[..][EXE])", - ) - .with_stdout_contains_n("test [..] ... bench: [..]", 2) +[RUNNING] [..] (target/release/deps/foo-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test lib_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bin_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -782,15 +951,28 @@ fn lib_with_standard_name() { .build(); p.cargo("bench") - .with_stderr( - "\ -[COMPILING] syntax v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] + .with_stderr_data(str![[r#" +[COMPILING] syntax v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [RUNNING] [..] (target/release/deps/syntax-[..][EXE]) -[RUNNING] [..] (target/release/deps/bench-[..][EXE])", - ) - .with_stdout_contains("test foo_bench ... bench: [..]") - .with_stdout_contains("test bench ... bench: [..]") +[RUNNING] [..] (target/release/deps/bench-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test foo_bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -831,13 +1013,21 @@ fn lib_with_standard_name2() { .build(); p.cargo("bench") - .with_stderr( - "\ -[COMPILING] syntax v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] -[RUNNING] [..] (target/release/deps/syntax-[..][EXE])", - ) - .with_stdout_contains("test bench ... bench: [..]") + .with_stderr_data(str![[r#" +[COMPILING] syntax v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] [..] (target/release/deps/syntax-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test bench ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -904,33 +1094,61 @@ fn bench_dylib() { .build(); p.cargo("bench -v") - .with_stderr( - "\ + .with_stderr_data(str![[r#" [LOCKING] 2 packages to latest compatible versions -[COMPILING] bar v0.0.1 ([CWD]/bar) +[COMPILING] bar v0.0.1 ([ROOT]/foo/bar) [RUNNING] [..] -C opt-level=3 [..] -[COMPILING] foo v0.0.1 ([CWD]) +[COMPILING] foo v0.0.1 ([ROOT]/foo) [RUNNING] [..] -C opt-level=3 [..] [RUNNING] [..] -C opt-level=3 [..] [RUNNING] [..] -C opt-level=3 [..] -[FINISHED] `bench` profile [optimized] target(s) in [..] +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [RUNNING] `[..]target/release/deps/foo-[..][EXE] --bench` -[RUNNING] `[..]target/release/deps/bench-[..][EXE] --bench`", - ) - .with_stdout_contains_n("test foo ... bench: [..]", 2) +[RUNNING] `[..]target/release/deps/bench-[..][EXE] --bench` + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test foo ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test foo ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); p.root().move_into_the_past(); p.cargo("bench -v") - .with_stderr( - "\ -[FRESH] bar v0.0.1 ([CWD]/bar) -[FRESH] foo v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] + .with_stderr_data(str![[r#" +[FRESH] bar v0.0.1 ([ROOT]/foo/bar) +[FRESH] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [RUNNING] `[..]target/release/deps/foo-[..][EXE] --bench` -[RUNNING] `[..]target/release/deps/bench-[..][EXE] --bench`", - ) - .with_stdout_contains_n("test foo ... bench: [..]", 2) +[RUNNING] `[..]target/release/deps/bench-[..][EXE] --bench` + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test foo ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test foo ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -962,21 +1180,38 @@ fn bench_twice_with_build_cmd() { .build(); p.cargo("bench") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([CWD]) -[FINISHED] `bench` profile [optimized] target(s) in [..] -[RUNNING] [..] (target/release/deps/foo-[..][EXE])", - ) - .with_stdout_contains("test foo ... bench: [..]") + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] [..] (target/release/deps/foo-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test foo ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); p.cargo("bench") - .with_stderr( - "[FINISHED] `bench` profile [optimized] target(s) in [..] -[RUNNING] [..] (target/release/deps/foo-[..][EXE])", - ) - .with_stdout_contains("test foo ... bench: [..]") + .with_stderr_data(str![[r#" +[FINISHED] `bench` profile [optimized] target(s) in [..] +[RUNNING] [..] (target/release/deps/foo-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test foo ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -1049,18 +1284,31 @@ fn bench_with_examples() { .build(); p.cargo("bench -v") - .with_stderr( - "\ -[COMPILING] foo v6.6.6 ([CWD]) + .with_stderr_data(str![[r#" +[COMPILING] foo v6.6.6 ([ROOT]/foo) [RUNNING] `rustc [..]` [RUNNING] `rustc [..]` [RUNNING] `rustc [..]` -[FINISHED] `bench` profile [optimized] target(s) in [..] -[RUNNING] `[CWD]/target/release/deps/foo-[..][EXE] --bench` -[RUNNING] `[CWD]/target/release/deps/testb1-[..][EXE] --bench`", - ) - .with_stdout_contains("test bench_bench1 ... bench: [..]") - .with_stdout_contains("test bench_bench2 ... bench: [..]") +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] `[ROOT]/foo/target/release/deps/foo-[..][EXE] --bench` +[RUNNING] `[ROOT]/foo/target/release/deps/testb1-[..][EXE] --bench` + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test bench_bench1 ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bench_bench2 ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -1091,13 +1339,21 @@ fn test_a_bench() { .build(); p.cargo("test") - .with_stderr( - "\ -[COMPILING] foo v0.1.0 ([..]) -[FINISHED] `test` profile [unoptimized + debuginfo] target(s) in [..] -[RUNNING] [..] (target/debug/deps/b-[..][EXE])", - ) - .with_stdout_contains("test foo ... ok") + .with_stderr_data(str![[r#" +[COMPILING] foo v0.1.0 ([ROOT]/foo) +[FINISHED] `test` profile [unoptimized + debuginfo] target(s) in [ELAPSED]s +[RUNNING] [..] (target/debug/deps/b-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 1 test +test foo ... ok + +test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -1121,14 +1377,13 @@ fn test_bench_no_run() { .build(); p.cargo("bench --no-run") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([..]) -[FINISHED] `bench` profile [optimized] target(s) in [..] + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s [EXECUTABLE] benches src/lib.rs (target/release/deps/foo-[..][EXE]) [EXECUTABLE] benches/bbaz.rs (target/release/deps/bbaz-[..][EXE]) -", - ) + +"#]]) .run(); } @@ -1152,12 +1407,11 @@ fn test_bench_no_run_emit_json() { .build(); p.cargo("bench --no-run --message-format json") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([..]) -[FINISHED] `bench` profile [optimized] target(s) in [..] -", - ) + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s + +"#]]) .run(); } @@ -1203,23 +1457,60 @@ fn test_bench_no_fail_fast() { p.cargo("bench --no-fail-fast -- --test-threads=1") .with_status(101) - .with_stderr( - "\ -[COMPILING] foo v0.5.0 [..] -[FINISHED] `bench` profile [..] -[RUNNING] unittests src/main.rs (target/release/deps/foo[..]) + .with_stderr_data(str![[r#" +[COMPILING] foo v0.5.0 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] unittests src/main.rs (target/release/deps/foo-[..][EXE]) [ERROR] bench failed, to rerun pass `--bin foo` -[RUNNING] benches/b1.rs (target/release/deps/b1[..]) +[RUNNING] benches/b1.rs (target/release/deps/b1-[..][EXE]) [ERROR] bench failed, to rerun pass `--bench b1` [ERROR] 2 targets failed: `--bin foo` `--bench b1` -", - ) - .with_stdout_contains("running 2 tests") - .with_stdout_contains("test bench_hello [..]") - .with_stdout_contains("test bench_nope [..]") - .with_stdout_contains("test b1_fail [..]") + +"#]]) + .with_stdout_data(str![[r#" + +running 2 tests +test bench_hello ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) +test bench_nope ... FAILED + +failures: + +---- bench_nope stdout ---- +thread 'main' panicked at src/main.rs:20:17: +assertion `left == right` failed + left: "nope" + right: "hello" +[NOTE] run with `RUST_BACKTRACE=1` environment variable to display a backtrace + + +failures: + bench_nope + +test result: FAILED. 0 passed; 1 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test b1_fail ... FAILED + +failures: + +---- b1_fail stdout ---- +thread 'main' panicked at benches/b1.rs:5:54: +assertion `left == right` failed + left: 1 + right: 2 +[NOTE] run with `RUST_BACKTRACE=1` environment variable to display a backtrace + + +failures: + b1_fail + +test result: FAILED. 0 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -1308,10 +1599,25 @@ fn test_bench_multiple_packages() { .build(); p.cargo("bench -p bar -p baz") - .with_stderr_contains("[RUNNING] [..] (target/release/deps/bbaz-[..][EXE])") - .with_stdout_contains("test bench_baz ... bench: [..]") - .with_stderr_contains("[RUNNING] [..] (target/release/deps/bbar-[..][EXE])") - .with_stdout_contains("test bench_bar ... bench: [..]") + .with_stderr_data(str![[r#" +[RUNNING] [..] (target/release/deps/bbaz-[..][EXE]) +[RUNNING] [..] (target/release/deps/bbar-[..][EXE]) + +"#]]) + .with_stderr_data( + str![[r#" +[LOCKING] 3 packages to latest compatible versions +[COMPILING] bar v0.1.0 ([ROOT]/bar) +[COMPILING] baz v0.1.0 ([ROOT]/baz) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] unittests src/lib.rs (target/release/deps/bar-[..][EXE]) +[RUNNING] benches/bbar.rs (target/release/deps/bbar-[..][EXE]) +[RUNNING] unittests src/lib.rs (target/release/deps/baz-[..][EXE]) +[RUNNING] benches/bbaz.rs (target/release/deps/bbaz-[..][EXE]) + +"#]] + .unordered(), + ) .run(); } @@ -1362,10 +1668,42 @@ fn bench_all_workspace() { .build(); p.cargo("bench --workspace") - .with_stderr_contains("[RUNNING] [..] (target/release/deps/bar-[..][EXE])") - .with_stdout_contains("test bench_bar ... bench: [..]") - .with_stderr_contains("[RUNNING] [..] (target/release/deps/foo-[..][EXE])") - .with_stdout_contains("test bench_foo ... bench: [..]") + .with_stderr_data(str![[r#" +[LOCKING] 2 packages to latest compatible versions +[COMPILING] bar v0.1.0 ([ROOT]/foo/bar) +[COMPILING] foo v0.1.0 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] unittests src/lib.rs (target/release/deps/bar-[..][EXE]) +[RUNNING] benches/bar.rs (target/release/deps/bar-[..][EXE]) +[RUNNING] unittests src/main.rs (target/release/deps/foo-[..][EXE]) +[RUNNING] benches/foo.rs (target/release/deps/foo-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 0 tests + +test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bench_bar ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 0 tests + +test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bench_foo ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -1407,11 +1745,20 @@ fn bench_all_exclude() { .build(); p.cargo("bench --workspace --exclude baz") - .with_stdout_contains( - "\ + .with_stdout_data(str![[r#" + running 1 test -test bar ... bench: [..] ns/iter (+/- [..])", - ) +test bar ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 0 tests + +test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -1453,11 +1800,20 @@ fn bench_all_exclude_glob() { .build(); p.cargo("bench --workspace --exclude '*z'") - .with_stdout_contains( - "\ + .with_stdout_data(str![[r#" + running 1 test -test bar ... bench: [..] ns/iter (+/- [..])", - ) +test bar ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 0 tests + +test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -1503,10 +1859,45 @@ fn bench_all_virtual_manifest() { // The order in which bar and baz are built is not guaranteed p.cargo("bench --workspace") - .with_stderr_contains("[RUNNING] [..] (target/release/deps/baz-[..][EXE])") - .with_stdout_contains("test bench_baz ... bench: [..]") - .with_stderr_contains("[RUNNING] [..] (target/release/deps/bar-[..][EXE])") - .with_stdout_contains("test bench_bar ... bench: [..]") + .with_stderr_data( + str![[r#" +[LOCKING] 2 packages to latest compatible versions +[COMPILING] bar v0.1.0 ([ROOT]/foo/bar) +[COMPILING] baz v0.1.0 ([ROOT]/foo/baz) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] unittests src/lib.rs (target/release/deps/bar-[..][EXE]) +[RUNNING] benches/bar.rs (target/release/deps/bar-[..][EXE]) +[RUNNING] unittests src/lib.rs (target/release/deps/baz-[..][EXE]) +[RUNNING] benches/baz.rs (target/release/deps/baz-[..][EXE]) + +"#]] + .unordered(), + ) + .with_stdout_data(str![[r#" + +running 0 tests + +test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bench_bar ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 0 tests + +test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bench_baz ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -1550,12 +1941,30 @@ fn bench_virtual_manifest_glob() { ) .build(); - // The order in which bar and baz are built is not guaranteed + // This should not have `bar` built or benched p.cargo("bench -p '*z'") - .with_stderr_contains("[RUNNING] [..] (target/release/deps/baz-[..][EXE])") - .with_stdout_contains("test bench_baz ... bench: [..]") - .with_stderr_does_not_contain("[RUNNING] [..] (target/release/deps/bar-[..][EXE])") - .with_stdout_does_not_contain("test bench_bar ... bench: [..]") + .with_stderr_data(str![[r#" +[LOCKING] 2 packages to latest compatible versions +[COMPILING] baz v0.1.0 ([ROOT]/foo/baz) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] unittests src/lib.rs (target/release/deps/baz-[..][EXE]) +[RUNNING] benches/baz.rs (target/release/deps/baz-[..][EXE]) + +"#]]) + .with_stdout_data(str![[r#" + +running 0 tests + +test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bench_baz ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -1591,11 +2000,15 @@ fn legacy_bench_name() { .build(); p.cargo("bench") - .with_stderr_contains( - "\ -[WARNING] path `[..]src/bench.rs` was erroneously implicitly accepted for benchmark `bench`, -please set bench.path in Cargo.toml", - ) + .with_stderr_data(str![[r#" +[WARNING] path `src/bench.rs` was erroneously implicitly accepted for benchmark `bench`, +please set bench.path in Cargo.toml +[COMPILING] foo v0.1.0 ([ROOT]/foo) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] unittests src/lib.rs (target/release/deps/foo-[..][EXE]) +[RUNNING] src/bench.rs (target/release/deps/bench-[..][EXE]) + +"#]]) .run(); } @@ -1638,10 +2051,45 @@ fn bench_virtual_manifest_all_implied() { // The order in which bar and baz are built is not guaranteed p.cargo("bench") - .with_stderr_contains("[RUNNING] [..] (target/release/deps/baz-[..][EXE])") - .with_stdout_contains("test bench_baz ... bench: [..]") - .with_stderr_contains("[RUNNING] [..] (target/release/deps/bar-[..][EXE])") - .with_stdout_contains("test bench_bar ... bench: [..]") + .with_stderr_data( + str![[r#" +[LOCKING] 2 packages to latest compatible versions +[COMPILING] bar v0.1.0 ([ROOT]/foo/bar) +[COMPILING] baz v0.1.0 ([ROOT]/foo/baz) +[FINISHED] `bench` profile [optimized] target(s) in [ELAPSED]s +[RUNNING] unittests src/lib.rs (target/release/deps/bar-[..][EXE]) +[RUNNING] benches/bar.rs (target/release/deps/bar-[..][EXE]) +[RUNNING] unittests src/lib.rs (target/release/deps/baz-[..][EXE]) +[RUNNING] benches/baz.rs (target/release/deps/baz-[..][EXE]) + +"#]] + .unordered(), + ) + .with_stdout_data(str![[r#" + +running 0 tests + +test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bench_bar ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +running 0 tests + +test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in [ELAPSED]s + + +running 1 test +test bench_baz ... bench: [AVG_ELAPSED] ns/iter (+/- [JITTER]) + +test result: ok. 0 passed; 0 failed; 0 ignored; 1 measured; 0 filtered out; finished in [ELAPSED]s + + +"#]]) .run(); } @@ -1663,31 +2111,13 @@ fn json_artifact_includes_executable_for_benchmark() { .build(); p.cargo("bench --no-run --message-format=json") - .with_json( - r#" - { - "executable": "[..]/foo/target/release/deps/benchmark-[..][EXE]", - "features": [], - "filenames": "{...}", - "fresh": false, - "package_id": "path+file:///[..]/foo#0.0.1", - "manifest_path": "[..]", - "profile": "{...}", - "reason": "compiler-artifact", - "target": { - "crate_types": [ "bin" ], - "kind": [ "bench" ], - "doc": false, - "doctest": false, - "edition": "2015", - "name": "benchmark", - "src_path": "[..]/foo/benches/benchmark.rs", - "test": false - } - } + .with_stdout_data( + str![[r#" +{"executable":"[ROOT]/foo/target/release/deps/benchmark-[..][EXE]","features":[],"filenames":"{...}","fresh":false,"manifest_path":"[ROOT]/foo/Cargo.toml","package_id":"path+[ROOTURL]/foo#0.0.1","profile":"{...}","reason":"compiler-artifact","target":{"crate_types":["bin"],"doc":false,"doctest":false,"edition":"2015","kind":["bench"],"name":"benchmark","src_path":"[ROOT]/foo/benches/benchmark.rs","test":false}} +{"reason":"build-finished","success":true} - {"reason": "build-finished", "success": true} - "#, +"#]] + .json_lines(), ) .run(); } @@ -1719,12 +2149,12 @@ fn cargo_bench_print_env_verbose() { ) .build(); p.cargo("bench -vv") - .with_stderr( - "\ -[COMPILING] foo v0.0.1 ([CWD]) -[RUNNING] `[..]CARGO_MANIFEST_DIR=[CWD][..] rustc[..]` + .with_stderr_data(str![[r#" +[COMPILING] foo v0.0.1 ([ROOT]/foo) +[RUNNING] `[..]CARGO_MANIFEST_DIR=[ROOT]/foo[..] rustc[..]` [FINISHED] `bench` profile [optimized] target(s) in [..] -[RUNNING] `[..]CARGO_MANIFEST_DIR=[CWD][..] [CWD]/target/release/deps/foo-[..][EXE] --bench`", - ) +[RUNNING] `[..]CARGO_MANIFEST_DIR=[ROOT]/foo[..] [ROOT]/foo/target/release/deps/foo-[..][EXE] --bench` + +"#]]) .run(); }