[INFO] fetching crate fail2ban-rs 1.0.0... [INFO] testing fail2ban-rs-1.0.0 against master#562dee4820c458d823175268e41601d4c060588a for pr-154210-1 [INFO] extracting crate fail2ban-rs 1.0.0 into /workspace/builds/worker-6-tc1/source [INFO] removed /workspace/builds/worker-6-tc1/source/rust-toolchain.toml [INFO] started tweaking crates.io crate fail2ban-rs 1.0.0 [INFO] removed 0 missing tests [INFO] finished tweaking crates.io crate fail2ban-rs 1.0.0 [INFO] tweaked toml for crates.io crate fail2ban-rs 1.0.0 written to /workspace/builds/worker-6-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate fail2ban-rs 1.0.0 on toolchain 562dee4820c458d823175268e41601d4c060588a [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate fail2ban-rs 1.0.0 already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded tell v0.1.1 [INFO] [stderr] Downloaded tell-encoding v0.1.0 [INFO] [stderr] Downloaded crossfire v3.1.3 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] e8a35182af6bede30cf84e5ae94efe30087675409b3da33315824270a8d3892f [INFO] running `Command { std: "docker" "start" "-a" "e8a35182af6bede30cf84e5ae94efe30087675409b3da33315824270a8d3892f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "e8a35182af6bede30cf84e5ae94efe30087675409b3da33315824270a8d3892f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e8a35182af6bede30cf84e5ae94efe30087675409b3da33315824270a8d3892f", kill_on_drop: false }` [INFO] [stdout] e8a35182af6bede30cf84e5ae94efe30087675409b3da33315824270a8d3892f [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] eb429399c12a30d8bda36210ba08f88ba5fd9356c42f7052231f1d9c56476f4e [INFO] running `Command { std: "docker" "start" "-a" "eb429399c12a30d8bda36210ba08f88ba5fd9356c42f7052231f1d9c56476f4e", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.182 [INFO] [stderr] Compiling semver v1.0.27 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling byteorder v1.5.0 [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Compiling nix v0.29.0 [INFO] [stderr] Compiling anyhow v1.0.102 [INFO] [stderr] Compiling clap_lex v1.0.0 [INFO] [stderr] Compiling chrono v0.4.43 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling xxhash-rust v0.8.15 [INFO] [stderr] Compiling hash32 v0.2.1 [INFO] [stderr] Compiling clap_builder v4.5.60 [INFO] [stderr] Compiling rustc_version v0.4.1 [INFO] [stderr] Compiling heapless v0.7.17 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling errno v0.3.14 [INFO] [stderr] Compiling socket2 v0.6.2 [INFO] [stderr] Compiling mio v1.1.1 [INFO] [stderr] Compiling signal-hook-registry v1.4.8 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling clap_derive v4.5.55 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling clap v4.5.60 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling cobs v0.3.0 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling ipnet v2.11.0 [INFO] [stderr] Compiling toml_edit v0.22.27 [INFO] [stderr] Compiling postcard v1.1.3 [INFO] [stderr] Compiling toml v0.8.23 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling fail2ban-rs v1.0.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 36.37s [INFO] running `Command { std: "docker" "inspect" "eb429399c12a30d8bda36210ba08f88ba5fd9356c42f7052231f1d9c56476f4e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "eb429399c12a30d8bda36210ba08f88ba5fd9356c42f7052231f1d9c56476f4e", kill_on_drop: false }` [INFO] [stdout] eb429399c12a30d8bda36210ba08f88ba5fd9356c42f7052231f1d9c56476f4e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 3014972916db09bca79520db3428515cdd1db7e24afc0849a486bf46f55855a2 [INFO] running `Command { std: "docker" "start" "-a" "3014972916db09bca79520db3428515cdd1db7e24afc0849a486bf46f55855a2", kill_on_drop: false }` [INFO] [stderr] Compiling zerocopy v0.8.39 [INFO] [stderr] Compiling zerocopy-derive v0.8.39 [INFO] [stderr] Compiling rayon-core v1.13.0 [INFO] [stderr] Compiling getrandom v0.4.1 [INFO] [stderr] Compiling ciborium-io v0.2.2 [INFO] [stderr] Compiling plotters-backend v0.3.7 [INFO] [stderr] Compiling chrono v0.4.43 [INFO] [stderr] Compiling nix v0.29.0 [INFO] [stderr] Compiling itertools v0.10.5 [INFO] [stderr] Compiling cast v0.3.0 [INFO] [stderr] Compiling same-file v1.0.6 [INFO] [stderr] Compiling tinytemplate v1.2.1 [INFO] [stderr] Compiling is-terminal v0.4.17 [INFO] [stderr] Compiling oorandom v11.1.5 [INFO] [stderr] Compiling rustix v1.1.3 [INFO] [stderr] Compiling anes v0.1.6 [INFO] [stderr] Compiling walkdir v2.5.0 [INFO] [stderr] Compiling plotters-svg v0.3.7 [INFO] [stderr] Compiling rayon v1.11.0 [INFO] [stderr] Compiling plotters v0.3.7 [INFO] [stderr] Compiling criterion-plot v0.5.0 [INFO] [stderr] Compiling fail2ban-rs v1.0.0 (/opt/rustwide/workdir) [INFO] [stderr] Compiling tempfile v3.25.0 [INFO] [stderr] Compiling half v2.7.1 [INFO] [stderr] Compiling ciborium-ll v0.2.2 [INFO] [stderr] Compiling ciborium v0.2.2 [INFO] [stderr] Compiling criterion v0.5.1 [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 33.50s [INFO] running `Command { std: "docker" "inspect" "3014972916db09bca79520db3428515cdd1db7e24afc0849a486bf46f55855a2", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "3014972916db09bca79520db3428515cdd1db7e24afc0849a486bf46f55855a2", kill_on_drop: false }` [INFO] [stdout] 3014972916db09bca79520db3428515cdd1db7e24afc0849a486bf46f55855a2 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 609bc5b21ba829f1acdfaac40113df4dd4e0cf335ba33d17fa4d50be31d61cdc [INFO] running `Command { std: "docker" "start" "-a" "609bc5b21ba829f1acdfaac40113df4dd4e0cf335ba33d17fa4d50be31d61cdc", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.20s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/fail2ban_rs-3496ed2bfe659a3e) [INFO] [stdout] [INFO] [stdout] running 222 tests [INFO] [stdout] test ban_calc_test::build_params_empty_configs ... ok [INFO] [stdout] test ban_calc_test::build_params_copies_values_correctly ... ok [INFO] [stdout] test ban_calc_test::build_params_preserves_defaults ... ok [INFO] [stdout] test ban_calc_test::explicit_multipliers ... ok [INFO] [stdout] test ban_calc_test::exponential_escalation ... ok [INFO] [stdout] test ban_calc_test::escalation_sequence_monotonically_increases ... ok [INFO] [stdout] test ban_calc_test::factor_applied ... ok [INFO] [stdout] test ban_calc_test::build_params_maps_all_jails ... ok [INFO] [stdout] test ban_calc_test::high_count_does_not_panic ... ok [INFO] [stdout] test ban_calc_test::maxtime_cap ... ok [INFO] [stdout] test ban_calc_test::permanent_ban_bypasses_increment ... ok [INFO] [stdout] test ban_calc_test::permanent_ban_never_downgrades ... ok [INFO] [stdout] test ban_calc_test::zero_maxtime_means_no_cap ... ok [INFO] [stdout] test ban_calc_test::no_increment_returns_base ... ok [INFO] [stdout] test circular_test::capacity_one ... ok [INFO] [stdout] test circular_test::capacity_returns_correct_value ... ok [INFO] [stdout] test circular_test::empty_buffer ... ok [INFO] [stdout] test circular_test::len_and_is_empty_through_lifecycle ... ok [INFO] [stdout] test circular_test::negative_timestamps ... ok [INFO] [stdout] test circular_test::overwrites_oldest_when_full ... ok [INFO] [stdout] test circular_test::push_until_full ... ok [INFO] [stdout] test circular_test::threshold_after_wrap ... ok [INFO] [stdout] test circular_test::threshold_within_window ... ok [INFO] [stdout] test circular_test::zero_capacity ... ok [INFO] [stdout] test circular_test::threshold_with_find_time_zero ... ok [INFO] [stdout] test circular_test::threshold_not_full ... ok [INFO] [stdout] test config_test::defaults_applied ... ok [INFO] [stdout] test config_test::duration_strings_in_config ... ok [INFO] [stdout] test config_test::ignoreregex_defaults_empty ... ok [INFO] [stdout] test config_test::config_d_overlay_adds_jail ... ok [INFO] [stdout] test config_test::from_file_not_found ... ok [INFO] [stdout] test config_test::enabled_jails_filter ... ok [INFO] [stdout] test config_test::from_file_invalid_toml ... ok [INFO] [stdout] test config_test::config_d_missing_dir_is_fine ... ok [INFO] [stdout] test config_test::config_d_overlay_overrides_scalar ... ok [INFO] [stdout] test config_test::ignoreregex_parses ... ok [INFO] [stdout] test config_test::iptables_backend ... ok [INFO] [stdout] test config_test::config_d_sorted_order ... ok [INFO] [stdout] test ban_calc_test::multiplier_sequence_monotonically_increases ... ok [INFO] [stdout] test config_test::empty_filter_error ... ok [INFO] [stdout] test config_test::duration_integers_still_work ... ok [INFO] [stdout] test config_test::missing_host_placeholder_error ... ok [INFO] [stdout] test config_test::logging_defaults_when_omitted ... ok [INFO] [stdout] test config_test::multiple_enabled_jails ... ok [INFO] [stdout] test config_test::multiple_filters ... ok [INFO] [stdout] test config_test::negative_find_time_error ... ok [INFO] [stdout] test config_test::no_enabled_jails_error ... ok [INFO] [stdout] test config_test::no_jails_error ... ok [INFO] [stdout] test config_test::parse_valid_config ... ok [INFO] [stdout] test config_test::permanent_ban_time_ok ... ok [INFO] [stdout] test config_test::logging_section_parses ... ok [INFO] [stdout] test config_test::script_backend ... ok [INFO] [stdout] test config_test::zero_ban_time_error ... ok [INFO] [stdout] test config_test::zero_find_time_error ... ok [INFO] [stdout] test config_test::zero_max_retry_error ... ok [INFO] [stdout] test control_test::connect_to_nonexistent_socket ... ok [INFO] [stdout] test control_test::list_bans_request_serialization ... ok [INFO] [stdout] test control_test::reload_request_serialization ... ok [INFO] [stdout] test control_test::response_ok_data_has_no_message ... ok [INFO] [stdout] test control_test::unban_request_serialization ... ok [INFO] [stdout] test control_test::ban_request_serialization ... ok [INFO] [stdout] test date_test::iso8601_format ... ok [INFO] [stdout] test date_test::iso8601_space_separator ... ok [INFO] [stdout] test date_test::no_match_returns_none ... ok [INFO] [stdout] test date_test::all_months_parse ... ok [INFO] [stdout] test duration_test::empty_string_error ... ok [INFO] [stdout] test duration_test::hours_suffix ... ok [INFO] [stdout] test duration_test::invalid_number_error ... ok [INFO] [stdout] test duration_test::invalid_suffix_error ... ok [INFO] [stdout] test date_test::syslog_format ... ok [INFO] [stdout] test duration_test::seconds_suffix ... ok [INFO] [stdout] test duration_test::plain_integers ... ok [INFO] [stdout] test duration_test::weeks_suffix ... ok [INFO] [stdout] test duration_test::whitespace_trimmed ... ok [INFO] [stdout] test error_test::already_banned_display ... ok [INFO] [stdout] test error_test::channel_closed_display ... ok [INFO] [stdout] test error_test::config_error_display ... ok [INFO] [stdout] test error_test::config_not_found_display ... ok [INFO] [stdout] test error_test::firewall_error_display ... ok [INFO] [stdout] test error_test::io_error_display ... ok [INFO] [stdout] test date_test::invalid_month_returns_none ... ok [INFO] [stdout] test error_test::protocol_error_display ... ok [INFO] [stdout] test error_test::io_error_source ... ok [INFO] [stdout] test error_test::state_corrupt_display ... ok [INFO] [stdout] test error_test::result_type_alias_works ... ok [INFO] [stdout] test error_test::regex_error_display ... ok [INFO] [stdout] test duration_test::minutes_suffix ... ok [INFO] [stdout] test error_test::not_banned_display ... ok [INFO] [stdout] test duration_test::days_suffix ... ok [INFO] [stdout] test date_test::syslog_invalid_time_returns_none ... ok [INFO] [stdout] test executor_test::create_backend_script ... ok [INFO] [stdout] test executor_test::restore_bans_empty ... ok [INFO] [stdout] test executor_test::restore_bans_skips_expired ... ok [INFO] [stdout] test executor_test::create_backend_iptables ... ok [INFO] [stdout] test executor_test::executor_channel_closed_stops ... ok [INFO] [stdout] test executor_test::restore_bans_keeps_permanent ... ok [INFO] [stdout] test date_test::wrong_format_returns_none ... ok [INFO] [stdout] test executor_test::create_backend_nftables ... ok [INFO] [stdout] test executor_test::script_substitute ... ok [INFO] [stdout] test executor_test::script_substitute_multiple_occurrences ... ok [INFO] [stdout] test executor_test::restore_bans_skips_on_backend_error ... ok [INFO] [stdout] test executor_test::script_substitute_no_placeholders ... ok [INFO] [stdout] test executor_test::script_substitute_ipv6 ... ok [INFO] [stdout] test date_test::epoch_nine_digits_no_match ... ok [INFO] [stdout] test filters_test::all_filters_have_host ... ok [INFO] [stdout] test filters_test::find_nonexistent ... ok [INFO] [stdout] test date_test::syslog_single_digit_day ... ok [INFO] [stdout] test date_test::epoch_format ... ok [INFO] [stdout] test filters_test::find_sshd ... ok [INFO] [stdout] test date_test::epoch_ten_digits_matches ... ok [INFO] [stdout] test filters_test::filter_count ... ok [INFO] [stdout] test filters_test::gen_config_all_services ... ok [INFO] [stdout] test filters_test::gen_config_sshd ... ok [INFO] [stdout] test ignore_test::invalid_cidr_errors ... ok [INFO] [stdout] test ignore_test::cidr_match ... ok [INFO] [stdout] test ignore_test::single_host_cidr ... ok [INFO] [stdout] test ignore_test::empty_list_ignores_nothing ... ok [INFO] [stdout] test ignore_test::ignoreself_includes_loopback ... ok [INFO] [stdout] test logging_test::init_none_without_api_key ... ok [INFO] [stdout] test logging_test::init_none_with_unsupported_destination ... ok [INFO] [stdout] test logging_test::init_none_without_destination ... ok [INFO] [stdout] test matcher_test::empty_patterns_error ... ok [INFO] [stdout] test date_test::common_log_format ... ok [INFO] [stdout] test logging_test::default_logging_config ... ok [INFO] [stdout] test ignore_test::ipv6_cidr ... ok [INFO] [stdout] test matcher_test::ignoreregex_does_not_suppress_non_matching ... ok [INFO] [stdout] test matcher_test::empty_line ... ok [INFO] [stdout] test matcher_test::ignoreregex_empty_is_noop ... ok [INFO] [stdout] test matcher_test::ac_passes_but_regex_fails ... ok [INFO] [stdout] test matcher_test::ignoreregex_multiple_patterns ... ok [INFO] [stdout] test matcher_test::ignoreregex_suppresses_match ... ok [INFO] [stdout] test filters_test::sshd_patterns_match_real_lines ... ok [INFO] [stdout] test matcher_test::no_ac_prefix_still_matches ... ok [INFO] [stdout] test matcher_test::match_ipv6 ... ok [INFO] [stdout] test matcher_test::multiple_patterns_first_wins ... ok [INFO] [stdout] test matcher_test::match_invalid_user ... ok [INFO] [stdout] test date_test::common_invalid_month_returns_none ... ok [INFO] [stdout] test matcher_test::no_match_normal_log ... ok [INFO] [stdout] test pattern_test::expand_host_ipv6 ... ok [INFO] [stdout] test executor_test::ban_and_unban_order ... ok [INFO] [stdout] test pattern_test::expand_host_empty_pattern ... ok [INFO] [stdout] test executor_test::save_state_command ... ok [INFO] [stdout] test pattern_test::expand_host_ipv4 ... ok [INFO] [stdout] test matcher_test::various_ipv4 ... ok [INFO] [stdout] test pattern_test::expand_host_multiple ... ok [INFO] [stdout] test pattern_test::expand_host_missing ... ok [INFO] [stdout] test pattern_test::literal_prefix_boundary_three_chars ... ok [INFO] [stdout] test pattern_test::literal_prefix_boundary_two_chars ... ok [INFO] [stdout] test pattern_test::literal_prefix_all_metacharacters ... ok [INFO] [stdout] test pattern_test::literal_prefix_dot_treated_as_meta ... ok [INFO] [stdout] test pattern_test::literal_prefix_none ... ok [INFO] [stdout] test pattern_test::literal_prefix_short ... ok [INFO] [stdout] test pattern_test::literal_prefix_fallback_too_short ... ok [INFO] [stdout] test executor_test::two_jails_different_backends_dispatch_correctly ... ok [INFO] [stdout] test pattern_test::literal_prefix_ssh ... ok [INFO] [stdout] test pattern_test::expand_host_with_regex ... ok [INFO] [stdout] test pattern_test::literal_prefix_simple ... ok [INFO] [stdout] test security_test::bantime_factor_rejects_infinity ... ok [INFO] [stdout] test security_test::bantime_factor_rejects_negative ... ok [INFO] [stdout] test control_test::all_request_variants_through_socket ... ok [INFO] [stdout] test security_test::bantime_factor_accepts_valid ... ok [INFO] [stdout] test security_test::duration_negative_returns_value ... ok [INFO] [stdout] test control_test::request_response_roundtrip ... ok [INFO] [stdout] test matcher_test::invalid_ip_returns_none ... ok [INFO] [stdout] test regex_tool_test::test_pattern_no_match ... ok [INFO] [stdout] test security_test::jail_name_accepts_valid ... ok [INFO] [stdout] test security_test::jail_name_rejects_empty ... ok [INFO] [stdout] test security_test::bantime_factor_rejects_nan ... ok [INFO] [stdout] test security_test::jail_name_rejects_path_traversal ... ok [INFO] [stdout] test security_test::jail_name_rejects_shell_metacharacters ... ok [INFO] [stdout] test matcher_test::pattern_count ... ok [INFO] [stdout] test regex_tool_test::test_pattern_match ... ok [INFO] [stdout] test security_test::crafted_username_with_embedded_ip ... ok [INFO] [stdout] test security_test::port_validation_accepts_valid ... ok [INFO] [stdout] test security_test::port_validation_rejects_invalid ... ok [INFO] [stdout] test security_test::protocol_accepts_valid ... ok [INFO] [stdout] test security_test::protocol_rejects_invalid ... ok [INFO] [stdout] test server_test::response_error_serialization ... ok [INFO] [stdout] test security_test::duration_overflow_returns_error ... ok [INFO] [stdout] test security_test::script_ip_cannot_inject_shell ... ok [INFO] [stdout] test server_test::response_ok_serialization ... ok [INFO] [stdout] test server_test::stats_request_serialization ... ok [INFO] [stdout] test matcher_test::match_failed_password ... ok [INFO] [stdout] test server_test::status_request_response ... ok [INFO] [stdout] test state_test::missing_file_returns_none ... ok [INFO] [stdout] test state_test::file_too_small ... ok [INFO] [stdout] test security_test::unicode_in_log_line ... ok [INFO] [stdout] test server_test::response_ok_data_serialization ... ok [INFO] [stdout] test state_test::overwrite_existing_state ... ok [INFO] [stdout] test state_test::empty_snapshot ... ok [INFO] [stdout] test security_test::ipv6_various_forms ... ok [INFO] [stdout] test state_test::corrupt_crc ... ok [INFO] [stdout] test tracker_test::bans_after_threshold ... ok [INFO] [stdout] test regex_tool_test::test_patterns_no_match_any ... ok [INFO] [stdout] test tracker_test::manual_unban_via_cmd ... ok [INFO] [stdout] test state_test::wrong_magic ... ok [INFO] [stdout] test tracker_test::manual_ban_already_banned_error ... ok [INFO] [stdout] test state_test::wrong_version ... ok [INFO] [stdout] test tracker_test::manual_ban_via_cmd ... ok [INFO] [stdout] test tracker_test::query_bans_via_cmd ... ok [INFO] [stdout] test matcher_test::no_match_unrelated ... ok [INFO] [stdout] test state_test::roundtrip_ipv6 ... ok [INFO] [stdout] test state_test::roundtrip ... ok [INFO] [stdout] test tracker_test::same_ip_different_jails_tracked_independently ... ok [INFO] [stdout] test security_test::invalid_ip_octets_rejected ... ok [INFO] [stdout] test security_test::extremely_long_line_no_panic ... ok [INFO] [stdout] test regex_tool_test::test_patterns_multiple_first_wins ... ok [INFO] [stdout] test security_test::ip_followed_by_unicode ... ok [INFO] [stdout] test filters_test::all_patterns_compile ... ok [INFO] [stdout] test tracker_test::get_stats_via_cmd ... ok [INFO] [stdout] test webhook_test::notify_ban_does_not_panic ... ok [INFO] [stdout] test security_test::null_bytes_in_line ... ok [INFO] [stdout] test webhook_test::notify_unban_does_not_panic ... ok [INFO] [stdout] test tracker_test::no_ban_below_threshold ... ok [INFO] [stdout] test tracker_test::no_ban_outside_find_time ... ok [INFO] [stdout] test tracker_test::already_banned_ip_ignored ... ok [INFO] [stdout] test tracker_test::unknown_jail_failure_ignored ... ok [INFO] [stdout] test watcher_test::detects_failure_in_appended_lines ... ok [INFO] [stdout] test watcher_test::ignores_allowlisted_ips ... ok [INFO] [stdout] test watcher_test::ignores_non_matching_lines ... ok [INFO] [stdout] test tracker_test::restored_bans_populate_unban_queue ... ok [INFO] [stdout] test tracker_test::unban_timer_fires ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 222 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.20s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/fail2ban_rs-1540c0a62a0c3871) [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running tests/e2e_ban.rs (/opt/rustwide/target/debug/deps/e2e_ban-fcede4db10efe276) [INFO] [stdout] [INFO] [stdout] running 4 tests [INFO] [stdout] test circular_threshold ... ok [INFO] [stdout] test state_roundtrip ... ok [INFO] [stdout] test matcher_ssh_log ... ok [INFO] [stdout] test watcher_to_tracker_ban ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.52s [INFO] [stdout] [INFO] [stderr] Doc-tests fail2ban_rs [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "609bc5b21ba829f1acdfaac40113df4dd4e0cf335ba33d17fa4d50be31d61cdc", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "609bc5b21ba829f1acdfaac40113df4dd4e0cf335ba33d17fa4d50be31d61cdc", kill_on_drop: false }` [INFO] [stdout] 609bc5b21ba829f1acdfaac40113df4dd4e0cf335ba33d17fa4d50be31d61cdc