[INFO] fetching crate klik 0.7.0... [INFO] testing klik-0.7.0 against try#b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b for pr-145330-1 [INFO] extracting crate klik 0.7.0 into /workspace/builds/worker-0-tc2/source [INFO] started tweaking crates.io crate klik 0.7.0 [INFO] finished tweaking crates.io crate klik 0.7.0 [INFO] tweaked toml for crates.io crate klik 0.7.0 written to /workspace/builds/worker-0-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate klik 0.7.0 on toolchain b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate klik 0.7.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" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 59513bd1e2dcd417ce60a69ac04bb45322402ef5bec5409bc12f880fd1d309ab [INFO] running `Command { std: "docker" "start" "-a" "59513bd1e2dcd417ce60a69ac04bb45322402ef5bec5409bc12f880fd1d309ab", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "59513bd1e2dcd417ce60a69ac04bb45322402ef5bec5409bc12f880fd1d309ab", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "59513bd1e2dcd417ce60a69ac04bb45322402ef5bec5409bc12f880fd1d309ab", kill_on_drop: false }` [INFO] [stdout] 59513bd1e2dcd417ce60a69ac04bb45322402ef5bec5409bc12f880fd1d309ab [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 63ab3bcc119864d0ce1aea7a32a0a4fad79b0dee4d8765361419cd4ab45d18ef [INFO] running `Command { std: "docker" "start" "-a" "63ab3bcc119864d0ce1aea7a32a0a4fad79b0dee4d8765361419cd4ab45d18ef", kill_on_drop: false }` [INFO] [stderr] Compiling zerocopy v0.8.25 [INFO] [stderr] Compiling ahash v0.8.12 [INFO] [stderr] Compiling lock_api v0.4.13 [INFO] [stderr] Compiling signal-hook v0.3.18 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling cc v1.2.26 [INFO] [stderr] Compiling syn v2.0.101 [INFO] [stderr] Compiling getrandom v0.2.16 [INFO] [stderr] Compiling signal-hook-registry v1.4.5 [INFO] [stderr] Compiling parking_lot_core v0.9.11 [INFO] [stderr] Compiling mio v1.0.4 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling allocator-api2 v0.2.21 [INFO] [stderr] Compiling linux-raw-sys v0.4.15 [INFO] [stderr] Compiling anstyle-query v1.1.3 [INFO] [stderr] Compiling castaway v0.2.3 [INFO] [stderr] Compiling anstream v0.6.19 [INFO] [stderr] Compiling indoc v2.0.6 [INFO] [stderr] Compiling unicode-segmentation v1.12.0 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling option-ext v0.2.0 [INFO] [stderr] Compiling dirs-sys v0.4.1 [INFO] [stderr] Compiling compact_str v0.8.1 [INFO] [stderr] Compiling parking_lot v0.12.4 [INFO] [stderr] Compiling signal-hook-mio v0.2.4 [INFO] [stderr] Compiling hashbrown v0.15.4 [INFO] [stderr] Compiling clap_builder v4.5.39 [INFO] [stderr] Compiling unicode-truncate v1.1.0 [INFO] [stderr] Compiling include_dir_macros v0.7.4 [INFO] [stderr] Compiling fallible-iterator v0.3.0 [INFO] [stderr] Compiling home v0.5.11 [INFO] [stderr] Compiling unicode-width v0.2.0 [INFO] [stderr] Compiling cassowary v0.3.0 [INFO] [stderr] Compiling fallible-streaming-iterator v0.1.9 [INFO] [stderr] Compiling iana-time-zone v0.1.63 [INFO] [stderr] Compiling include_dir v0.7.4 [INFO] [stderr] Compiling directories v5.0.1 [INFO] [stderr] Compiling time-humanize v0.1.3 [INFO] [stderr] Compiling crossterm v0.28.1 [INFO] [stderr] Compiling lru v0.12.5 [INFO] [stderr] Compiling libsqlite3-sys v0.30.1 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling hashbrown v0.14.5 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling cgisf_lib v0.1.3 [INFO] [stderr] Compiling hashlink v0.9.1 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling darling_core v0.20.11 [INFO] [stderr] Compiling zerovec-derive v0.11.1 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling strum_macros v0.26.4 [INFO] [stderr] Compiling clap_derive v4.5.32 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.0 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.0 [INFO] [stderr] Compiling zerotrie v0.2.2 [INFO] [stderr] Compiling zerovec v0.11.2 [INFO] [stderr] Compiling clap v4.5.39 [INFO] [stderr] Compiling strum v0.26.3 [INFO] [stderr] Compiling darling_macro v0.20.11 [INFO] [stderr] Compiling tinystr v0.8.1 [INFO] [stderr] Compiling potential_utf v0.1.2 [INFO] [stderr] Compiling icu_collections v2.0.0 [INFO] [stderr] Compiling darling v0.20.11 [INFO] [stderr] Compiling icu_locale_core v2.0.0 [INFO] [stderr] Compiling instability v0.3.7 [INFO] [stderr] Compiling serde v1.0.219 [INFO] [stderr] Compiling icu_provider v2.0.0 [INFO] [stderr] Compiling ratatui v0.29.0 [INFO] [stderr] Compiling icu_properties v2.0.1 [INFO] [stderr] Compiling icu_normalizer v2.0.0 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.0.3 [INFO] [stderr] Compiling url v2.5.4 [INFO] [stderr] Compiling webbrowser v1.0.4 [INFO] [stderr] Compiling serde_json v1.0.140 [INFO] [stderr] Compiling chrono v0.4.41 [INFO] [stderr] Compiling rusqlite v0.32.1 [INFO] [stderr] Compiling klik v0.7.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 44.45s [INFO] running `Command { std: "docker" "inspect" "63ab3bcc119864d0ce1aea7a32a0a4fad79b0dee4d8765361419cd4ab45d18ef", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "63ab3bcc119864d0ce1aea7a32a0a4fad79b0dee4d8765361419cd4ab45d18ef", kill_on_drop: false }` [INFO] [stdout] 63ab3bcc119864d0ce1aea7a32a0a4fad79b0dee4d8765361419cd4ab45d18ef [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 4c95362802f5655654ea8a6f718811fe92d1c1763cefeaa0daf77cdc2b67d87f [INFO] running `Command { std: "docker" "start" "-a" "4c95362802f5655654ea8a6f718811fe92d1c1763cefeaa0daf77cdc2b67d87f", kill_on_drop: false }` [INFO] [stderr] Compiling ahash v0.8.12 [INFO] [stderr] Compiling getrandom v0.3.3 [INFO] [stderr] Compiling rustix v1.0.7 [INFO] [stderr] Compiling assert_matches v1.5.0 [INFO] [stderr] Compiling hashbrown v0.14.5 [INFO] [stderr] Compiling hashlink v0.9.1 [INFO] [stderr] Compiling rusqlite v0.32.1 [INFO] [stderr] Compiling tempfile v3.20.0 [INFO] [stderr] Compiling klik v0.7.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 9.38s [INFO] running `Command { std: "docker" "inspect" "4c95362802f5655654ea8a6f718811fe92d1c1763cefeaa0daf77cdc2b67d87f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4c95362802f5655654ea8a6f718811fe92d1c1763cefeaa0daf77cdc2b67d87f", kill_on_drop: false }` [INFO] [stdout] 4c95362802f5655654ea8a6f718811fe92d1c1763cefeaa0daf77cdc2b67d87f [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+b6ae10aa7319b7ebb6c7b3331dd71a9d6c9c5b4b" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] bb0f42cbc378ad2344e04e750176f8e2f80c0ae40c524329082c4c78137d0139 [INFO] running `Command { std: "docker" "start" "-a" "bb0f42cbc378ad2344e04e750176f8e2f80c0ae40c524329082c4c78137d0139", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.19s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/klik-c99ea26ca661b381) [INFO] [stdout] [INFO] [stdout] running 219 tests [INFO] [stdout] test celebration::tests::test_celebration_animation_imperfect_session ... ok [INFO] [stdout] test celebration::tests::test_celebration_particle_physics ... ok [INFO] [stdout] test celebration::tests::test_celebration_animation_perfect_session ... ok [INFO] [stdout] test celebration::tests::test_encouraging_words_selection ... ok [INFO] [stdout] test language::formatter::tests::test_basic_formatter ... ok [INFO] [stdout] test language::formatter::tests::test_capitalization_formatter ... ok [INFO] [stdout] test celebration::tests::test_particles_removed_when_off_screen ... ok [INFO] [stdout] test celebration::tests::test_text_particle_movement ... ok [INFO] [stdout] test language::core::tests::test_language_deserialization ... ok [INFO] [stdout] test language::core::tests::test_language_new ... ok [INFO] [stdout] test celebration::tests::test_celebration_particle_movement ... ok [INFO] [stdout] test language::core::tests::test_language_new_english1k ... ok [INFO] [stdout] test language::core::tests::test_read_language_from_file ... ok [INFO] [stdout] test language::formatter::tests::test_capitalize_first_letter ... ok [INFO] [stdout] test language::formatter::tests::test_combined_formatter_functionality ... ok [INFO] [stdout] test language::formatter::tests::test_combined_formatter_capitalization_guaranteed ... ok [INFO] [stdout] test language::formatter::tests::test_formatters_with_empty_input ... ok [INFO] [stdout] test language::formatting::tests::test_capitalize_first_letter ... ok [INFO] [stdout] test language::formatting::tests::test_flag_independence_neither ... ok [INFO] [stdout] test language::formatter::tests::test_combined_formatter_empty_input ... ok [INFO] [stdout] test language::formatter::tests::test_composite_formatter_build_from_flags ... ok [INFO] [stdout] test language::formatter::tests::test_composite_formatter_new_and_add ... ok [INFO] [stdout] test language::formatter::tests::test_formatters_with_single_word ... ok [INFO] [stdout] test language::formatting::tests::test_apply_advanced_formatting_basic ... ok [INFO] [stdout] test language::selection::tests::test_get_random_single_word ... ok [INFO] [stdout] test language::formatting::tests::test_flag_independence_capitalize_only ... ok [INFO] [stdout] test language::formatting::tests::test_flag_independence_symbols_only ... ok [INFO] [stdout] test language::selection::tests::test_get_random_words ... ok [INFO] [stdout] test language::selector::tests::test_calculate_word_difficulty_score ... ok [INFO] [stdout] test language::selector::tests::test_calculate_word_difficulty_score_edge_cases ... ok [INFO] [stdout] test language::selection::tests::test_get_random_zero_words ... ok [INFO] [stdout] test language::selector::tests::test_word_selectors_with_different_counts ... ok [INFO] [stdout] test language::selection::tests::test_get_substituted_returns_correct_count ... ok [INFO] [stdout] test language::selector::tests::test_random_selector ... ok [INFO] [stdout] test language::selector::tests::test_get_weakest_characters ... ok [INFO] [stdout] test language::selector::tests::test_calculate_word_difficulty_score_with_uppercase ... ok [INFO] [stdout] test language::selector::tests::test_intelligent_selector ... ok [INFO] [stdout] test language::tests::test_integrated_functionality ... ok [INFO] [stdout] test language::formatter::tests::test_symbol_formatter ... ok [INFO] [stdout] test language::sentences::tests::test_get_random_sentence_word_count_accuracy ... ok [INFO] [stdout] test language::sentences::tests::test_get_random_sentence ... ok [INFO] [stdout] test language::formatter::tests::test_combined_formatter_debug_comma_issue ... ok [INFO] [stdout] test stats::tests::test_auto_compact ... ok [INFO] [stdout] test language::selector::tests::test_intelligent_selector_with_limited_words ... ok [INFO] [stdout] test language::selection::tests::test_intelligent_selection_prioritizes_difficult_characters ... ok [INFO] [stdout] test language::selector::tests::test_substitute_characters_in_word ... ok [INFO] [stdout] test language::selector::tests::test_substitution_selector ... ok [INFO] [stdout] test language::selector::tests::test_selector_fallback_to_random ... ok [INFO] [stdout] test stats::tests::test_compaction_info ... ok [INFO] [stdout] test language::sentences::tests::test_get_random_sentence_zero ... ok [INFO] [stdout] test language::tests::test_substitution_with_formatting ... ok [INFO] [stdout] test language::sentences::tests::test_get_random_sentence_single ... ok [INFO] [stdout] test stats::tests::test_extract_context ... ok [INFO] [stdout] test stats::tests::test_extract_context_at_end ... ok [INFO] [stdout] test stats::tests::test_extract_context_at_beginning ... ok [INFO] [stdout] test stats::tests::test_current_session_summary ... ok [INFO] [stdout] test language::core::tests::test_language_new_english10k ... ok [INFO] [stdout] test stats::tests::test_session_count ... ok [INFO] [stdout] test stats::tests::test_database_size ... ok [INFO] [stdout] test stats::tests::test_clear_all_stats ... ok [INFO] [stdout] test stats::tests::test_compaction_with_no_old_data ... ok [INFO] [stdout] test stats::tests::test_session_aggregation ... ok [INFO] [stdout] test stats::tests::test_flush ... ok [INFO] [stdout] test stats::tests::test_char_summary_with_new_character ... ok [INFO] [stdout] test stats::tests::test_char_summary_with_deltas ... ok [INFO] [stdout] test stats::tests::test_record_and_retrieve_aggregated_stats ... ok [INFO] [stdout] test stats::tests::test_time_diff_ms ... ok [INFO] [stdout] test stats::tests::test_needs_compaction ... ok [INFO] [stdout] test stats::tests::test_compaction_preserves_data ... ok [INFO] [stdout] test tests::test_app_state_variants ... ok [INFO] [stdout] test tests::test_char_stats_state_default ... ok [INFO] [stdout] test tests::test_cli_number_of_secs ... ok [INFO] [stdout] test tests::test_cli_custom_prompt ... ok [INFO] [stdout] test tests::test_cli_default_values ... ok [INFO] [stdout] test tests::test_cli_number_of_sentences ... ok [INFO] [stdout] test tests::test_app_new_with_sentences ... ok [INFO] [stdout] test tests::test_app_reset_without_new_prompt ... ok [INFO] [stdout] test tests::test_app_reset_with_new_prompt ... ok [INFO] [stdout] test tests::test_character_stats_scrolling ... ok [INFO] [stdout] test tests::test_character_stats_sorting ... ok [INFO] [stdout] test tests::test_app_state_transitions ... ok [INFO] [stdout] test tests::test_app_new_with_custom_prompt ... ok [INFO] [stdout] test tests::test_app_new_with_words ... ok [INFO] [stdout] test tests::test_app_new_with_time_limit ... ok [INFO] [stdout] test tests::test_app_state_clone ... ok [INFO] [stdout] test tests::test_cli_to_word_gen_config ... ok [INFO] [stdout] test tests::test_cli_number_of_words ... ok [INFO] [stdout] test tests::test_get_thok_events_no_tick ... ok [INFO] [stdout] test tests::test_cli_supported_language ... ok [INFO] [stdout] test tests::test_exit_type_variants ... ok [INFO] [stdout] test tests::test_sort_by_variants ... ok [INFO] [stdout] test tests::test_cli_to_word_gen_config_with_custom_prompt ... ok [INFO] [stdout] test language::core::tests::test_read_nonexistent_language_file - should panic ... ok [INFO] [stdout] test tests::test_get_thok_events_with_tick ... ok [INFO] [stdout] test tests::test_supported_language_enum_variants ... ok [INFO] [stdout] test tests::test_thok_event_clone ... ok [INFO] [stdout] test tests::test_exit_type_debug ... ok [INFO] [stdout] test tests::test_supported_language_display ... ok [INFO] [stdout] test tests::test_tick_rate_constant ... ok [INFO] [stdout] test tests::test_integration_complete_typing_session ... ok [INFO] [stdout] test thok::tests::test_backspace ... ok [INFO] [stdout] test tests::test_supported_language_as_lang ... ok [INFO] [stdout] test tests::test_strict_mode_flag ... ok [INFO] [stdout] test thok::tests::test_boundary_conditions_cursor_limits ... ok [INFO] [stdout] test thok::tests::test_backspace_at_start ... ok [INFO] [stdout] test thok::tests::test_calc_results_empty_input ... ok [INFO] [stdout] test thok::tests::test_boundary_conditions_time_precision ... ok [INFO] [stdout] test thok::tests::test_auto_compaction_integration ... ok [INFO] [stdout] test tests::test_ui_function_typing_state ... ok [INFO] [stdout] test thok::tests::test_celebration_animation_imperfect_session ... ok [INFO] [stdout] test tests::test_render_character_stats_with_data ... ok [INFO] [stdout] test thok::tests::test_celebration_triggers_on_perfect_session ... ok [INFO] [stdout] test thok::tests::test_calc_results_with_errors ... ok [INFO] [stdout] test thok::tests::test_calc_results_flushes_stats ... ok [INFO] [stdout] test thok::tests::test_database_path_and_creation ... ok [INFO] [stdout] test thok::tests::test_calc_results_basic ... ok [INFO] [stdout] test thok::tests::test_decrement_cursor ... ok [INFO] [stdout] test thok::tests::test_character_statistics_methods ... ok [INFO] [stdout] test thok::tests::test_edge_case_negative_time_limit ... ok [INFO] [stdout] test thok::tests::test_edge_case_single_character_prompt ... ok [INFO] [stdout] test thok::tests::test_database_path_retrieval ... ok [INFO] [stdout] test thok::tests::test_char_summary_with_deltas_integration ... ok [INFO] [stdout] test thok::tests::test_edge_case_zero_time_limit ... ok [INFO] [stdout] test thok::tests::test_error_handling_backspace_at_start ... ok [INFO] [stdout] test thok::tests::test_edge_case_unicode_characters ... ok [INFO] [stdout] test tests::test_integration_formatting_combinations ... ok [INFO] [stdout] test thok::tests::test_error_handling_calc_results_no_input ... ok [INFO] [stdout] test tests::test_render_character_stats_no_data ... ok [INFO] [stdout] test thok::tests::test_error_handling_calc_results_zero_time ... ok [INFO] [stdout] test thok::tests::test_error_handling_invalid_cursor_position ... ok [INFO] [stdout] test thok::tests::test_error_handling_null_character ... ok [INFO] [stdout] test thok::tests::test_edge_case_empty_prompt ... ok [INFO] [stdout] test thok::tests::test_celebration_animation_perfect_session ... ok [INFO] [stdout] test thok::tests::test_error_handling_multiple_backspaces ... ok [INFO] [stdout] test thok::tests::test_has_finished_by_completion ... ok [INFO] [stdout] test thok::tests::test_get_expected_char ... ok [INFO] [stdout] test thok::tests::test_edge_case_very_long_prompt ... ok [INFO] [stdout] test thok::tests::test_has_finished_by_time ... ok [INFO] [stdout] test thok::tests::test_idle_state_reset ... ok [INFO] [stdout] test thok::tests::test_input_creation ... ok [INFO] [stdout] test thok::tests::test_error_handling_stats_database_failure ... ok [INFO] [stdout] test thok::tests::test_increment_cursor ... ok [INFO] [stdout] test thok::tests::test_mark_activity_not_idle ... ok [INFO] [stdout] test tests::test_integration_strict_mode_workflow ... ok [INFO] [stdout] test thok::tests::test_on_tick ... ok [INFO] [stdout] test thok::tests::test_keypress_timing_reset ... ok [INFO] [stdout] test thok::tests::test_outcome_equality ... ok [INFO] [stdout] test thok::tests::test_normal_mode_vs_strict_mode ... ok [INFO] [stdout] test tests::test_integration_app_reset_preserves_cli_settings ... ok [INFO] [stdout] test thok::tests::test_strict_mode_backspace ... ok [INFO] [stdout] test thok::tests::test_strict_mode_cursor_behavior ... ok [INFO] [stdout] test thok::tests::test_thok_new_with_time_limit ... ok [INFO] [stdout] test thok::tests::test_thok_new ... ok [INFO] [stdout] test thok::tests::test_keypress_timing ... ok [INFO] [stdout] test thok::tests::test_session_delta_summary ... ok [INFO] [stdout] test thok::tests::test_flush_char_stats ... ok [INFO] [stdout] test thok::tests::test_timing_initialization ... ok [INFO] [stdout] test thok::tests::test_database_compaction_methods ... ok [INFO] [stdout] test tests::test_integration_timed_session ... ok [INFO] [stdout] test thok::tests::test_error_handling_special_characters ... ok [INFO] [stdout] test thok::tests::test_write_incorrect_char ... ok [INFO] [stdout] test tests::test_integration_character_substitution_workflow ... ok [INFO] [stdout] test ui::tests::test_ui_constants ... ok [INFO] [stdout] test ui::tests::test_ui_constants_consistency ... ok [INFO] [stdout] test thok::tests::test_write_correct_char ... ok [INFO] [stdout] test ui::tests::test_ui_widget_color_consistency ... ok [INFO] [stdout] test tests::test_flag_independence_at_app_level ... ok [INFO] [stdout] test ui::tests::test_ui_widget_different_aspect_ratios ... ok [INFO] [stdout] test tests::test_ui_function_results_state ... ok [INFO] [stdout] test thok::tests::test_training_session_integration_single_session ... ok [INFO] [stdout] test thok::tests::test_training_session_database_compaction_integration ... ok [INFO] [stdout] test ui::tests::test_ui_widget_large_prompt ... ok [INFO] [stdout] test ui::tests::test_ui_widget_partial_typing ... ok [INFO] [stdout] test ui::tests::test_ui_widget_in_progress ... ok [INFO] [stdout] test ui::tests::test_ui_widget_render_multiple_times ... ok [INFO] [stdout] test tests::test_ui_function_character_stats_state ... ok [INFO] [stdout] test ui::tests::test_ui_widget_performance_large_text ... ok [INFO] [stdout] test ui::tests::test_ui_widget_special_characters ... ok [INFO] [stdout] test ui::tests::test_ui_widget_renders_without_panic ... ok [INFO] [stdout] test ui::tests::test_ui_widget_with_incorrect_input ... ok [INFO] [stdout] test ui::tests::test_ui_widget_with_newlines_in_prompt ... ok [INFO] [stdout] test ui::tests::test_ui_widget_empty_prompt ... ok [INFO] [stdout] test tests::test_integration_multiple_language_support ... ok [INFO] [stdout] test util::tests::test_mean ... ok [INFO] [stdout] test ui::tests::test_ui_widget_with_time_limit ... ok [INFO] [stdout] test util::tests::test_mean_negative_values ... ok [INFO] [stdout] test util::tests::test_mean_single_value ... ok [INFO] [stdout] test util::tests::test_std_dev ... ok [INFO] [stdout] test ui::tests::test_ui_widget_small_area ... ok [INFO] [stdout] test util::tests::test_std_dev_empty_slice ... ok [INFO] [stdout] test util::tests::test_std_dev_identical_values ... ok [INFO] [stdout] test util::tests::test_std_dev_single_value ... ok [INFO] [stdout] test word_generator::tests::test_config_conversion ... ok [INFO] [stdout] test word_generator::tests::test_custom_prompt ... ok [INFO] [stdout] test word_generator::tests::test_generate_prompt_respects_custom_prompt ... ok [INFO] [stdout] test word_generator::tests::test_priority_order_custom_prompt_over_sentences ... ok [INFO] [stdout] test util::tests::test_std_dev_negative_values ... ok [INFO] [stdout] test word_generator::tests::test_sentences_when_no_custom_prompt ... ok [INFO] [stdout] test word_generator::tests::test_word_generation_combined_flags ... ok [INFO] [stdout] test word_generator::tests::test_sentence_generation ... ok [INFO] [stdout] test util::tests::test_mean_mixed_values ... ok [INFO] [stdout] test word_generator::tests::test_word_generation_intelligent_selection ... ok [INFO] [stdout] test word_generator::tests::test_word_generation_random ... ok [INFO] [stdout] test word_generator::tests::test_word_generation_with_capitalization ... ok [INFO] [stdout] test word_generator::tests::test_word_generation_with_substitution ... ok [INFO] [stdout] test word_generator::tests::test_word_generation_with_symbols_only ... ok [INFO] [stdout] test util::tests::test_mean_empty_slice ... ok [INFO] [stdout] test ui::tests::test_ui_widget_extreme_sizes ... ok [INFO] [stdout] test ui::tests::test_celebration_animation_rendering ... ok [INFO] [stdout] test ui::tests::test_ui_widget_finished ... ok [INFO] [stdout] test thok::tests::test_real_typing_saves_to_database ... ok [INFO] [stdout] test ui::tests::test_ui_widget_finished_with_browser_available ... ok [INFO] [stdout] test thok::tests::test_inter_keystroke_timing ... ok [INFO] [stdout] test ui::tests::test_ui_widget_with_errors ... ok [INFO] [stdout] test thok::tests::test_training_session_character_difficulty_tracking ... ok [INFO] [stdout] test thok::tests::test_training_session_stats_ui_integration ... ok [INFO] [stdout] test thok::tests::test_training_session_celebration_integration ... ok [INFO] [stdout] test thok::tests::test_fresh_database_with_realistic_timing ... ok [INFO] [stdout] test thok::tests::test_training_session_integration_multiple_sessions ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 219 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.03s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "bb0f42cbc378ad2344e04e750176f8e2f80c0ae40c524329082c4c78137d0139", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "bb0f42cbc378ad2344e04e750176f8e2f80c0ae40c524329082c4c78137d0139", kill_on_drop: false }` [INFO] [stdout] bb0f42cbc378ad2344e04e750176f8e2f80c0ae40c524329082c4c78137d0139