[INFO] fetching crate galvanic-assert 0.8.7... [INFO] checking galvanic-assert-0.8.7 against try#8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8 for pr-82565 [INFO] extracting crate galvanic-assert 0.8.7 into /workspace/builds/worker-3/source [INFO] validating manifest of crates.io crate galvanic-assert 0.8.7 on toolchain 8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking crates.io crate galvanic-assert 0.8.7 [INFO] finished tweaking crates.io crate galvanic-assert 0.8.7 [INFO] tweaked toml for crates.io crate galvanic-assert 0.8.7 written to /workspace/builds/worker-3/source/Cargo.toml [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update", kill_on_drop: false }` [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "rustops/crates-build-env@sha256:f2f6bcd4b43ebee4e173f653a26493129bdb64017c85f916b780ca7fbdbaa79d" "/opt/rustwide/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 523eb644cbd1e51d1e7a12ac4a4301ef27d0f77327ebf7d272b5550cd16391be [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "523eb644cbd1e51d1e7a12ac4a4301ef27d0f77327ebf7d272b5550cd16391be", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "523eb644cbd1e51d1e7a12ac4a4301ef27d0f77327ebf7d272b5550cd16391be", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "523eb644cbd1e51d1e7a12ac4a4301ef27d0f77327ebf7d272b5550cd16391be", kill_on_drop: false }` [INFO] [stdout] 523eb644cbd1e51d1e7a12ac4a4301ef27d0f77327ebf7d272b5550cd16391be [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "rustops/crates-build-env@sha256:f2f6bcd4b43ebee4e173f653a26493129bdb64017c85f916b780ca7fbdbaa79d" "/opt/rustwide/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 8e618526f7dc352a7752886267b74c2f9234c8dfad2b578ff80b892c881de350 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "8e618526f7dc352a7752886267b74c2f9234c8dfad2b578ff80b892c881de350", kill_on_drop: false }` [INFO] [stderr] Checking galvanic-assert v0.8.7 (/opt/rustwide/workdir) [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:43:52 [INFO] [stdout] | [INFO] [stdout] 43 | pub fn assertion_always_succeeds<'a,T:'a>() -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:55:36 [INFO] [stdout] | [INFO] [stdout] 55 | pub fn any_value<'a,T:'a>() -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:71:49 [INFO] [stdout] | [INFO] [stdout] 71 | pub fn assertion_always_fails<'a,T:'a>() -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:88:35 [INFO] [stdout] | [INFO] [stdout] 88 | pub fn no_value<'a,T:'a>() -> Box + 'a> { assertion_always_fails() } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:101:34 [INFO] [stdout] | [INFO] [stdout] 101 | pub fn is<'a, T:'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:101:62 [INFO] [stdout] | [INFO] [stdout] 101 | pub fn is<'a, T:'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:117:35 [INFO] [stdout] | [INFO] [stdout] 117 | pub fn has<'a, T:'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:117:63 [INFO] [stdout] | [INFO] [stdout] 117 | pub fn has<'a, T:'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:130:36 [INFO] [stdout] | [INFO] [stdout] 130 | pub fn not<'a, T: 'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:130:64 [INFO] [stdout] | [INFO] [stdout] 130 | pub fn not<'a, T: 'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:154:44 [INFO] [stdout] | [INFO] [stdout] 154 | pub fn equal_to<'a, T>(expected: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:170:62 [INFO] [stdout] | [INFO] [stdout] 170 | pub fn eq<'a, T: PartialEq + Debug + 'a>(expected: T) -> Box + 'a> { equal_to(expected) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:183:45 [INFO] [stdout] | [INFO] [stdout] 183 | pub fn less_than<'a, T>(expected: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:198:63 [INFO] [stdout] | [INFO] [stdout] 198 | pub fn lt<'a, T: PartialOrd + Debug + 'a>(expected: T) -> Box + 'a> { less_than(expected) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:211:48 [INFO] [stdout] | [INFO] [stdout] 211 | pub fn greater_than<'a, T>(expected: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:226:63 [INFO] [stdout] | [INFO] [stdout] 226 | pub fn gt<'a, T: PartialOrd + Debug + 'a>(expected: T) -> Box + 'a> { greater_than(expected) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:240:54 [INFO] [stdout] | [INFO] [stdout] 240 | pub fn less_than_or_equal<'a, T>(expected: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:256:64 [INFO] [stdout] | [INFO] [stdout] 256 | pub fn leq<'a, T: PartialOrd + Debug + 'a>(expected: T) -> Box + 'a> { less_than_or_equal(expected) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:270:57 [INFO] [stdout] | [INFO] [stdout] 270 | pub fn greater_than_or_equal<'a, T>(expected: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:286:64 [INFO] [stdout] | [INFO] [stdout] 286 | pub fn geq<'a, T: PartialOrd + Debug + 'a>(expected: T) -> Box + 'a> { greater_than_or_equal(expected) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:299:52 [INFO] [stdout] | [INFO] [stdout] 299 | pub fn close_to<'a, T>(expected: T, eps: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:334:51 [INFO] [stdout] | [INFO] [stdout] 334 | pub fn same_object<'a, T>(expected: &'a T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:49:22 [INFO] [stdout] | [INFO] [stdout] 49 | pub matcher: Box + 'a>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:55:28 [INFO] [stdout] | [INFO] [stdout] 55 | pub fn of(matcher: Box + 'a>) -> All<'a,T> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:63:35 [INFO] [stdout] | [INFO] [stdout] 63 | pub fn and(self, matcher: Box + 'a>) -> All<'a,T> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:116:22 [INFO] [stdout] | [INFO] [stdout] 116 | pub matcher: Box + 'a>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:122:28 [INFO] [stdout] | [INFO] [stdout] 122 | pub fn of(matcher: Box + 'a>) -> Any<'a,T> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:130:34 [INFO] [stdout] | [INFO] [stdout] 130 | pub fn or(self, matcher: Box + 'a>) -> Any<'a,T> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:67:43 [INFO] [stdout] | [INFO] [stdout] 67 | pub fn maybe_some<'a, T: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:67:71 [INFO] [stdout] | [INFO] [stdout] 67 | pub fn maybe_some<'a, T: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,Option> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:88:48 [INFO] [stdout] | [INFO] [stdout] 88 | pub fn maybe_ok<'a, T: 'a, E: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:88:76 [INFO] [stdout] | [INFO] [stdout] 88 | pub fn maybe_ok<'a, T: 'a, E: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,Result> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:109:49 [INFO] [stdout] | [INFO] [stdout] 109 | pub fn maybe_err<'a, T: 'a, E: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,E> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:109:77 [INFO] [stdout] | [INFO] [stdout] 109 | pub fn maybe_err<'a, T: 'a, E: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,Result> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:47:78 [INFO] [stdout] | [INFO] [stdout] 47 | pub fn contains_in_any_order<'a,T:'a,I:'a,J:'a>(expected_elements: I) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,J> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:109:74 [INFO] [stdout] | [INFO] [stdout] 109 | pub fn contains_in_order<'a,T:'a,I:'a,J:'a>(expected_elements: I) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,J> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:166:72 [INFO] [stdout] | [INFO] [stdout] 166 | pub fn contains_subset<'a,T:'a,I:'a,J:'a>(expected_elements: I) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,J> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:214:63 [INFO] [stdout] | [INFO] [stdout] 214 | pub fn contained_in<'a,T:'a,I>(expected_to_contain: I) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:248:88 [INFO] [stdout] | [INFO] [stdout] 248 | pub fn sorted_by<'a,T,I,P>(predicate: P, expected_ordering: std::cmp::Ordering) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:289:97 [INFO] [stdout] | [INFO] [stdout] 289 | pub fn sorted_strictly_by<'a,T,I,P>(predicate: P, expected_ordering: std::cmp::Ordering) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:329:62 [INFO] [stdout] | [INFO] [stdout] 329 | pub fn sorted_by_in_any_order<'a,T,I,P>(predicate: P) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:375:71 [INFO] [stdout] | [INFO] [stdout] 375 | pub fn sorted_strictly_by_in_any_order<'a,T,I,P>(predicate: P) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:422:42 [INFO] [stdout] | [INFO] [stdout] 422 | pub fn sorted_ascending<'a,T,I>() -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:439:51 [INFO] [stdout] | [INFO] [stdout] 439 | pub fn sorted_strictly_ascending<'a,T,I>() -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:456:43 [INFO] [stdout] | [INFO] [stdout] 456 | pub fn sorted_descending<'a,T,I>() -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:473:52 [INFO] [stdout] | [INFO] [stdout] 473 | pub fn sorted_strictly_descending<'a,T,I>() -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:490:60 [INFO] [stdout] | [INFO] [stdout] 490 | pub fn all_elements_satisfy<'a,T,I,P>(predicate: P) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:518:61 [INFO] [stdout] | [INFO] [stdout] 518 | pub fn some_elements_satisfy<'a,T,I,P>(predicate: P) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:566:62 [INFO] [stdout] | [INFO] [stdout] 566 | pub fn has_entry<'a,K:'a,V:'a,M:'a>(key: K, value: V) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,M> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:637:50 [INFO] [stdout] | [INFO] [stdout] 637 | pub fn has_key<'a,K:'a,V:'a,M:'a>(key: K) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,M> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:690:52 [INFO] [stdout] | [INFO] [stdout] 690 | pub fn has_value<'a,K:'a,V:'a,M:'a>(key: K) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,M> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:43:52 [INFO] [stdout] | [INFO] [stdout] 43 | pub fn assertion_always_succeeds<'a,T:'a>() -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:55:36 [INFO] [stdout] | [INFO] [stdout] 55 | pub fn any_value<'a,T:'a>() -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:71:49 [INFO] [stdout] | [INFO] [stdout] 71 | pub fn assertion_always_fails<'a,T:'a>() -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:88:35 [INFO] [stdout] | [INFO] [stdout] 88 | pub fn no_value<'a,T:'a>() -> Box + 'a> { assertion_always_fails() } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:101:34 [INFO] [stdout] | [INFO] [stdout] 101 | pub fn is<'a, T:'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:101:62 [INFO] [stdout] | [INFO] [stdout] 101 | pub fn is<'a, T:'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:117:35 [INFO] [stdout] | [INFO] [stdout] 117 | pub fn has<'a, T:'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:117:63 [INFO] [stdout] | [INFO] [stdout] 117 | pub fn has<'a, T:'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:130:36 [INFO] [stdout] | [INFO] [stdout] 130 | pub fn not<'a, T: 'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:130:64 [INFO] [stdout] | [INFO] [stdout] 130 | pub fn not<'a, T: 'a>(matcher: Box + 'a>) -> Box + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:154:44 [INFO] [stdout] | [INFO] [stdout] 154 | pub fn equal_to<'a, T>(expected: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:170:62 [INFO] [stdout] | [INFO] [stdout] 170 | pub fn eq<'a, T: PartialEq + Debug + 'a>(expected: T) -> Box + 'a> { equal_to(expected) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:183:45 [INFO] [stdout] | [INFO] [stdout] 183 | pub fn less_than<'a, T>(expected: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:198:63 [INFO] [stdout] | [INFO] [stdout] 198 | pub fn lt<'a, T: PartialOrd + Debug + 'a>(expected: T) -> Box + 'a> { less_than(expected) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:211:48 [INFO] [stdout] | [INFO] [stdout] 211 | pub fn greater_than<'a, T>(expected: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:226:63 [INFO] [stdout] | [INFO] [stdout] 226 | pub fn gt<'a, T: PartialOrd + Debug + 'a>(expected: T) -> Box + 'a> { greater_than(expected) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:240:54 [INFO] [stdout] | [INFO] [stdout] 240 | pub fn less_than_or_equal<'a, T>(expected: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:256:64 [INFO] [stdout] | [INFO] [stdout] 256 | pub fn leq<'a, T: PartialOrd + Debug + 'a>(expected: T) -> Box + 'a> { less_than_or_equal(expected) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:270:57 [INFO] [stdout] | [INFO] [stdout] 270 | pub fn greater_than_or_equal<'a, T>(expected: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:286:64 [INFO] [stdout] | [INFO] [stdout] 286 | pub fn geq<'a, T: PartialOrd + Debug + 'a>(expected: T) -> Box + 'a> { greater_than_or_equal(expected) } [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:299:52 [INFO] [stdout] | [INFO] [stdout] 299 | pub fn close_to<'a, T>(expected: T, eps: T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/core.rs:334:51 [INFO] [stdout] | [INFO] [stdout] 334 | pub fn same_object<'a, T>(expected: &'a T) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:49:22 [INFO] [stdout] | [INFO] [stdout] 49 | pub matcher: Box + 'a>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:55:28 [INFO] [stdout] | [INFO] [stdout] 55 | pub fn of(matcher: Box + 'a>) -> All<'a,T> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:63:35 [INFO] [stdout] | [INFO] [stdout] 63 | pub fn and(self, matcher: Box + 'a>) -> All<'a,T> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:116:22 [INFO] [stdout] | [INFO] [stdout] 116 | pub matcher: Box + 'a>, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:122:28 [INFO] [stdout] | [INFO] [stdout] 122 | pub fn of(matcher: Box + 'a>) -> Any<'a,T> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/combinators.rs:130:34 [INFO] [stdout] | [INFO] [stdout] 130 | pub fn or(self, matcher: Box + 'a>) -> Any<'a,T> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:67:43 [INFO] [stdout] | [INFO] [stdout] 67 | pub fn maybe_some<'a, T: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:67:71 [INFO] [stdout] | [INFO] [stdout] 67 | pub fn maybe_some<'a, T: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,Option> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:88:48 [INFO] [stdout] | [INFO] [stdout] 88 | pub fn maybe_ok<'a, T: 'a, E: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:88:76 [INFO] [stdout] | [INFO] [stdout] 88 | pub fn maybe_ok<'a, T: 'a, E: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,Result> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:109:49 [INFO] [stdout] | [INFO] [stdout] 109 | pub fn maybe_err<'a, T: 'a, E: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,E> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/variant.rs:109:77 [INFO] [stdout] | [INFO] [stdout] 109 | pub fn maybe_err<'a, T: 'a, E: 'a>(matcher: Box + 'a>) -> Box> + 'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,Result> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:47:78 [INFO] [stdout] | [INFO] [stdout] 47 | pub fn contains_in_any_order<'a,T:'a,I:'a,J:'a>(expected_elements: I) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,J> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:109:74 [INFO] [stdout] | [INFO] [stdout] 109 | pub fn contains_in_order<'a,T:'a,I:'a,J:'a>(expected_elements: I) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,J> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:166:72 [INFO] [stdout] | [INFO] [stdout] 166 | pub fn contains_subset<'a,T:'a,I:'a,J:'a>(expected_elements: I) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,J> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:214:63 [INFO] [stdout] | [INFO] [stdout] 214 | pub fn contained_in<'a,T:'a,I>(expected_to_contain: I) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,T> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:248:88 [INFO] [stdout] | [INFO] [stdout] 248 | pub fn sorted_by<'a,T,I,P>(predicate: P, expected_ordering: std::cmp::Ordering) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:289:97 [INFO] [stdout] | [INFO] [stdout] 289 | pub fn sorted_strictly_by<'a,T,I,P>(predicate: P, expected_ordering: std::cmp::Ordering) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:329:62 [INFO] [stdout] | [INFO] [stdout] 329 | pub fn sorted_by_in_any_order<'a,T,I,P>(predicate: P) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:375:71 [INFO] [stdout] | [INFO] [stdout] 375 | pub fn sorted_strictly_by_in_any_order<'a,T,I,P>(predicate: P) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:422:42 [INFO] [stdout] | [INFO] [stdout] 422 | pub fn sorted_ascending<'a,T,I>() -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:439:51 [INFO] [stdout] | [INFO] [stdout] 439 | pub fn sorted_strictly_ascending<'a,T,I>() -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:456:43 [INFO] [stdout] | [INFO] [stdout] 456 | pub fn sorted_descending<'a,T,I>() -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:473:52 [INFO] [stdout] | [INFO] [stdout] 473 | pub fn sorted_strictly_descending<'a,T,I>() -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:490:60 [INFO] [stdout] | [INFO] [stdout] 490 | pub fn all_elements_satisfy<'a,T,I,P>(predicate: P) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:518:61 [INFO] [stdout] | [INFO] [stdout] 518 | pub fn some_elements_satisfy<'a,T,I,P>(predicate: P) -> Box MatchResult> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(&'a I) -> MatchResult` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:566:62 [INFO] [stdout] | [INFO] [stdout] 566 | pub fn has_entry<'a,K:'a,V:'a,M:'a>(key: K, value: V) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,M> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:637:50 [INFO] [stdout] | [INFO] [stdout] 637 | pub fn has_key<'a,K:'a,V:'a,M:'a>(key: K) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,M> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/collection.rs:690:52 [INFO] [stdout] | [INFO] [stdout] 690 | pub fn has_value<'a,K:'a,V:'a,M:'a>(key: K) -> Box + 'a> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Matcher<'a,M> + 'a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 51 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 51 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused comparison that must be used [INFO] [stdout] --> tests/expectations.rs:91:42 [INFO] [stdout] | [INFO] [stdout] 91 | let e = get_expectation_for!(1 == 1, panics); [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused comparison that must be used [INFO] [stdout] --> tests/expectations.rs:101:42 [INFO] [stdout] | [INFO] [stdout] 101 | let e = get_expectation_for!(1 == 1, does not panic); [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused comparison that must be used [INFO] [stdout] --> tests/expectations.rs:178:26 [INFO] [stdout] | [INFO] [stdout] 178 | expect_that!(1 == 1, panics); [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused comparison that must be used [INFO] [stdout] --> tests/expectations.rs:187:26 [INFO] [stdout] | [INFO] [stdout] 187 | expect_that!(1 == 1, does not panic); [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 4 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused arithmetic operation that must be used [INFO] [stdout] --> tests/core_matchers.rs:34:26 [INFO] [stdout] | [INFO] [stdout] 34 | assert_that!(&1+1, panics); [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused arithmetic operation that must be used [INFO] [stdout] --> tests/core_matchers.rs:45:22 [INFO] [stdout] | [INFO] [stdout] 45 | assert_that!(&1+1, does not panic); [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 2 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 1.77s [INFO] running `Command { std: "docker" "inspect" "8e618526f7dc352a7752886267b74c2f9234c8dfad2b578ff80b892c881de350", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8e618526f7dc352a7752886267b74c2f9234c8dfad2b578ff80b892c881de350", kill_on_drop: false }` [INFO] [stdout] 8e618526f7dc352a7752886267b74c2f9234c8dfad2b578ff80b892c881de350