[INFO] fetching crate http_desync_guardian 0.1.3... [INFO] testing http_desync_guardian-0.1.3 against try#ecabaf78506b7a4668d42dc20268c086b93f0fad for pr-87041 [INFO] extracting crate http_desync_guardian 0.1.3 into /workspace/builds/worker-15/source [INFO] validating manifest of crates.io crate http_desync_guardian 0.1.3 on toolchain ecabaf78506b7a4668d42dc20268c086b93f0fad [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [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-15/source/Cargo.toml [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update", kill_on_drop: false }` [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded snailquote v0.3.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-15/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-15/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:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] a16fb343656612cbe4470c5ac9d0f70fb425318dde96a215b234e4bdaa4cc8ba [INFO] running `Command { std: "docker" "start" "-a" "a16fb343656612cbe4470c5ac9d0f70fb425318dde96a215b234e4bdaa4cc8ba", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "a16fb343656612cbe4470c5ac9d0f70fb425318dde96a215b234e4bdaa4cc8ba", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "a16fb343656612cbe4470c5ac9d0f70fb425318dde96a215b234e4bdaa4cc8ba", kill_on_drop: false }` [INFO] [stdout] a16fb343656612cbe4470c5ac9d0f70fb425318dde96a215b234e4bdaa4cc8ba [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-15/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-15/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" "ghcr.io/rust-lang/crates-build-env/linux@sha256:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 48dd02dfb659c7edd0c6d3f3688a401650311f791209b9a0919ef51284b5aa82 [INFO] running `Command { std: "docker" "start" "-a" "48dd02dfb659c7edd0c6d3f3688a401650311f791209b9a0919ef51284b5aa82", kill_on_drop: false }` [INFO] [stderr] Compiling http_desync_guardian v0.1.3 (/opt/rustwide/workdir) [INFO] [stderr] Compiling smallvec v1.6.1 [INFO] [stderr] Compiling strum v0.18.0 [INFO] [stderr] Compiling heck v0.3.3 [INFO] [stderr] Compiling syn v1.0.73 [INFO] [stderr] Compiling strum_macros v0.18.0 [INFO] [stdout] warning: use of deprecated associated function `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: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 10.69s [INFO] running `Command { std: "docker" "inspect" "48dd02dfb659c7edd0c6d3f3688a401650311f791209b9a0919ef51284b5aa82", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "48dd02dfb659c7edd0c6d3f3688a401650311f791209b9a0919ef51284b5aa82", kill_on_drop: false }` [INFO] [stdout] 48dd02dfb659c7edd0c6d3f3688a401650311f791209b9a0919ef51284b5aa82 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-15/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-15/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" "ghcr.io/rust-lang/crates-build-env/linux@sha256:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] dfc65ead3baf73435f6272a72f0e99b4f488ef950478f3377cbd626f05da3f72 [INFO] running `Command { std: "docker" "start" "-a" "dfc65ead3baf73435f6272a72f0e99b4f488ef950478f3377cbd626f05da3f72", kill_on_drop: false }` [INFO] [stderr] Compiling semver v1.0.3 [INFO] [stderr] Compiling either v1.6.1 [INFO] [stderr] Compiling serde_derive v1.0.126 [INFO] [stderr] Compiling memoffset v0.6.4 [INFO] [stderr] Compiling rayon v1.5.1 [INFO] [stderr] Compiling yaml-rust v0.4.5 [INFO] [stderr] Compiling crossbeam-utils v0.8.5 [INFO] [stderr] Compiling bstr v0.2.16 [INFO] [stderr] Compiling serde_json v1.0.64 [INFO] [stderr] Compiling serde_cbor v0.11.1 [INFO] [stderr] Compiling clap v2.33.3 [INFO] [stderr] Compiling plotters v0.3.1 [INFO] [stderr] Compiling thiserror-impl v1.0.26 [INFO] [stdout] warning: use of deprecated associated function `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: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling itertools v0.9.0 [INFO] [stderr] Compiling itertools v0.10.1 [INFO] [stderr] Compiling crossbeam-channel v0.5.1 [INFO] [stderr] Compiling crossbeam-epoch v0.9.5 [INFO] [stderr] Compiling crossbeam-deque v0.8.0 [INFO] [stderr] Compiling rustc_version v0.4.0 [INFO] [stderr] Compiling csv v1.1.6 [INFO] [stderr] Compiling rayon-core v1.9.1 [INFO] [stderr] Compiling tinytemplate v1.2.1 [INFO] [stderr] Compiling cast v0.2.7 [INFO] [stderr] Compiling criterion-plot v0.4.3 [INFO] [stderr] Compiling thiserror v1.0.26 [INFO] [stderr] Compiling snailquote v0.3.0 [INFO] [stderr] Compiling criterion v0.3.4 [INFO] [stderr] Compiling http_desync_guardian v0.1.3 (/opt/rustwide/workdir) [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: `#[warn(non_fmt_panics)]` on by default [INFO] [stdout] = note: this usage of panic!() 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] help: remove the `format!(..)` macro call [INFO] [stdout] | [INFO] [stdout] 1456 | "Case {}. Expected '{}' to be in '{}'", case.name, m, s [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] | |__________^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_must_use)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 2 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 14.41s [INFO] running `Command { std: "docker" "inspect" "dfc65ead3baf73435f6272a72f0e99b4f488ef950478f3377cbd626f05da3f72", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "dfc65ead3baf73435f6272a72f0e99b4f488ef950478f3377cbd626f05da3f72", kill_on_drop: false }` [INFO] [stdout] dfc65ead3baf73435f6272a72f0e99b4f488ef950478f3377cbd626f05da3f72 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-15/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-15/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" "ghcr.io/rust-lang/crates-build-env/linux@sha256:34b6a614d2c27851fe6cbf88fbd1137609cefab8b10d0615aaeb6fd47975d74e" "/opt/rustwide/cargo-home/bin/cargo" "+ecabaf78506b7a4668d42dc20268c086b93f0fad" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] e72203e10f8b01cf8a24507b31a1fef71859442f9f5af0e5f3ff1f2406cf795d [INFO] running `Command { std: "docker" "start" "-a" "e72203e10f8b01cf8a24507b31a1fef71859442f9f5af0e5f3ff1f2406cf795d", kill_on_drop: false }` [INFO] [stderr] warning: use of deprecated associated function `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: 1 warning emitted [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: `#[warn(non_fmt_panics)]` on by default [INFO] [stderr] = note: this usage of panic!() 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] help: remove the `format!(..)` macro call [INFO] [stderr] | [INFO] [stderr] 1456 | "Case {}. Expected '{}' to be in '{}'", case.name, m, s [INFO] [stderr] | -- -- [INFO] [stderr] [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] | |__________^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 2 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.04s [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/http_desync_guardian-50ac1738f1faa979) [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_value ... ok [INFO] [stdout] test http_token_utils::tests::test_parse_num ... ok [INFO] [stdout] test http_token_utils::tests::test_obfuscate_large_value ... 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_trim ... ok [INFO] [stdout] test http_token_utils::tests::test_to_ascii_large_value ... ok [INFO] [stdout] test http_token_utils::tests::test_to_ascii ... ok [INFO] [stdout] test http_token_utils::tests::test_tchar ... ok [INFO] [stdout] test http_token_utils::tests::verify_essential_headers_lowercase ... ok [INFO] [stdout] test http_token_utils::tests::test_valid_te ... 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::verify_te_options_lowercase ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_empty_uri ... 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 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 raw_request_parser::tests::test_parse_request_line_http_09 ... ok [INFO] [stdout] test request_analyzer::tests::test_header_tier ... 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_h3_not_analyzed ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_empty_header_name_double_colon ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_multiline_headers ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_crafted_smuggling ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_allow_multiline_content_type_other_acceptable ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_non_tchar_request_line ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_content_type ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_malformed_status_line ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_acceptable_multiline_content_type ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_mimic_header ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_malformed_request_single_line ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_uri ... 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_analyze_bad_multiline_mimic_header_severe ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_request_first_multiline ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_request ... ok [INFO] [stdout] test request_analyzer::tests::test_no_headers ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_headers ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_allow_multiline_content_type ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_request_missing_empty_line ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_spaces_in_uri ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_multiline_besides_content_type ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_first_line_multiline ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_request_multiline ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_lfcr ... ok [INFO] [stdout] test request_analyzer::tests::test_h2_not_analyzed ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_missing_uri ... 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_parse_bad_request_line ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_malformed_request_single_line_partial ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_print_request_insufficient_buffer_length ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_empty_uri ... ok [INFO] [stdout] test tests::test_invalid_header_tier ... ok [INFO] [stdout] test tests::test_non_compliant_header_tier ... ok [INFO] [stdout] test tests::test_http_desync_guardian_analyze_request ... ok [INFO] [stdout] test tests::test_classification_reason_metrics_callback ... ok [INFO] [stdout] test request_analyzer::tests::test_te_ok ... ok [INFO] [stdout] test tests::test_http_desync_guardian_analyze_raw_request ... ok [INFO] [stdout] test request_analyzer::tests::test_te_with_space ... ok [INFO] [stdout] test tests::test_log_callback ... ok [INFO] [stdout] test request_analyzer::tests::test_very_many_headers ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_once_per_second ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_round_down ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_time_stamp_overflow ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_try_acquire_value ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_twice_per_minute ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_twice_per_second ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_once_per_minute ... ok [INFO] [stdout] test request_analyzer::tests::test_very_many_headers_raw ... ok [INFO] [stdout] test tests::test_request_tier_metrics_callback ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_100_per_second ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_print_request_parameters_null_request - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_analysis_parameters_null_header_name - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_analysis_parameters_null_header_value - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_analysis_parameters_null_method - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_print_request_parameters_invalid_buffer_length - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_analysis_parameters_null_uri - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_analysis_parameters_null_verdict - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_analysis_parameters_null_version - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_raw_request_null_buffer - should panic ... ok [INFO] [stdout] test tests::test_classification_metrics_callback_required - should panic ... ok [INFO] [stdout] test tests::test_classification_metrics_settings_required - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_print_request_parameters_null_buffer - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_raw_request_null_verdict - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_raw_request_zero_buffer_size - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_analysis_parameters_null_request - should panic ... ok [INFO] [stdout] test tests::test_logger_callback_required - should panic ... ok [INFO] [stdout] test tests::test_logger_settings_required - should panic ... ok [INFO] [stdout] test tests::test_tier_metrics_callback_required - should panic ... ok [INFO] [stdout] test tests::test_tier_metrics_settings_required - should panic ... ok [INFO] [stdout] test request_analyzer::tests::file_tests ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_fuzzing_input ... ok [INFO] [stdout] test http_token_utils::tests::test_same_char_covers_all_utf8 ... ok [INFO] [stdout] test request_analyzer::tests::test_walk_through_states ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 106 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 42.53s [INFO] [stdout] [INFO] [stderr] Doc-tests http_desync_guardian [INFO] [stdout] [INFO] [stdout] running 5 tests [INFO] [stdout] test src/http_token_utils.rs - http_token_utils::SP (line 34) ... ignored [INFO] [stdout] test src/http_token_utils.rs - http_token_utils::SP (line 57) ... ignored [INFO] [stdout] test src/http_token_utils.rs - http_token_utils::TokenSimilarity::Distant (line 119) - compile ... ok [INFO] [stdout] test src/http_token_utils.rs - http_token_utils::TokenSimilarity::Identical (line 101) - compile ... ok [INFO] [stdout] test src/http_token_utils.rs - http_token_utils::TokenSimilarity::SameLetters (line 110) - compile ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 3 passed; 0 failed; 2 ignored; 0 measured; 0 filtered out; finished in 0.12s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "e72203e10f8b01cf8a24507b31a1fef71859442f9f5af0e5f3ff1f2406cf795d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e72203e10f8b01cf8a24507b31a1fef71859442f9f5af0e5f3ff1f2406cf795d", kill_on_drop: false }` [INFO] [stdout] e72203e10f8b01cf8a24507b31a1fef71859442f9f5af0e5f3ff1f2406cf795d