[INFO] fetching crate http_desync_guardian 0.1.3... [INFO] testing http_desync_guardian-0.1.3 against 1.60.0 for beta-1.61-1 [INFO] extracting crate http_desync_guardian 0.1.3 into /workspace/builds/worker-1/source [INFO] validating manifest of crates.io crate http_desync_guardian 0.1.3 on toolchain 1.60.0 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.60.0" "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-1/source/Cargo.toml [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.60.0" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update", kill_on_drop: false }` [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.60.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded snailquote v0.3.1 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/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:eaef2f80f755933c374d2ae5edccceec0c1312ceb8a4e0b6404e8ab76561e1e5" "/opt/rustwide/cargo-home/bin/cargo" "+1.60.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] ffad85f0bcdb3fc02b7f185821acf82bed298dd10a01e09ae64f3dd79d8957eb [INFO] running `Command { std: "docker" "start" "-a" "ffad85f0bcdb3fc02b7f185821acf82bed298dd10a01e09ae64f3dd79d8957eb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "ffad85f0bcdb3fc02b7f185821acf82bed298dd10a01e09ae64f3dd79d8957eb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "ffad85f0bcdb3fc02b7f185821acf82bed298dd10a01e09ae64f3dd79d8957eb", kill_on_drop: false }` [INFO] [stdout] ffad85f0bcdb3fc02b7f185821acf82bed298dd10a01e09ae64f3dd79d8957eb [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/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=warn" "-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:eaef2f80f755933c374d2ae5edccceec0c1312ceb8a4e0b6404e8ab76561e1e5" "/opt/rustwide/cargo-home/bin/cargo" "+1.60.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] efe5091f893604c223d7d14c18b134d86fdb032c4cd55f0e39f1a261d0214dc2 [INFO] running `Command { std: "docker" "start" "-a" "efe5091f893604c223d7d14c18b134d86fdb032c4cd55f0e39f1a261d0214dc2", kill_on_drop: false }` [INFO] [stderr] Compiling http_desync_guardian v0.1.3 (/opt/rustwide/workdir) [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 8.55s [INFO] running `Command { std: "docker" "inspect" "efe5091f893604c223d7d14c18b134d86fdb032c4cd55f0e39f1a261d0214dc2", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "efe5091f893604c223d7d14c18b134d86fdb032c4cd55f0e39f1a261d0214dc2", kill_on_drop: false }` [INFO] [stdout] efe5091f893604c223d7d14c18b134d86fdb032c4cd55f0e39f1a261d0214dc2 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/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=warn" "-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:eaef2f80f755933c374d2ae5edccceec0c1312ceb8a4e0b6404e8ab76561e1e5" "/opt/rustwide/cargo-home/bin/cargo" "+1.60.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 6e1e63699479977540d69546a07b46dd4005c5aa8d573591126e2961b54b0f07 [INFO] running `Command { std: "docker" "start" "-a" "6e1e63699479977540d69546a07b46dd4005c5aa8d573591126e2961b54b0f07", kill_on_drop: false }` [INFO] [stderr] Compiling snailquote v0.3.1 [INFO] [stderr] Compiling criterion v0.3.5 [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 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 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] 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] [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)]` 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: 2 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 15.77s [INFO] running `Command { std: "docker" "inspect" "6e1e63699479977540d69546a07b46dd4005c5aa8d573591126e2961b54b0f07", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6e1e63699479977540d69546a07b46dd4005c5aa8d573591126e2961b54b0f07", kill_on_drop: false }` [INFO] [stdout] 6e1e63699479977540d69546a07b46dd4005c5aa8d573591126e2961b54b0f07 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/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=warn" "-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:eaef2f80f755933c374d2ae5edccceec0c1312ceb8a4e0b6404e8ab76561e1e5" "/opt/rustwide/cargo-home/bin/cargo" "+1.60.0" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 6d70e3712883d03eecc4987346dd76007226360424c6ab0d1e73b1d69e4d01a1 [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" "6d70e3712883d03eecc4987346dd76007226360424c6ab0d1e73b1d69e4d01a1", 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: `http_desync_guardian` (lib) generated 1 warning [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 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] 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: 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)]` 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: `http_desync_guardian` (lib test) generated 2 warnings [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.11s [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/http_desync_guardian-fd77212313c199ed) [INFO] [stdout] [INFO] [stdout] running 106 tests [INFO] [stdout] test http_token_utils::tests::test_same_char ... ok [INFO] [stdout] test http_token_utils::tests::test_header_value ... ok [INFO] [stdout] test http_token_utils::tests::test_arbitrary_non_utf8_bytes ... ok [INFO] [stdout] test http_token_utils::tests::test_parse_num ... ok [INFO] [stdout] test http_token_utils::tests::test_obfuscate_value ... ok [INFO] [stdout] test http_token_utils::tests::test_obfuscate_large_value ... ok [INFO] [stdout] test http_token_utils::tests::test_to_ascii_large_value ... 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 raw_request_parser::tests::test_parse_line_by_line ... ok [INFO] [stdout] test http_token_utils::tests::test_utf8_delimiters ... ok [INFO] [stdout] test http_token_utils::tests::verify_essential_headers_lowercase ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_missing_uri ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_empty_uri_bad_delimiters ... ok [INFO] [stdout] test http_token_utils::tests::test_tchar ... 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 http_token_utils::tests::test_trim ... 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 request_analyzer::tests::test_analyze_allow_multiline_content_type ... ok [INFO] [stdout] test http_token_utils::tests::test_valid_te ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_non_tchar_request_line ... 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_analyze_acceptable_multiline_content_type ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_malformed_status_line ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_crafted_smuggling ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_mimic_header_severe ... ok [INFO] [stdout] test raw_request_parser::tests::test_parse_partial ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_headers ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_non_tchar_request_line ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_mimic_header ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_no_header_value ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_uri ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_multiline_headers ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_first_line_multiline ... ok [INFO] [stdout] test request_analyzer::tests::test_h2_not_analyzed ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_spaces_in_uri ... ok [INFO] [stdout] test request_analyzer::tests::test_no_headers ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_lfcr ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_multiline_besides_content_type ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_bad_request_line ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_allow_multiline_content_type_other_acceptable ... ok [INFO] [stdout] test request_analyzer::tests::test_analyze_bad_multiline_content_type ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_empty_header_name_double_colon ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_empty_uri ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_malformed_request_single_line ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_malformed_request_single_line_partial ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_missing_uri ... ok [INFO] [stdout] test request_analyzer::tests::test_header_tier ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_empty_header_name ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_request ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_spaces_in_uri ... ok [INFO] [stdout] test request_analyzer::tests::test_te_ok ... 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 tests::test_classification_reason_metrics_callback ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_print_request_insufficient_buffer_length ... ok [INFO] [stdout] test tests::test_http_desync_guardian_analyze_raw_request ... ok [INFO] [stdout] test tests::test_http_desync_guardian_analyze_request ... 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_te_with_space ... 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_request_first_multiline ... ok [INFO] [stdout] test request_analyzer::tests::test_parse_request_missing_empty_line ... ok [INFO] [stdout] test tests::test_classification_metrics_settings_required - 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_print_request_parameters_invalid_buffer_length - 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_classification_metrics_callback_required - 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_print_request_parameters_null_request - 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_print_request_parameters_null_buffer - 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_invalid_header_tier ... ok [INFO] [stdout] test tests::test_logger_settings_required - should panic ... ok [INFO] [stdout] test tests::test_tier_metrics_settings_required - should panic ... ok [INFO] [stdout] test tests::test_tier_metrics_callback_required - should panic ... ok [INFO] [stdout] test tests::test_request_tier_metrics_callback ... ok [INFO] [stdout] test tests::test_non_compliant_header_tier ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_round_down ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_once_per_minute ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_raw_request_zero_buffer_size - should panic ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_time_stamp_overflow ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_100_per_second ... 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_once_per_second ... ok [INFO] [stdout] test tests::test_logger_callback_required - 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_log_callback ... ok [INFO] [stdout] test ultralight_rate_limiter::tests::test_twice_per_second ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_analysis_parameters_null_request - should panic ... ok [INFO] [stdout] test tests::test_http_desync_guardian_validate_request_raw_request_null_buffer - 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 31.96s [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::Identical (line 101) - compile ... ok [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::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.55s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "6d70e3712883d03eecc4987346dd76007226360424c6ab0d1e73b1d69e4d01a1", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6d70e3712883d03eecc4987346dd76007226360424c6ab0d1e73b1d69e4d01a1", kill_on_drop: false }` [INFO] [stdout] 6d70e3712883d03eecc4987346dd76007226360424c6ab0d1e73b1d69e4d01a1