[INFO] fetching crate http_desync_guardian 0.1.3... [INFO] testing http_desync_guardian-0.1.3 against master#cdb45c87e2cd43495379f7e867e3cc15dcee9f93 for pr-145838-1 [INFO] extracting crate http_desync_guardian 0.1.3 into /workspace/builds/worker-7-tc1/source [INFO] started tweaking crates.io crate http_desync_guardian 0.1.3 [INFO] finished tweaking crates.io crate http_desync_guardian 0.1.3 [INFO] tweaked toml for crates.io crate http_desync_guardian 0.1.3 written to /workspace/builds/worker-7-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate http_desync_guardian 0.1.3 on toolchain cdb45c87e2cd43495379f7e867e3cc15dcee9f93 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Locking 84 packages to latest compatible versions [INFO] [stderr] Adding criterion v0.3.6 (available: v0.7.0) [INFO] [stderr] Adding strum v0.18.0 (available: v0.27.2) [INFO] [stderr] Adding strum_macros v0.18.0 (available: v0.27.2) [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/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" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] bbad76a0aa74ecab2e9a68db7cb01be114570b2bfcc237b415b6de8723b42651 [INFO] running `Command { std: "docker" "start" "-a" "bbad76a0aa74ecab2e9a68db7cb01be114570b2bfcc237b415b6de8723b42651", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "bbad76a0aa74ecab2e9a68db7cb01be114570b2bfcc237b415b6de8723b42651", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "bbad76a0aa74ecab2e9a68db7cb01be114570b2bfcc237b415b6de8723b42651", kill_on_drop: false }` [INFO] [stdout] bbad76a0aa74ecab2e9a68db7cb01be114570b2bfcc237b415b6de8723b42651 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/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" "RUSTDOCFLAGS=--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" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 1a953a66b2c5c36e99c5d58698f74bb31f2a9012f280a0e560433b5e5ff599dc [INFO] running `Command { std: "docker" "start" "-a" "1a953a66b2c5c36e99c5d58698f74bb31f2a9012f280a0e560433b5e5ff599dc", kill_on_drop: false }` [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling http_desync_guardian v0.1.3 (/opt/rustwide/workdir) [INFO] [stderr] Compiling strum v0.18.0 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling heck v0.3.3 [INFO] [stderr] Compiling strum_macros v0.18.0 [INFO] [stdout] warning: use of deprecated method `std::sync::atomic::AtomicPtr::::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead [INFO] [stdout] --> src/metrics.rs:85:14 [INFO] [stdout] | [INFO] [stdout] 85 | .compare_and_swap( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/lib.rs:222:22 [INFO] [stdout] | [INFO] [stdout] 222 | fn as_http_token(&self, name: &'static str) -> HttpToken { [INFO] [stdout] | ^^^^^ ^^^^^^^^^ the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 222 | fn as_http_token(&self, name: &'static str) -> HttpToken<'_> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/http_token_utils.rs:23:28 [INFO] [stdout] | [INFO] [stdout] 23 | pub const fn http_token(v: &str) -> HttpToken { [INFO] [stdout] | ^^^^ ^^^^^^^^^ the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 23 | pub const fn http_token(v: &str) -> HttpToken<'_> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/http_token_utils.rs:267:25 [INFO] [stdout] | [INFO] [stdout] 267 | pub fn parse_num(value: HttpToken) -> Result { [INFO] [stdout] | ^^^^^^^^^ ^^^^ the same lifetime is elided here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is hidden here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 267 | pub fn parse_num(value: HttpToken<'_>) -> Result { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing [INFO] [stdout] --> src/request_analyzer.rs:148:44 [INFO] [stdout] | [INFO] [stdout] 148 | fn parse(buf: HttpToken<'a>) -> (Self, RequestAnalysisState) { [INFO] [stdout] | -- ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is named here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: consistently use `'a` [INFO] [stdout] | [INFO] [stdout] 148 | fn parse(buf: HttpToken<'a>) -> (Self, RequestAnalysisState<'a>) { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 4.06s [INFO] running `Command { std: "docker" "inspect" "1a953a66b2c5c36e99c5d58698f74bb31f2a9012f280a0e560433b5e5ff599dc", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "1a953a66b2c5c36e99c5d58698f74bb31f2a9012f280a0e560433b5e5ff599dc", kill_on_drop: false }` [INFO] [stdout] 1a953a66b2c5c36e99c5d58698f74bb31f2a9012f280a0e560433b5e5ff599dc [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/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" "RUSTDOCFLAGS=--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" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] d28adb0a84828b26920d9498aad93f0a0e44aa0ad591c1c0416cf2233fc511aa [INFO] running `Command { std: "docker" "start" "-a" "d28adb0a84828b26920d9498aad93f0a0e44aa0ad591c1c0416cf2233fc511aa", kill_on_drop: false }` [INFO] [stderr] Compiling syn v2.0.106 [INFO] [stderr] Compiling libc v0.2.175 [INFO] [stderr] Compiling csv-core v0.1.12 [INFO] [stderr] Compiling regex-automata v0.4.10 [INFO] [stderr] Compiling textwrap v0.11.0 [INFO] [stderr] Compiling half v1.8.3 [INFO] [stderr] Compiling unicode_categories v0.1.1 [INFO] [stderr] Compiling criterion-plot v0.4.5 [INFO] [stderr] Compiling tinytemplate v1.2.1 [INFO] [stderr] Compiling yaml-rust v0.4.5 [INFO] [stdout] warning: use of deprecated method `std::sync::atomic::AtomicPtr::::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead [INFO] [stdout] --> src/metrics.rs:85:14 [INFO] [stdout] | [INFO] [stdout] 85 | .compare_and_swap( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/lib.rs:222:22 [INFO] [stdout] | [INFO] [stdout] 222 | fn as_http_token(&self, name: &'static str) -> HttpToken { [INFO] [stdout] | ^^^^^ ^^^^^^^^^ the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 222 | fn as_http_token(&self, name: &'static str) -> HttpToken<'_> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/http_token_utils.rs:23:28 [INFO] [stdout] | [INFO] [stdout] 23 | pub const fn http_token(v: &str) -> HttpToken { [INFO] [stdout] | ^^^^ ^^^^^^^^^ the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 23 | pub const fn http_token(v: &str) -> HttpToken<'_> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/http_token_utils.rs:267:25 [INFO] [stdout] | [INFO] [stdout] 267 | pub fn parse_num(value: HttpToken) -> Result { [INFO] [stdout] | ^^^^^^^^^ ^^^^ the same lifetime is elided here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is hidden here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 267 | pub fn parse_num(value: HttpToken<'_>) -> Result { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing [INFO] [stdout] --> src/request_analyzer.rs:148:44 [INFO] [stdout] | [INFO] [stdout] 148 | fn parse(buf: HttpToken<'a>) -> (Self, RequestAnalysisState) { [INFO] [stdout] | -- ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is named here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: consistently use `'a` [INFO] [stdout] | [INFO] [stdout] 148 | fn parse(buf: HttpToken<'a>) -> (Self, RequestAnalysisState<'a>) { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling clap v2.34.0 [INFO] [stderr] Compiling serde_cbor v0.11.2 [INFO] [stderr] Compiling csv v1.3.1 [INFO] [stderr] Compiling atty v0.2.14 [INFO] [stderr] Compiling regex v1.11.2 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling snailquote v0.3.1 [INFO] [stderr] Compiling criterion v0.3.6 [INFO] [stderr] Compiling http_desync_guardian v0.1.3 (/opt/rustwide/workdir) [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/lib.rs:222:22 [INFO] [stdout] | [INFO] [stdout] 222 | fn as_http_token(&self, name: &'static str) -> HttpToken { [INFO] [stdout] | ^^^^^ ^^^^^^^^^ the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 222 | fn as_http_token(&self, name: &'static str) -> HttpToken<'_> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/http_token_utils.rs:23:28 [INFO] [stdout] | [INFO] [stdout] 23 | pub const fn http_token(v: &str) -> HttpToken { [INFO] [stdout] | ^^^^ ^^^^^^^^^ the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is elided here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 23 | pub const fn http_token(v: &str) -> HttpToken<'_> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/http_token_utils.rs:267:25 [INFO] [stdout] | [INFO] [stdout] 267 | pub fn parse_num(value: HttpToken) -> Result { [INFO] [stdout] | ^^^^^^^^^ ^^^^ the same lifetime is elided here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is hidden here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: use `'_` for type paths [INFO] [stdout] | [INFO] [stdout] 267 | pub fn parse_num(value: HttpToken<'_>) -> Result { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused borrow that must be used [INFO] [stdout] --> src/http_token_utils.rs:389:9 [INFO] [stdout] | [INFO] [stdout] 389 | / &[TE, CL].iter().for_each(|h| { [INFO] [stdout] 390 | | h.iter().for_each(|b| { [INFO] [stdout] 391 | | assert_eq!(b.to_ascii_lowercase(), *b); [INFO] [stdout] 392 | | }); [INFO] [stdout] 393 | | }); [INFO] [stdout] | |__________^ the borrow produces a value [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 389 | let _ = &[TE, CL].iter().for_each(|h| { [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing [INFO] [stdout] --> src/request_analyzer.rs:148:44 [INFO] [stdout] | [INFO] [stdout] 148 | fn parse(buf: HttpToken<'a>) -> (Self, RequestAnalysisState) { [INFO] [stdout] | -- ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here [INFO] [stdout] | | [INFO] [stdout] | the lifetime is named here [INFO] [stdout] | [INFO] [stdout] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stdout] help: consistently use `'a` [INFO] [stdout] | [INFO] [stdout] 148 | fn parse(buf: HttpToken<'a>) -> (Self, RequestAnalysisState<'a>) { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: panic message is not a string literal [INFO] [stdout] --> src/request_analyzer.rs:1456:17 [INFO] [stdout] | [INFO] [stdout] 1456 | format!("Case {}. Expected '{}' to be in '{}'", case.name, m, s) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021 [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here [INFO] [stdout] = note: `#[warn(non_fmt_panics)]` (part of `#[warn(rust_2021_compatibility)]`) on by default [INFO] [stdout] help: remove the `format!(..)` macro call [INFO] [stdout] | [INFO] [stdout] 1456 - format!("Case {}. Expected '{}' to be in '{}'", case.name, m, s) [INFO] [stdout] 1456 + "Case {}. Expected '{}' to be in '{}'", case.name, m, s [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 13.80s [INFO] running `Command { std: "docker" "inspect" "d28adb0a84828b26920d9498aad93f0a0e44aa0ad591c1c0416cf2233fc511aa", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "d28adb0a84828b26920d9498aad93f0a0e44aa0ad591c1c0416cf2233fc511aa", kill_on_drop: false }` [INFO] [stdout] d28adb0a84828b26920d9498aad93f0a0e44aa0ad591c1c0416cf2233fc511aa [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/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" "RUSTDOCFLAGS=--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" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 99abbbd22d8111960ec638c9f28b1f6889a52bc8965ea77d8aaedfae840cef2c [INFO] running `Command { std: "docker" "start" "-a" "99abbbd22d8111960ec638c9f28b1f6889a52bc8965ea77d8aaedfae840cef2c", kill_on_drop: false }` [INFO] [stderr] warning: use of deprecated method `std::sync::atomic::AtomicPtr::::compare_and_swap`: Use `compare_exchange` or `compare_exchange_weak` instead [INFO] [stderr] --> src/metrics.rs:85:14 [INFO] [stderr] | [INFO] [stderr] 85 | .compare_and_swap( [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stderr] --> src/lib.rs:222:22 [INFO] [stderr] | [INFO] [stderr] 222 | fn as_http_token(&self, name: &'static str) -> HttpToken { [INFO] [stderr] | ^^^^^ ^^^^^^^^^ the same lifetime is hidden here [INFO] [stderr] | | [INFO] [stderr] | the lifetime is elided here [INFO] [stderr] | [INFO] [stderr] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stderr] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stderr] help: use `'_` for type paths [INFO] [stderr] | [INFO] [stderr] 222 | fn as_http_token(&self, name: &'static str) -> HttpToken<'_> { [INFO] [stderr] | ++++ [INFO] [stderr] [INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stderr] --> src/http_token_utils.rs:23:28 [INFO] [stderr] | [INFO] [stderr] 23 | pub const fn http_token(v: &str) -> HttpToken { [INFO] [stderr] | ^^^^ ^^^^^^^^^ the same lifetime is hidden here [INFO] [stderr] | | [INFO] [stderr] | the lifetime is elided here [INFO] [stderr] | [INFO] [stderr] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stderr] help: use `'_` for type paths [INFO] [stderr] | [INFO] [stderr] 23 | pub const fn http_token(v: &str) -> HttpToken<'_> { [INFO] [stderr] | ++++ [INFO] [stderr] [INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stderr] --> src/http_token_utils.rs:267:25 [INFO] [stderr] | [INFO] [stderr] 267 | pub fn parse_num(value: HttpToken) -> Result { [INFO] [stderr] | ^^^^^^^^^ ^^^^ the same lifetime is elided here [INFO] [stderr] | | [INFO] [stderr] | the lifetime is hidden here [INFO] [stderr] | [INFO] [stderr] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stderr] help: use `'_` for type paths [INFO] [stderr] | [INFO] [stderr] 267 | pub fn parse_num(value: HttpToken<'_>) -> Result { [INFO] [stderr] | ++++ [INFO] [stderr] [INFO] [stderr] warning: hiding a lifetime that's named elsewhere is confusing [INFO] [stderr] --> src/request_analyzer.rs:148:44 [INFO] [stderr] | [INFO] [stderr] 148 | fn parse(buf: HttpToken<'a>) -> (Self, RequestAnalysisState) { [INFO] [stderr] | -- ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here [INFO] [stderr] | | [INFO] [stderr] | the lifetime is named here [INFO] [stderr] | [INFO] [stderr] = help: the same lifetime is referred to in inconsistent ways, making the signature confusing [INFO] [stderr] help: consistently use `'a` [INFO] [stderr] | [INFO] [stderr] 148 | fn parse(buf: HttpToken<'a>) -> (Self, RequestAnalysisState<'a>) { [INFO] [stderr] | ++++ [INFO] [stderr] [INFO] [stderr] warning: `http_desync_guardian` (lib) generated 5 warnings (run `cargo fix --lib -p http_desync_guardian` to apply 4 suggestions) [INFO] [stderr] warning: unused borrow that must be used [INFO] [stderr] --> src/http_token_utils.rs:389:9 [INFO] [stderr] | [INFO] [stderr] 389 | / &[TE, CL].iter().for_each(|h| { [INFO] [stderr] 390 | | h.iter().for_each(|b| { [INFO] [stderr] 391 | | assert_eq!(b.to_ascii_lowercase(), *b); [INFO] [stderr] 392 | | }); [INFO] [stderr] 393 | | }); [INFO] [stderr] | |__________^ the borrow produces a value [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 389 | let _ = &[TE, CL].iter().for_each(|h| { [INFO] [stderr] | +++++++ [INFO] [stderr] [INFO] [stderr] warning: panic message is not a string literal [INFO] [stderr] --> src/request_analyzer.rs:1456:17 [INFO] [stderr] | [INFO] [stderr] 1456 | format!("Case {}. Expected '{}' to be in '{}'", case.name, m, s) [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this usage of `assert!()` is deprecated; it will be a hard error in Rust 2021 [INFO] [stderr] = note: for more information, see [INFO] [stderr] = note: the `assert!()` macro supports formatting, so there's no need for the `format!()` macro here [INFO] [stderr] = note: `#[warn(non_fmt_panics)]` (part of `#[warn(rust_2021_compatibility)]`) on by default [INFO] [stderr] help: remove the `format!(..)` macro call [INFO] [stderr] | [INFO] [stderr] 1456 - format!("Case {}. Expected '{}' to be in '{}'", case.name, m, s) [INFO] [stderr] 1456 + "Case {}. Expected '{}' to be in '{}'", case.name, m, s [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: `http_desync_guardian` (lib test) generated 6 warnings (4 duplicates) (run `cargo fix --lib -p http_desync_guardian --tests` to apply 1 suggestion) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.14s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/http_desync_guardian-d58c1e54b04a7e87) [INFO] [stdout] [INFO] [stdout] running 106 tests [INFO] [stdout] test http_token_utils::tests::test_arbitrary_non_utf8_bytes ... ok [INFO] [stdout] test http_token_utils::tests::test_header_value ... ok [INFO] [stdout] test http_token_utils::tests::test_obfuscate_large_value ... ok [INFO] [stdout] test http_token_utils::tests::test_obfuscate_value ... ok [INFO] [stdout] test http_token_utils::tests::test_parse_num ... ok [INFO] [stdout] test http_token_utils::tests::test_same_char ... ok [INFO] [stdout] test http_token_utils::tests::test_same_letters ... ok [INFO] [stdout] test http_token_utils::tests::test_to_ascii ... ok [INFO] [stdout] test http_token_utils::tests::test_trim ... ok [INFO] [stdout] test http_token_utils::tests::test_utf8_delimiters ... ok [INFO] [stdout] test http_token_utils::tests::test_utf8_spaces ... ok [INFO] [stdout] test http_token_utils::tests::test_valid_te ... ok [INFO] [stdout] test http_token_utils::tests::verify_essential_headers_lowercase ... ok [INFO] [stdout] test http_token_utils::tests::verify_te_options_lowercase ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_empty_uri_bad_delimiters ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_line_by_line ... ok [INFO] [stdout] test http_token_utils::tests::test_to_ascii_large_value ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_missing_uri ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_non_compliant_request_line ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_non_compliant_terminator_request_line ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_non_missing_empty_line ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_non_tchar_request_line ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_partial ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_request_line ... ok [INFO] [stdout] test http_token_utils::tests::test_tchar ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_empty_uri ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_first_line_multiline ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_headers ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_mimic_header_severe ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_mimic_header ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_uri ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_crafted_smuggling ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_malformed_status_line ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_lfcr ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_multiline_headers ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_multiline_besides_content_type ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_request_line_http_09 ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_allow_multiline_content_type ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_allow_multiline_content_type_other_acceptable ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_acceptable_multiline_content_type ... ok [INFO] [stdout] test request_analyzer::tests::test_field_name_tier ... ok [INFO] [stdout] test request_analyzer::tests::test_field_value_tier ... ok [INFO] [stdout] test request_analyzer::tests::test_h2_not_analyzed ... ok [INFO] [stdout] test request_analyzer::tests::test_h3_not_analyzed ... ok [INFO] [stdout] test request_analyzer::tests::test_header_tier ... ok [INFO] [stdout] test request_analyzer::tests::test_no_headers ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_bad_request_line ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_empty_header_name ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_no_header_value ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_empty_header_name_double_colon ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_non_tchar_request_line ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_request_missing_empty_line ... ok [INFO] [stdout] test request_analyzer::tests::test_te_ok ... ok [INFO] [stdout] test request_analyzer::tests::test_te_with_space ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_request_multiline ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_request_partial_header ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_spaces_in_uri ... ok [INFO] [stdout] test request_analyzer::tests::test_very_many_headers ... ok [INFO] [stdout] test request_analyzer::tests::test_very_many_headers_raw ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_empty_uri ... ok [INFO] [stdout] test tests::test_http_desync_guardian_analyze_request ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_malformed_request_single_line ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_spaces_in_uri ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_print_request_insufficient_buffer_length ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_content_type ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_missing_uri ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_malformed_request_single_line_partial ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_request ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_request_first_multiline ... ok [INFO] [stdout] test tests::test_classification_reason_metrics_callback ... ok [INFO] [stdout] test tests::test_http_desync_guardian_analyze_raw_request ... ok [INFO] [stderr] [INFO] [stderr] thread 'tests::test_classification_metrics_callback_required' (96) panicked at library/core/src/panicking.rs:225:5: [INFO] [stderr] panic in a function that cannot unwind [INFO] [stderr] stack backtrace: [INFO] [stderr] 0: 0x6314582622c2 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stderr] 1: 0x6314582622c2 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stderr] 2: 0x6314582622c2 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stderr] 3: 0x6314582622c2 - ::fmt::h5bb8a979ba5db788 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stderr] 4: 0x631458273b0f - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stderr] 5: 0x631458273b0f - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stderr] 6: 0x63145822fa23 - std::io::default_write_fmt::hb0810a37865e52a5 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stderr] 7: 0x63145822fa23 - std::io::Write::write_fmt::h12c8908aaac7ca22 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stderr] 8: 0x63145823b912 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stderr] 9: 0x63145824036f - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stderr] 10: 0x6314582401c9 - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:328:9 [INFO] [stderr] 11: 0x6314581c95fe - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stderr] 12: 0x6314581c95fe - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stderr] 13: 0x631458240a0e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stderr] 14: 0x631458240a0e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stderr] 15: 0x6314582407a6 - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:700:13 [INFO] [stderr] 16: 0x63145823ba49 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stderr] 17: 0x631458223dbd - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stderr] 18: 0x63145827d41d - core::panicking::panic_nounwind_fmt::runtime::hac4f6b13dba0e83c [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:117:22 [INFO] [stderr] 19: 0x63145827d41d - core::panicking::panic_nounwind_fmt::h6abdf93d58efc633 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/intrinsics/mod.rs:2380:9 [INFO] [stderr] 20: 0x63145827d362 - core::panicking::panic_nounwind::hba3a78ea378721bc [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:225:5 [INFO] [stderr] 21: 0x63145827d577 - core::panicking::panic_cannot_unwind::hb33c1bfea17e4df0 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:337:5 [INFO] [stderr] 22: 0x63145818d71e - http_desync_guardian_register_classification_metrics_callback [INFO] [stderr] at /opt/rustwide/workdir/src/lib.rs:449:1 [INFO] [stderr] 23: 0x63145819d901 - http_desync_guardian::tests::test_classification_metrics_callback_required::h1d5ebf87231b4a5e [INFO] [stderr] at /opt/rustwide/workdir/src/lib.rs:819:9 [INFO] [stderr] 24: 0x63145819d927 - http_desync_guardian::tests::test_classification_metrics_callback_required::{{closure}}::hf33ee1588f4c2f48 [INFO] [stderr] at /opt/rustwide/workdir/src/lib.rs:813:55 [INFO] [stderr] 25: 0x6314581985b6 - core::ops::function::FnOnce::call_once::hc6c9874fa7b23c59 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stderr] 26: 0x6314581c93fb - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stderr] 27: 0x6314581c93fb - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stderr] 28: 0x6314581deea5 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stderr] 29: 0x6314581deea5 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stderr] 30: 0x6314581deea5 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stderr] 31: 0x6314581deea5 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stderr] 32: 0x6314581deea5 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stderr] 33: 0x6314581deea5 - test::run_test_in_process::had0273166695a036 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stderr] 34: 0x6314581deea5 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stderr] 35: 0x6314581b58c4 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stderr] 36: 0x6314581b58c4 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stderr] 37: 0x6314581b91aa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stderr] 38: 0x6314581b91aa - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stderr] 39: 0x6314581b91aa - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stderr] 40: 0x6314581b91aa - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stderr] 41: 0x6314581b91aa - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stderr] 42: 0x6314581b91aa - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stderr] 43: 0x6314581b91aa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stderr] 44: 0x631458235ccf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stderr] 45: 0x631458235ccf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stderr] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stderr] 46: 0x7194362ffaa4 - [INFO] [stderr] 47: 0x71943638ca34 - clone [INFO] [stderr] 48: 0x0 - [INFO] [stderr] thread caused non-unwinding panic. aborting. [INFO] [stdout] [INFO] [stdout] thread 'tests::test_classification_metrics_callback_required' (96) panicked at src/metrics.rs:299:14: [INFO] [stdout] Callback to send classification metrics is required [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x6314582622c2 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x6314582622c2 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x6314582622c2 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x6314582622c2 - ::fmt::h5bb8a979ba5db788 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x631458273b0f - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x631458273b0f - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x63145822fb53 - std::io::default_write_fmt::h7d7ad5ed6a883d81 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x63145822fb53 - std::io::Write::write_fmt::hc477d9325b345ece [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x63145823b912 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x63145824036f - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x631458240201 - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6314581c95fe - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x6314581c95fe - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x631458240a0e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x631458240a0e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x6314582407da - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x63145823ba49 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x631458223dbd - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x63145827d6d0 - core::panicking::panic_fmt::h78e817a90331d98b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x63145827c81b - core::panicking::panic_display::hcaaa80cf240a8456 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:259:5 [INFO] [stdout] 20: 0x63145827c81b - core::option::expect_failed::h5f7ba2be79015352 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/option.rs:2175:5 [INFO] [stdout] 21: 0x6314581a7b50 - core::option::Option::expect::hef6ea5193873a007 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/option.rs:964:21 [INFO] [stdout] 22: 0x631458178111 - http_desync_guardian::metrics::ClassificationMetricsSettings::set::hddd92bf4c5871f16 [INFO] [stdout] at /opt/rustwide/workdir/src/metrics.rs:299:14 [INFO] [stdout] 23: 0x63145818d728 - http_desync_guardian_register_classification_metrics_callback [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:452:11 [INFO] [stdout] 24: 0x63145819d901 - http_desync_guardian::tests::test_classification_metrics_callback_required::h1d5ebf87231b4a5e [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:819:9 [INFO] [stdout] 25: 0x63145819d927 - http_desync_guardian::tests::test_classification_metrics_callback_required::{{closure}}::hf33ee1588f4c2f48 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:813:55 [INFO] [stdout] 26: 0x6314581985b6 - core::ops::function::FnOnce::call_once::hc6c9874fa7b23c59 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 27: 0x6314581c93fb - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 28: 0x6314581c93fb - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stdout] 29: 0x6314581deea5 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stdout] 30: 0x6314581deea5 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 31: 0x6314581deea5 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 32: 0x6314581deea5 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 33: 0x6314581deea5 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 34: 0x6314581deea5 - test::run_test_in_process::had0273166695a036 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stdout] 35: 0x6314581deea5 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stdout] 36: 0x6314581b58c4 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stdout] 37: 0x6314581b58c4 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 38: 0x6314581b91aa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 39: 0x6314581b91aa - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 40: 0x6314581b91aa - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 41: 0x6314581b91aa - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 42: 0x6314581b91aa - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 43: 0x6314581b91aa - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 44: 0x6314581b91aa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 45: 0x631458235ccf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 46: 0x631458235ccf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 47: 0x7194362ffaa4 - [INFO] [stdout] 48: 0x71943638ca34 - clone [INFO] [stdout] 49: 0x0 - [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] [stderr] [INFO] [stderr] Caused by: [INFO] [stderr] process didn't exit successfully: `/opt/rustwide/target/debug/deps/http_desync_guardian-d58c1e54b04a7e87` (signal: 6, SIGABRT: process abort signal) [INFO] running `Command { std: "docker" "inspect" "99abbbd22d8111960ec638c9f28b1f6889a52bc8965ea77d8aaedfae840cef2c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "99abbbd22d8111960ec638c9f28b1f6889a52bc8965ea77d8aaedfae840cef2c", kill_on_drop: false }` [INFO] [stdout] 99abbbd22d8111960ec638c9f28b1f6889a52bc8965ea77d8aaedfae840cef2c