[INFO] cloning repository https://github.com/permacommons/chabeau [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/permacommons/chabeau" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpermacommons%2Fchabeau", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpermacommons%2Fchabeau'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 14e3c1f3ae5b71cd21738294433fb6ff6395c0e9 [INFO] testing permacommons/chabeau against try#a7ee93192a766fb0dafa23def7154fc03cfcfc3e for pr-146989 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fpermacommons%2Fchabeau" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/permacommons/chabeau [INFO] finished tweaking git repo https://github.com/permacommons/chabeau [INFO] tweaked toml for git repo https://github.com/permacommons/chabeau written to /workspace/builds/worker-5-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/permacommons/chabeau on toolchain a7ee93192a766fb0dafa23def7154fc03cfcfc3e [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+a7ee93192a766fb0dafa23def7154fc03cfcfc3e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/permacommons/chabeau 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" "+a7ee93192a766fb0dafa23def7154fc03cfcfc3e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+a7ee93192a766fb0dafa23def7154fc03cfcfc3e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 5370d37c54d6a94dbf6c5471b3828e255964393779258b8b43166484a924415a [INFO] running `Command { std: "docker" "start" "-a" "5370d37c54d6a94dbf6c5471b3828e255964393779258b8b43166484a924415a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "5370d37c54d6a94dbf6c5471b3828e255964393779258b8b43166484a924415a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5370d37c54d6a94dbf6c5471b3828e255964393779258b8b43166484a924415a", kill_on_drop: false }` [INFO] [stdout] 5370d37c54d6a94dbf6c5471b3828e255964393779258b8b43166484a924415a [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+a7ee93192a766fb0dafa23def7154fc03cfcfc3e" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 50655dcfbf0e5353e9b27ee36b0f2fef6f20a01fa902dca8896cfeb9b4c11fd9 [INFO] running `Command { std: "docker" "start" "-a" "50655dcfbf0e5353e9b27ee36b0f2fef6f20a01fa902dca8896cfeb9b4c11fd9", kill_on_drop: false }` [INFO] [stderr] Compiling syn v2.0.110 [INFO] [stderr] Compiling cc v1.2.45 [INFO] [stderr] Compiling mio v1.1.0 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling time v0.3.44 [INFO] [stderr] Compiling camino v1.2.1 [INFO] [stderr] Compiling serde_json v1.0.145 [INFO] [stderr] Compiling rustls v0.23.35 [INFO] [stderr] Compiling unicase v2.8.1 [INFO] [stderr] Compiling cookie v0.18.1 [INFO] [stderr] Compiling anyhow v1.0.100 [INFO] [stderr] Compiling vergen-lib v0.1.6 [INFO] [stderr] Compiling percent-encoding v2.3.2 [INFO] [stderr] Compiling mime_guess v2.0.5 [INFO] [stderr] Compiling form_urlencoded v1.2.2 [INFO] [stderr] Compiling vergen v9.0.6 [INFO] [stderr] Compiling libdbus-sys v0.2.6 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling litrs v1.0.0 [INFO] [stderr] Compiling regex v1.12.2 [INFO] [stderr] Compiling signal-hook v0.3.18 [INFO] [stderr] Compiling document-features v0.2.12 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling libz-sys v1.1.22 [INFO] [stderr] Compiling libgit2-sys v0.18.2+1.9.1 [INFO] [stderr] Compiling onig_sys v69.9.1 [INFO] [stderr] Compiling vergen-git2 v1.0.7 [INFO] [stderr] Compiling sysinfo v0.34.2 [INFO] [stderr] Compiling instability v0.3.9 [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling itertools v0.13.0 [INFO] [stderr] Compiling semver v1.0.27 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling darling_core v0.20.11 [INFO] [stderr] Compiling rustc_version v0.4.1 [INFO] [stderr] Compiling hashbrown v0.15.5 [INFO] [stderr] Compiling signal-hook-mio v0.2.5 [INFO] [stderr] Compiling castaway v0.2.4 [INFO] [stderr] Compiling simd-adler32 v0.3.7 [INFO] [stderr] Compiling indoc v2.0.7 [INFO] [stderr] Compiling anstream v0.6.21 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling zeroize_derive v1.4.2 [INFO] [stderr] Compiling darling_macro v0.20.11 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling zeroize v1.8.2 [INFO] [stderr] Compiling darling v0.20.11 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling thiserror-impl v2.0.17 [INFO] [stderr] Compiling rustls-pki-types v1.13.0 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling tokio v1.48.0 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling derive_builder_core v0.20.2 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling thiserror v2.0.17 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling icu_properties v2.1.1 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling rustls-webpki v0.103.8 [INFO] [stderr] Compiling derive_builder_macro v0.20.2 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling derive_builder v0.20.2 [INFO] [stderr] Compiling cargo-platform v0.1.9 [INFO] [stderr] Compiling cargo_metadata v0.19.2 [INFO] [stderr] Compiling webpki-roots v1.0.4 [INFO] [stderr] Compiling url v2.5.7 [INFO] [stderr] Compiling publicsuffix v2.3.0 [INFO] [stderr] Compiling hyper v1.7.0 [INFO] [stderr] Compiling tower v0.5.2 [INFO] [stderr] Compiling hyper-util v0.1.17 [INFO] [stderr] Compiling cookie_store v0.21.1 [INFO] [stderr] Compiling tower-http v0.6.6 [INFO] [stderr] Compiling tokio-util v0.7.17 [INFO] [stderr] Compiling futures-executor v0.3.31 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling strum_macros v0.26.4 [INFO] [stderr] Compiling futures v0.3.31 [INFO] [stderr] Compiling tokio-stream v0.1.18 [INFO] [stderr] Compiling rust-mcp-schema v0.9.4 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling compact_str v0.8.1 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling strum v0.26.3 [INFO] [stderr] Compiling unicode-truncate v1.1.0 [INFO] [stderr] Compiling reqwest v0.12.24 [INFO] [stderr] Compiling dbus v0.9.9 [INFO] [stderr] Compiling crossterm v0.28.1 [INFO] [stderr] Compiling lru v0.12.5 [INFO] [stderr] Compiling regex-automata v0.4.13 [INFO] [stderr] Compiling quick-xml v0.38.3 [INFO] [stderr] Compiling winnow v0.7.13 [INFO] [stderr] Compiling pulldown-cmark v0.13.0 [INFO] [stderr] Compiling cassowary v0.3.0 [INFO] [stderr] Compiling clap_lex v0.7.6 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling clap_builder v4.5.51 [INFO] [stderr] Compiling toml_parser v1.0.4 [INFO] [stderr] Compiling dbus-secret-service v4.1.0 [INFO] [stderr] Compiling ratatui v0.29.0 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling plist v1.8.0 [INFO] [stderr] Compiling rust-mcp-transport v0.8.0 [INFO] [stderr] Compiling flate2 v1.1.5 [INFO] [stderr] Compiling onig v6.5.1 [INFO] [stderr] Compiling bincode v1.3.3 [INFO] [stderr] Compiling clap_derive v4.5.49 [INFO] [stderr] Compiling uuid v1.19.0 [INFO] [stderr] Compiling getopts v0.2.24 [INFO] [stderr] Compiling tracing-log v0.2.0 [INFO] [stderr] Compiling toml_datetime v0.7.3 [INFO] [stderr] Compiling serde_spanned v1.0.3 [INFO] [stderr] Compiling toml_writer v1.0.4 [INFO] [stderr] Compiling pulldown-cmark-escape v0.11.0 [INFO] [stderr] Compiling toml v0.9.8 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling chrono v0.4.42 [INFO] [stderr] Compiling clap v4.5.51 [INFO] [stderr] Compiling syntect v5.3.0 [INFO] [stderr] Compiling tui-textarea v0.7.0 [INFO] [stderr] Compiling directories v6.0.0 [INFO] [stderr] Compiling keyring v3.6.3 [INFO] [stderr] Compiling rust-mcp-sdk v0.8.2 [INFO] [stderr] Compiling git2 v0.20.2 [INFO] [stderr] Compiling chabeau v0.6.1-dev (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 4m 03s [INFO] running `Command { std: "docker" "inspect" "50655dcfbf0e5353e9b27ee36b0f2fef6f20a01fa902dca8896cfeb9b4c11fd9", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "50655dcfbf0e5353e9b27ee36b0f2fef6f20a01fa902dca8896cfeb9b4c11fd9", kill_on_drop: false }` [INFO] [stdout] 50655dcfbf0e5353e9b27ee36b0f2fef6f20a01fa902dca8896cfeb9b4c11fd9 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+a7ee93192a766fb0dafa23def7154fc03cfcfc3e" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 51f043bdd7db50a1ec07ea37fa2918c689084608ccbe3417937bd69b41ff5b16 [INFO] running `Command { std: "docker" "start" "-a" "51f043bdd7db50a1ec07ea37fa2918c689084608ccbe3417937bd69b41ff5b16", kill_on_drop: false }` [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling zerocopy v0.8.27 [INFO] [stderr] Compiling regex-automata v0.4.13 [INFO] [stderr] Compiling zerocopy-derive v0.8.27 [INFO] [stderr] Compiling plotters-backend v0.3.7 [INFO] [stderr] Compiling cast v0.3.0 [INFO] [stderr] Compiling criterion-plot v0.6.0 [INFO] [stderr] Compiling plotters-svg v0.3.7 [INFO] [stderr] Compiling rayon v1.11.0 [INFO] [stderr] Compiling oorandom v11.1.5 [INFO] [stderr] Compiling plotters v0.3.7 [INFO] [stderr] Compiling anes v0.1.6 [INFO] [stderr] Compiling cargo-platform v0.1.9 [INFO] [stderr] Compiling url v2.5.7 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling cargo_metadata v0.19.2 [INFO] [stderr] Compiling rust-mcp-schema v0.9.4 [INFO] [stderr] Compiling cookie_store v0.21.1 [INFO] [stderr] Compiling git2 v0.20.2 [INFO] [stderr] Compiling bincode v1.3.3 [INFO] [stderr] Compiling plist v1.8.0 [INFO] [stderr] Compiling vergen v9.0.6 [INFO] [stderr] Compiling reqwest v0.12.24 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling half v2.7.1 [INFO] [stderr] Compiling syntect v5.3.0 [INFO] [stderr] Compiling regex v1.12.2 [INFO] [stderr] Compiling ciborium-ll v0.2.2 [INFO] [stderr] Compiling ciborium v0.2.2 [INFO] [stderr] Compiling chrono v0.4.42 [INFO] [stderr] Compiling vergen-git2 v1.0.7 [INFO] [stderr] Compiling tinytemplate v1.2.1 [INFO] [stderr] Compiling criterion v0.7.0 [INFO] [stderr] Compiling chabeau v0.6.1-dev (/opt/rustwide/workdir) [INFO] [stderr] Compiling rust-mcp-transport v0.8.0 [INFO] [stderr] Compiling rust-mcp-sdk v0.8.2 [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 2m 24s [INFO] running `Command { std: "docker" "inspect" "51f043bdd7db50a1ec07ea37fa2918c689084608ccbe3417937bd69b41ff5b16", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "51f043bdd7db50a1ec07ea37fa2918c689084608ccbe3417937bd69b41ff5b16", kill_on_drop: false }` [INFO] [stdout] 51f043bdd7db50a1ec07ea37fa2918c689084608ccbe3417937bd69b41ff5b16 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+a7ee93192a766fb0dafa23def7154fc03cfcfc3e" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] afe3cfe0ae22df075d05b951987508a0c9a9de2fb03738199bf623a46705ef58 [INFO] running `Command { std: "docker" "start" "-a" "afe3cfe0ae22df075d05b951987508a0c9a9de2fb03738199bf623a46705ef58", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.56s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/chabeau-b9bea49b3ab2a8a6) [INFO] [stdout] [INFO] [stdout] running 629 tests [INFO] [stdout] test auth::tests::collect_configured_providers_skips_duplicate_custom_entries ... ok [INFO] [stdout] test auth::ui::tests::confirmation_parsing_handles_empty_and_cancel ... ok [INFO] [stdout] test auth::ui::tests::delete_last_word_handles_spaces_only ... ok [INFO] [stdout] test auth::tests::resolve_deauth_target_normalizes_builtin_provider ... ok [INFO] [stdout] test auth::ui::tests::delete_last_word_removes_trailing_word ... ok [INFO] [stdout] test auth::ui::tests::masked_input_cancel ... ok [INFO] [stdout] test auth::tests::env_fallback_sets_openai_provider_for_default_base ... ok [INFO] [stdout] test auth::ui::tests::masked_input_insert_and_backspace ... ok [INFO] [stdout] test auth::ui::tests::masked_input_submit_after_paste_with_newline ... ok [INFO] [stdout] test auth::ui::tests::provider_selection_handles_custom_option ... ok [INFO] [stdout] test auth::ui::tests::provider_selection_handles_cancel_option ... ok [INFO] [stdout] test auth::ui::tests::provider_selection_rejects_duplicates ... ok [INFO] [stdout] test character::cache::tests::test_compute_cache_key_empty_directory ... ok [INFO] [stdout] test character::cache::tests::test_default_creates_empty_cache ... ok [INFO] [stdout] test character::cache::tests::test_metadata_sorted_by_name ... ok [INFO] [stdout] test character::cache::tests::test_new_cache_is_empty ... ok [INFO] [stdout] test character::card::tests::test_character_card_structure ... ok [INFO] [stdout] test character::card::tests::test_greeting_with_substitutions ... ok [INFO] [stdout] test character::cache::tests::test_cache_miss_reloads_data ... ok [INFO] [stdout] test character::cache::tests::test_cache_reuses_data_on_second_call ... ok [INFO] [stdout] test character::card::tests::test_optional_fields_not_serialized_when_none ... ok [INFO] [stdout] test auth::ui::tests::resolve_provider_id_detects_duplicates ... ok [INFO] [stdout] test character::cache::tests::test_cache_hit_returns_same_data ... ok [INFO] [stdout] test character::card::tests::test_post_history_instructions_with_substitutions ... ok [INFO] [stdout] test character::card::tests::test_serialization_deserialization ... ok [INFO] [stdout] test character::import::tests::test_import_and_verify_in_temp_dir ... ok [INFO] [stdout] test character::card::tests::test_system_prompt_with_substitutions ... ok [INFO] [stdout] test character::import::tests::test_import_card_validation_before_copy ... ok [INFO] [stdout] test character::import::tests::test_import_card_creates_directory ... ok [INFO] [stdout] test auth::tests::resolve_deauth_target_normalizes_custom_provider ... ok [INFO] [stdout] test character::import::tests::test_import_card_success_message_format ... ok [INFO] [stdout] test character::import::tests::test_import_card_wrong_extension ... ok [INFO] [stdout] test character::import::tests::test_import_card_missing_file ... ok [INFO] [stdout] test auth::tests::env_fallback_sets_openai_compatible_for_custom_base ... ok [INFO] [stdout] test character::import::tests::test_import_card_preserves_filename ... ok [INFO] [stdout] test character::import::tests::test_import_error_display ... ok [INFO] [stdout] test character::import::tests::test_import_with_force_flag ... ok [INFO] [stdout] test character::import::tests::test_import_valid_card ... ok [INFO] [stdout] test character::loader::tests::test_card_discovery_prefers_json_over_png ... ok [INFO] [stdout] test character::loader::tests::test_card_discovery_with_temp_directory ... ok [INFO] [stdout] test character::import::tests::test_import_invalid_card ... ok [INFO] [stdout] test character::import::tests::test_import_overwrite_protection ... ok [INFO] [stdout] test character::loader::tests::test_card_load_error_display_png_errors ... ok [INFO] [stdout] test character::loader::tests::test_get_cards_dir ... ok [INFO] [stdout] test character::loader::tests::test_get_cards_dir_env_override ... ok [INFO] [stdout] test character::loader::tests::test_list_available_cards_empty_directory ... ok [INFO] [stdout] test character::loader::tests::test_card_load_error_display ... ok [INFO] [stdout] test character::loader::tests::test_list_available_cards_with_test_cards ... ok [INFO] [stdout] test character::loader::tests::test_load_hypatia_json ... ok [INFO] [stdout] test character::loader::tests::test_list_cards_ignores_subdirectories ... ok [INFO] [stdout] test character::loader::tests::test_load_invalid_test_card ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_file_not_found ... ok [INFO] [stdout] test character::loader::tests::test_load_card_json ... ok [INFO] [stdout] test character::loader::tests::test_load_card_invalid_extension ... ok [INFO] [stdout] test character::loader::tests::test_load_hypatia_png ... ok [INFO] [stdout] test character::loader::tests::test_load_card_png ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_missing_required_field ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_with_optional_fields ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_invalid_json ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_file_not_found ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_invalid_base64 ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_without_metadata ... ok [INFO] [stdout] test character::loader::tests::test_load_simple_test_card ... ok [INFO] [stdout] test character::loader::tests::test_load_valid_json_card ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_invalid_json ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_not_a_png ... ok [INFO] [stdout] test character::loader::tests::test_png_and_json_equivalence ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_empty_name ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_valid ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_empty_fields_allowed ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_invalid_spec ... ok [INFO] [stdout] test character::png_text::tests::extracts_requested_text ... ok [INFO] [stdout] test character::png_text::tests::rejects_invalid_crc ... ok [INFO] [stdout] test character::png_text::tests::reports_missing_keyword ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_with_metadata ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_multiple_errors ... ok [INFO] [stdout] test character::png_text::tests::rejects_invalid_signature ... ok [INFO] [stdout] test character::test_helpers::helpers::tests::test_create_temp_card_file ... ok [INFO] [stdout] test character::test_helpers::helpers::tests::test_valid_card_json ... ok [INFO] [stdout] test character::test_helpers::helpers::tests::test_create_temp_cards_dir_with_cards ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_error_case_invalid_card_format ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_config_persistence_with_multiple_defaults ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_character_precedence_cli_over_default ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_error_case_missing_card_file ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_error_case_missing_required_fields ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_character_switching_during_session ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_error_case_wrong_spec_version ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_character_with_empty_optional_fields ... ok [INFO] [stdout] test character::loader::tests::test_load_spec_v2_png_cards ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_import_then_select_via_cli_workflow ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_import_then_select_via_picker_workflow ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_full_conversation_flow_with_character ... ok [INFO] [stdout] test cli::say::tests::plain_prefix_rendering_stays_escape_free_when_redirected ... ok [INFO] [stdout] test cli::say::tests::plain_stream_state_inserts_newline_for_redirected_streams ... ok [INFO] [stdout] test cli::say::tests::plain_stream_state_writes_errors_on_new_lines ... ok [INFO] [stdout] test cli::say::tests::resolve_prompt_prefers_cli_args ... ok [INFO] [stdout] test cli::say::tests::resolve_prompt_reads_from_piped_stdin ... ok [INFO] [stdout] test cli::tests::test_character_flag_with_other_flags ... ok [INFO] [stdout] test cli::tests::test_character_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_disable_mcp_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_token_command_parsing ... ok [INFO] [stdout] test cli::tests::test_persona_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_persona_flag_with_other_flags ... ok [INFO] [stdout] test cli::tests::test_persona_validation_with_valid_config ... ok [INFO] [stdout] test cli::tests::test_preset_flag_parsing ... ok [INFO] [stdout] test character::card::tests::test_optional_fields ... ok [INFO] [stdout] test cli::say::tests::resolve_prompt_handles_empty_sources ... ok [INFO] [stdout] test commands::tests::character_command_opens_picker ... ok [INFO] [stdout] test commands::tests::character_command_registered_in_help ... ok [INFO] [stdout] test commands::tests::character_command_with_invalid_name_shows_error ... ok [INFO] [stdout] test commands::tests::clear_command_resets_transcript_state ... ok [INFO] [stdout] test commands::tests::clear_command_shows_character_greeting_when_available ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_import_set_default_start_session_workflow ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_import_overwrite_protection ... ok [INFO] [stdout] test character::service::tests::resolves_updates_after_file_change ... ok [INFO] [stdout] test commands::tests::dispatch_reports_unknown_commands ... ok [INFO] [stdout] test commands::tests::dispatch_provides_multi_word_arguments ... ok [INFO] [stdout] test commands::tests::help_command_includes_registry_metadata ... ok [INFO] [stdout] test cli::tests::test_cli_set_default_character_with_cached_service ... ok [INFO] [stdout] test commands::tests::dump_conversation_uses_persona_display_name ... ok [INFO] [stdout] test commands::tests::mcp_command_includes_allowed_tools ... ok [INFO] [stdout] test commands::tests::mcp_command_highlights_disabled_state ... ok [INFO] [stdout] test commands::tests::mcp_command_lists_empty_config ... ok [INFO] [stdout] test cli::tests::test_cli_set_default_model_with_mixed_case_provider ... ok [INFO] [stdout] test commands::tests::parse_kv_args_rejects_missing_equals ... ok [INFO] [stdout] test commands::tests::parse_kv_args_supports_quotes ... ok [INFO] [stdout] test cli::tests::test_resolve_provider_id_builtin_and_custom ... ok [INFO] [stdout] test commands::tests::model_command_with_id_sets_model ... ok [INFO] [stdout] test commands::tests::model_command_returns_open_picker_result ... ok [INFO] [stdout] test cli::tests::test_resolve_theme_id_builtin_and_custom ... ok [INFO] [stdout] test commands::tests::persona_command_opens_picker ... ok [INFO] [stdout] test commands::tests::persona_command_with_invalid_id_shows_error ... ok [INFO] [stdout] test commands::tests::persona_command_with_valid_id_updates_user_display_name ... ok [INFO] [stdout] test commands::tests::picker_supports_home_end_navigation_and_metadata ... ok [INFO] [stdout] test commands::tests::registry_lists_commands ... ok [INFO] [stdout] test commands::tests::provider_command_with_same_id_reuses_session ... ok [INFO] [stdout] test commands::tests::commands_dispatch_case_insensitively ... ok [INFO] [stdout] test commands::tests::test_dump_conversation_file_exists ... ok [INFO] [stdout] test commands::tests::markdown_command_rejects_invalid_argument ... ok [INFO] [stdout] test commands::tests::test_dump_conversation ... ok [INFO] [stdout] test commands::tests::test_process_input_dump_with_filename ... ok [INFO] [stdout] test commands::tests::theme_command_opens_picker ... ok [INFO] [stdout] test commands::tests::theme_picker_supports_filtering ... ok [INFO] [stdout] test commands::tests::test_process_input_dump_empty_conversation ... ok [INFO] [stdout] test core::app::actions::file_prompt::tests::file_prompt_dump_success_sets_status_and_closes_prompt ... ok [INFO] [stdout] test core::app::actions::input::tests::process_command_submits_message ... ok [INFO] [stdout] test core::app::actions::input::tests::tool_request_inspect_formats_arguments ... ok [INFO] [stdout] test core::app::actions::file_prompt::tests::file_prompt_save_block_success_writes_file ... ok [INFO] [stdout] test core::app::actions::file_prompt::tests::file_prompt_dump_existing_without_overwrite_sets_status ... ok [INFO] [stdout] test commands::tests::theme_picker_shows_a_z_sort_indicators ... ok [INFO] [stdout] test core::app::actions::picker::tests::character_picker_marks_default_with_asterisk ... ok [INFO] [stdout] test core::app::actions::picker::tests::model_picker_escape_reverts_provider_transition ... ok [INFO] [stdout] test core::app::actions::input::tests::process_command_opens_theme_picker ... ok [INFO] [stdout] test core::app::actions::picker::tests::model_selection_loads_default_character ... ok [INFO] [stdout] test commands::tests::markdown_command_updates_state_and_persists ... ok [INFO] [stdout] test core::app::actions::picker::tests::character_picker_closes_after_selection ... ok [INFO] [stdout] test core::app::actions::input::tests::help_command_focuses_transcript ... ok [INFO] [stdout] test commands::tests::syntax_command_updates_state_and_persists ... ok [INFO] [stdout] test core::app::actions::picker::tests::test_load_default_persona_if_configured ... ok [INFO] [stdout] test core::app::actions::picker::tests::test_load_default_persona_respects_existing_active_persona ... ok [INFO] [stdout] test core::app::actions::input::tests::tool_request_inspect_handles_missing_arguments ... ok [INFO] [stdout] test core::app::actions::picker::tests::test_load_default_preset_respects_existing_active_preset ... ok [INFO] [stdout] test core::app::actions::picker::tests::test_load_default_preset_if_configured ... ok [INFO] [stdout] test core::app::actions::streaming::tests::stream_app_message_adds_trimmed_content_and_keeps_stream_alive ... ok [INFO] [stdout] test core::app::actions::streaming::tests::tool_unsupported_detection_requires_tool_signal ... ok [INFO] [stdout] test core::app::actions::streaming::tests::stream_errored_drops_empty_assistant_placeholder ... ok [INFO] [stdout] test core::app::conversation::tests::test_add_user_message_with_character_no_post_history ... ok [INFO] [stdout] test core::app::actions::picker::tests::theme_picker_escape_reverts_preview ... ok [INFO] [stdout] test core::app::conversation::tests::add_user_message_omits_trailing_empty_assistant_turns ... ok [INFO] [stdout] test core::app::conversation::tests::test_add_user_message_with_character_active ... ok [INFO] [stdout] test core::app::conversation::tests::log_rewrite_excludes_app_messages ... ok [INFO] [stdout] test core::app::conversation::tests::test_add_user_message_without_character ... ok [INFO] [stdout] test core::app::conversation::tests::test_app_messages_excluded_from_api ... ok [INFO] [stdout] test core::app::conversation::tests::test_persona_system_prompt_integration_without_character ... ok [INFO] [stdout] test core::app::conversation::tests::test_character_greeting_included_in_api_messages ... ok [INFO] [stdout] test core::app::conversation::tests::test_character_greeting_with_persona_substitutions ... ok [INFO] [stdout] test core::app::conversation::tests::test_persona_system_prompt_integration_with_character ... ok [INFO] [stdout] test core::app::conversation::tests::test_persona_bio_char_placeholder_with_active_character ... ok [INFO] [stdout] test core::app::conversation::tests::test_character_messages_with_transcript_system_messages ... ok [INFO] [stdout] test core::app::conversation::tests::test_prepare_retry_excludes_system_messages ... ok [INFO] [stdout] test core::app::conversation::tests::test_retry_character_greeting_reinserts_locally ... ok [INFO] [stdout] test core::app::conversation::tests::test_persona_with_blank_bio_does_not_add_system_message ... ok [INFO] [stdout] test core::app::conversation::tests::test_prepare_retry_with_character_active ... ok [INFO] [stdout] test core::app::picker::tests::test_character_picker_highlights_active_character ... ok [INFO] [stdout] test core::app::picker::tests::test_filter_characters_preserves_special_entry_and_selection_bounds ... ok [INFO] [stdout] test core::app::conversation::tests::test_show_character_greeting_if_needed ... ok [INFO] [stdout] test core::app::picker::tests::test_filter_personas_preserves_special_entry_and_selection_bounds ... ok [INFO] [stdout] test core::app::picker::tests::test_filter_presets_preserves_special_entry_and_selection_bounds ... ok [INFO] [stdout] test core::app::conversation::tests::test_prepare_retry_without_character ... ok [INFO] [stdout] test core::app::conversation::tests::test_retry_character_greeting_updates_after_persona_change ... ok [INFO] [stdout] test core::app::picker::tests::test_persona_picker_highlights_active_persona ... ok [INFO] [stdout] test core::app::picker::tests::test_persona_picker_metadata_defaults_to_no_bio_when_empty ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_collapses_whitespace ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_handles_empty_string ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_handles_mixed_whitespace ... ok [INFO] [stdout] test core::app::conversation::tests::test_show_character_greeting_no_character ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_preserves_normal_text ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_removes_carriage_returns ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_removes_control_chars ... ok [INFO] [stdout] test core::app::picker::tests::test_filter_models_resets_selection_and_matches_case_insensitively ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_handles_only_whitespace ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_removes_newlines ... ok [INFO] [stdout] test core::app::picker::tests::test_persona_picker_sanitizes_bio_metadata ... ok [INFO] [stdout] test core::app::conversation::tests::add_user_message_logs_persona_display_name ... ok [INFO] [stdout] test core::app::actions::streaming::tests::stream_tool_call_delta_flushes_on_complete ... ok [INFO] [stdout] test core::app::session::tests::initialize_logging_with_file_writes_initial_entry ... ok [INFO] [stdout] test core::app::session::tests::load_character_for_session_cards_dir_priority ... ok [INFO] [stdout] test core::app::picker::tests::test_turn_off_character_entry_added_when_character_active ... ok [INFO] [stdout] test core::app::session::tests::load_character_for_session_cli_takes_precedence ... ok [INFO] [stdout] test core::app::session::tests::load_character_for_session_filepath_fallback ... ok [INFO] [stdout] test core::app::picker::tests::test_turn_off_character_entry_not_added_when_no_character ... ok [INFO] [stdout] test core::app::session::tests::load_character_for_session_no_character ... ok [INFO] [stdout] test core::app::picker::tests::test_preset_picker_highlights_active_preset ... ok [INFO] [stdout] test core::app::session::tests::session_context_get_character_returns_none_initially ... ok [INFO] [stdout] test core::app::session::tests::resolve_theme_prefers_configured_theme ... ok [INFO] [stdout] test core::app::picker::tests::test_turn_off_persona_stays_at_top_after_sort ... ok [INFO] [stdout] test core::app::session::tests::session_context_reselecting_same_character_preserves_greeting_flag ... ok [INFO] [stdout] test core::app::session::tests::session_context_greeting_lifecycle ... ok [INFO] [stdout] test core::app::picker::tests::test_turn_off_character_stays_at_top_after_sort ... ok [INFO] [stdout] test core::app::session::tests::session_context_clear_character ... ok [INFO] [stdout] test core::app::session::tests::session_context_selecting_different_character_resets_greeting_flag ... ok [INFO] [stdout] test core::app::conversation::tests::test_show_character_greeting_empty_greeting ... ok [INFO] [stdout] test core::app::session::tests::session_context_should_not_show_empty_greeting ... ok [INFO] [stdout] test core::app::session::tests::session_context_should_show_greeting ... ok [INFO] [stdout] test core::app::session::tests::session_context_set_character ... ok [INFO] [stdout] test core::app::session::tests::theme_from_appearance_matches_dark_theme ... ok [INFO] [stdout] test core::app::settings::tests::apply_model_clears_transition_state ... ok [INFO] [stdout] test core::app::settings::tests::apply_provider_reuses_existing_session_credentials ... ok [INFO] [stdout] test core::app::settings::tests::apply_theme_session_only_updates_ui ... ok [INFO] [stdout] test core::app::session::tests::theme_from_appearance_matches_light_theme ... ok [INFO] [stdout] test core::app::settings::tests::preview_theme_preserves_current_theme_id ... ok [INFO] [stdout] test core::app::tests::build_stream_params_includes_mcp_tools ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_fills_unique_match ... ok [INFO] [stdout] test core::app::session::tests::prepare_with_auth_uses_pre_resolved_session ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_reports_unknown_prefix ... ok [INFO] [stdout] test core::app::tests::calculate_available_height_matches_expected_layout_rules ... ok [INFO] [stdout] test core::app::tests::build_stream_params_includes_mcp_resources ... ok [INFO] [stdout] test core::app::tests::clear_transcript_resets_transcript_state ... ok [INFO] [stdout] test core::app::tests::default_sort_mode_helper_behaviour ... ok [INFO] [stdout] test core::app::session::tests::prepare_with_auth_uses_env_session_when_env_only ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_lists_multiple_matches ... ok [INFO] [stdout] test core::app::tests::model_picker_title_uses_az_when_no_dates ... ok [INFO] [stdout] test core::app::tests::paste_inserts_cursor_at_end_of_insert ... ok [INFO] [stdout] test core::app::tests::prewrap_cache_plain_text_last_message_wrapping ... ok [INFO] [stdout] test core::app::tests::prewrap_cache_updates_metadata_for_markdown_last_message ... ok [INFO] [stdout] test core::app::tests::prewrap_cache_updates_metadata_for_plain_text_last_message ... ok [INFO] [stdout] test core::app::tests::streaming_table_autoscroll_stays_consistent ... ok [INFO] [stdout] test core::app::tests::page_cursor_movement_skips_multiple_wrapped_lines ... ok [INFO] [stdout] test core::app::tests::provider_model_cancel_reverts_base_url_and_state ... ok [INFO] [stdout] test core::app::tests::test_backspace_with_alt_modifier_deletes_single_char ... ok [INFO] [stdout] test core::app::tests::streaming_table_with_cache_invalidation_consistency ... ok [INFO] [stdout] test core::app::tests::test_last_and_first_user_message_index ... ok [INFO] [stdout] test core::app::tests::test_prev_next_user_message_index_navigation ... ok [INFO] [stdout] test core::app::tests::test_backspace_at_line_start_joins_lines ... ok [INFO] [stdout] test core::app::tests::test_cursor_mapping_blankline_insert_no_desync ... ok [INFO] [stdout] test core::app::tests::test_page_up_down_and_home_end_behavior ... ok [INFO] [stdout] test core::app::tests::test_backspace_at_start_noop ... ok [INFO] [stdout] test core::app::tests::test_scroll_height_consistency_narrow_terminal_regression ... ok [INFO] [stdout] test core::app::tests::test_prewrap_cache_invalidates_on_width_change ... ok [INFO] [stdout] test core::app::tests::test_scroll_height_consistency_with_tables_regression ... ok [INFO] [stdout] test core::app::tests::test_set_input_text_places_cursor_at_end ... ok [INFO] [stdout] test core::app::tests::test_recompute_input_layout_after_edit_updates_scroll ... ok [INFO] [stdout] test core::app::tests::test_turn_off_character_mode_from_picker ... ok [INFO] [stdout] test core::app::tests::test_shift_like_left_right_moves_one_char ... ok [INFO] [stdout] test core::app::tests::test_shift_like_up_down_moves_one_line_on_many_newlines ... ok [INFO] [stdout] test core::app::tests::test_sync_cursor_mapping_single_and_multi_line ... ok [INFO] [stdout] test core::app::tests::test_wrapped_vertical_navigation_clamps_to_shorter_line ... ok [INFO] [stdout] test core::app::tests::test_wrapped_vertical_navigation_handles_multiple_paragraphs ... ok [INFO] [stdout] test core::app::tests::test_wrapped_vertical_navigation_keeps_column_zero_on_descend ... ok [INFO] [stdout] test core::app::tests::test_update_input_scroll_keeps_cursor_visible ... ok [INFO] [stdout] test core::app::tests::test_wrapped_vertical_navigation_preserves_visual_column ... ok [INFO] [stdout] test core::app::tests::visual_line_controls_handle_blank_lines ... ok [INFO] [stdout] test core::app::tests::block_selection_uses_cached_metadata ... ok [INFO] [stdout] test core::app::tests::metadata_contains_code_blocks_after_cache ... ok [INFO] [stdout] test core::app::tests::visual_line_start_end_track_wrapped_columns ... ok [INFO] [stdout] test core::app::tests::cache_invalidates_on_message_change ... ok [INFO] [stdout] test core::app::tests::test_prewrap_cache_reuse_when_unchanged ... ok [INFO] [stdout] test core::app::ui_state::tests::begin_streaming_forces_transcript_focus ... ok [INFO] [stdout] test core::app::tests::theme_picker_highlights_active_theme_over_default ... ok [INFO] [stdout] test core::app::tests::wrapped_cursor_crosses_paragraph_boundaries ... ok [INFO] [stdout] test core::app::tests::wrapped_cursor_moves_through_blank_lines ... ok [INFO] [stdout] test core::app::ui_state::tests::assistant_edit_flag_tracks_input_usage ... ok [INFO] [stdout] test core::app::ui_state::tests::block_select_mode_transitions_round_trip ... ok [INFO] [stdout] test core::app::ui_state::tests::cancel_in_place_edit_returns_to_typing ... ok [INFO] [stdout] test core::app::ui_state::tests::default_focus_is_transcript ... ok [INFO] [stdout] test core::builtin_providers::tests::test_find_builtin_provider ... ok [INFO] [stdout] test core::builtin_providers::tests::test_provider_properties ... ok [INFO] [stdout] test core::chat_stream::tests::format_api_error_handles_json_without_summary ... ok [INFO] [stdout] test core::chat_stream::tests::format_api_error_handles_xml_and_plaintext ... ok [INFO] [stdout] test core::builtin_presets::tests::load_has_expected_builtins ... ok [INFO] [stdout] test core::chat_stream::tests::format_api_error_prettifies_json_with_summary ... ok [INFO] [stdout] test core::chat_stream::tests::process_sse_line_handles_spacing_variants ... ok [INFO] [stdout] test core::app::ui_state::tests::enter_edit_select_mode_focuses_last_user_message ... ok [INFO] [stdout] test core::chat_stream::tests::process_sse_line_routes_stream_errors ... ok [INFO] [stdout] test core::chat_stream::tests::simple_sse_framer_handles_crlf_and_blank_lines ... ok [INFO] [stdout] test core::chat_stream::tests::simple_sse_framer_reports_invalid_utf8 ... ok [INFO] [stdout] test core::chat_stream::tests::simple_sse_framer_flushes_end_of_stream ... ok [INFO] [stdout] test core::chat_stream::tests::simple_sse_framer_suppresses_repeated_invalid_utf8 ... ok [INFO] [stdout] test core::config::tests::test_config_with_personas ... ok [INFO] [stdout] test core::builtin_providers::tests::test_anthropic_mode ... ok [INFO] [stdout] test core::builtin_providers::tests::test_builtin_providers_cached_slice ... ok [INFO] [stdout] test core::builtin_providers::tests::test_load_builtin_providers ... ok [INFO] [stdout] test core::config::tests::test_custom_provider_auth_modes ... ok [INFO] [stdout] test core::config::tests::test_default_character_case_insensitive_provider ... ok [INFO] [stdout] test core::config::tests::test_format_default_characters_empty ... ok [INFO] [stdout] test core::config::tests::test_format_default_characters_sorting_and_format ... ok [INFO] [stdout] test core::config::tests::test_load_nonexistent_config ... ok [INFO] [stdout] test core::config::tests::test_empty_personas_array ... ok [INFO] [stdout] test core::app::ui_state::tests::exit_edit_select_mode_returns_to_typing ... ok [INFO] [stdout] test core::app::ui_state::tests::focus_transitions_round_trip ... ok [INFO] [stdout] test core::config::tests::test_custom_theme_save_load ... ok [INFO] [stdout] test core::config::tests::test_custom_provider_management ... ok [INFO] [stdout] test core::config::tests::test_mcp_server_config_persistence ... ok [INFO] [stdout] test core::config::tests::test_mcp_server_stdio_config_persistence ... ok [INFO] [stdout] test core::config::tests::test_path_display ... ok [INFO] [stdout] test core::config::tests::test_overwrite_default_character ... ok [INFO] [stdout] test core::config::tests::test_overwrite_default_persona ... ok [INFO] [stdout] test core::config::tests::test_path_display_with_config_dir ... ok [INFO] [stdout] test core::config::tests::test_persona_optional_bio ... ok [INFO] [stdout] test core::config::tests::test_persona_serialization ... ok [INFO] [stdout] test core::config::tests::test_set_and_get_default_character ... ok [INFO] [stdout] test core::config::tests::test_set_and_get_default_persona ... ok [INFO] [stdout] test core::config::tests::test_set_multiple_default_characters ... ok [INFO] [stdout] test core::config::tests::test_suggest_provider_id ... ok [INFO] [stdout] test core::config::tests::test_unset_default_character ... ok [INFO] [stdout] test core::config::tests::test_unset_default_persona ... ok [INFO] [stdout] test core::config::tests::test_unset_default_persona_cleans_up_empty_provider ... ok [INFO] [stdout] test core::config::tests::test_unset_last_character_cleans_up_provider ... ok [INFO] [stdout] test core::message::tests::tool_messages_set_roles ... ok [INFO] [stdout] test core::config::tests::test_config_persistence_lifecycle ... ok [INFO] [stdout] test core::message::tests::tool_roles_are_not_app_roles ... ok [INFO] [stdout] test core::config::tests::test_save_and_load_default_characters ... ok [INFO] [stdout] test core::persona::tests::test_default_persona_loading_from_config ... ok [INFO] [stdout] test core::persona::tests::test_default_persona_lookup_case_and_underscores ... ok [INFO] [stdout] test core::persona::tests::test_display_name_with_active_persona ... ok [INFO] [stdout] test core::persona::tests::test_display_name_with_no_persona ... ok [INFO] [stdout] test core::persona::tests::test_invalid_persona_id_error_handling ... ok [INFO] [stdout] test core::persona::tests::test_persona_activation_and_deactivation ... ok [INFO] [stdout] test core::config::tests::test_provider_id_normalization ... ok [INFO] [stdout] test core::persona::tests::test_persona_bio_substitution ... ok [INFO] [stdout] test core::persona::tests::test_persona_loading_from_configuration ... ok [INFO] [stdout] test core::persona::tests::test_substitution_logic_with_active_persona ... ok [INFO] [stdout] test core::persona::tests::test_substitution_logic_with_no_persona ... ok [INFO] [stdout] test core::persona::tests::test_system_prompt_modification_ignores_empty_or_whitespace_bio ... ok [INFO] [stdout] test core::persona::tests::test_system_prompt_modification_no_persona ... ok [INFO] [stdout] test core::persona::tests::test_system_prompt_modification_with_persona_bio ... ok [INFO] [stdout] test core::persona::tests::test_system_prompt_modification_with_persona_no_bio ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_cli_persona_overrides_default ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_default_persona_loading_from_config ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_config_persistence ... ok [INFO] [stdout] test core::persona::test_message_rendering_with_persona_display_name ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_display_name_in_conversation ... ok [INFO] [stdout] test core::persona::tests::test_ui_display_name_integration ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_cli_persona_command_updates_ui_and_status ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_substitution_in_conversation ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_system_prompt_modification_with_active_persona ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_picker_turn_off_updates_ui_state ... ok [INFO] [stdout] test core::preset::tests::test_apply_to_messages_inserts_system_messages ... ok [INFO] [stdout] test core::preset::tests::test_apply_to_messages_skips_when_empty ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_end_to_end_persona_workflow ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_interactive_persona_command_workflow ... ok [INFO] [stdout] test core::preset::tests::test_builtin_presets_can_be_disabled ... ok [INFO] [stdout] test core::preset::tests::test_builtin_presets_enabled_by_default ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_command_variations ... ok [INFO] [stdout] test core::preset::tests::test_get_default_for_provider_model ... ok [INFO] [stdout] test core::preset::tests::test_set_active_preset_error_message_mentions_available_options ... ok [INFO] [stdout] test core::preset::tests::test_set_and_clear_active_preset ... ok [INFO] [stdout] test core::preset::tests::test_user_presets_override_builtins ... ok [INFO] [stdout] test core::providers::tests::permanent_keyring_failure_is_propagated ... ok [INFO] [stdout] test core::providers::tests::provider_override_falls_back_to_env_on_keyring_failure ... ok [INFO] [stdout] test core::providers::tests::recoverable_keyring_failure_uses_env_credentials ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_error_recovery ... ok [INFO] [stdout] test core::text_wrapping::tests::cursor_layout_reports_line_count_and_line_search ... ok [INFO] [stdout] test core::text_wrapping::tests::cursor_layout_tracks_consecutive_blank_lines ... ok [INFO] [stdout] test core::text_wrapping::tests::multiple_spaces_preserved_across_wrap ... ok [INFO] [stdout] test core::text_wrapping::tests::elided_space_maps_cursor_to_next_line_start ... ok [INFO] [stdout] test core::text_wrapping::tests::single_space_elided_when_wrap_occurs ... ok [INFO] [stdout] test core::text_wrapping::tests::test_basic_wrapping ... ok [INFO] [stdout] test core::text_wrapping::tests::test_cursor_mapping_with_double_width_emoji ... ok [INFO] [stdout] test core::text_wrapping::tests::test_cursor_position_calculation ... ok [INFO] [stdout] test core::text_wrapping::tests::test_cursor_position_with_multiple_spaces_and_newlines ... ok [INFO] [stdout] test core::text_wrapping::tests::test_extra_padding ... ok [INFO] [stdout] test core::text_wrapping::tests::test_long_word_breaking ... ok [INFO] [stdout] test core::text_wrapping::tests::test_preserve_multiple_spaces ... ok [INFO] [stdout] test core::text_wrapping::tests::test_wrap_with_double_width_emoji ... ok [INFO] [stdout] test mcp::client::tests::format_error_chain_includes_sources ... ok [INFO] [stdout] test mcp::client::tests::format_error_chain_without_sources ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_picker_with_active_persona ... ok [INFO] [stdout] test mcp::permissions::tests::allow_once_is_consumed_after_query ... ok [INFO] [stdout] test core::text_wrapping::tests::position_map_lines_are_monotonic ... ok [INFO] [stdout] test core::text_wrapping::tests::test_cursor_position_map_soft_wrap_column_zero ... ok [INFO] [stdout] test mcp::permissions::tests::allow_session_is_retained ... ok [INFO] [stdout] test mcp::permissions::tests::block_is_retained ... ok [INFO] [stdout] test mcp::permissions::tests::clear_server_removes_decisions ... ok [INFO] [stdout] test mcp::permissions::tests::deny_once_is_not_recorded ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::end_messages_finalize_responses ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::error_messages_add_system_entries_and_stop_streaming ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::retry_last_message_emits_command_with_history ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::sanitize_paste_text_removes_control_characters ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::process_stream_updates_dispatches_actions ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::submit_message_returns_spawn_command ... ok [INFO] [stdout] test ui::builtin_themes::tests::find_builtin_theme_works_case_insensitive ... ok [INFO] [stdout] test ui::builtin_themes::tests::load_has_expected_builtins ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::arrow_key_in_file_prompt_keeps_transcript_focus ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::handle_paste_event_dispatches_insert_action ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::retry_last_message_returns_none_without_history ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::tab_autocompletes_slash_commands ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::tab_does_not_switch_focus_in_block_select_mode ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::tab_does_not_switch_focus_in_assistant_edit_select_mode ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::tab_does_not_switch_focus_in_edit_select_mode ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::typing_in_file_prompt_refocuses_input ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::tab_toggles_focus_without_slash_prefix ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::ctrl_n_handler_sets_status_when_cannot_retry ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::arrow_key_handler_moves_cursor_when_input_focused ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::ctrl_n_handler_dispatches_refine_action ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::arrow_key_handler_scrolls_when_transcript_focused ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::wrap_next_index_wraps_to_start ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::wrap_previous_index_wraps_to_end ... ok [INFO] [stdout] test ui::chat_loop::lifecycle::tests::apply_cursor_color_writes_sequence ... ok [INFO] [stdout] test ui::chat_loop::lifecycle::tests::apply_cursor_reset_writes_sequence ... ok [INFO] [stdout] test ui::chat_loop::lifecycle::tests::cursor_color_payload_is_hex ... ok [INFO] [stdout] test ui::chat_loop::lifecycle::tests::queues_cursor_color_sequence ... ok [INFO] [stdout] test ui::chat_loop::lifecycle::tests::setup_terminal_enables_raw_mode ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::ctrl_l_handler_emits_clear_status_action ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::escape_handler_cancels_file_prompt_via_action ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::ctrl_n_handler_sets_status_when_prompt_missing ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::escape_handler_cancels_streaming_via_action ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::assistant_edit_select_delete_truncates_without_flag ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::assistant_edit_select_enter_loads_message_into_input ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::language_extension_detection ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::assistant_edit_submission_appends_message_without_resend ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::edit_select_enter_refocuses_input ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::escape_handler_cancels_in_place_edit_via_action ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_block_extraction_returns_consistent_results ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_block_navigation_cycles_through_multiple_blocks ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::enter_key_completes_file_prompt_dump ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_blocks_across_messages_have_unique_indices ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_exact_user_scenario_two_assistant_code_blocks ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_incremental_cache_update_preserves_global_indices ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_interleaved_blocks_have_unique_indices ... ok [INFO] [stdout] test ui::layout::tests::layout_lines_can_be_encoded_with_osc_links ... ok [INFO] [stdout] test ui::layout::tests::link_metadata_spans_cover_spaces_within_link_text ... ok [INFO] [stdout] test ui::layout::tests::markdown_layout_populates_span_metadata ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::enter_key_dispatches_process_command_action ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::f4_handler_toggles_compose_mode_via_action ... ok [INFO] [stdout] test ui::markdown::table::tests::clip_text_to_width_allows_mixed_text_and_emoji ... ok [INFO] [stdout] test ui::markdown::table::tests::clip_text_to_width_keeps_entire_graphemes ... ok [INFO] [stdout] test ui::markdown::tests::blockquote_followed_by_paragraph_has_single_blank_line ... ok [INFO] [stdout] test ui::markdown::tests::blockquote_followed_by_list_has_single_blank_line ... ok [INFO] [stdout] test ui::layout::tests::plain_text_layout_synthesizes_metadata ... ok [INFO] [stdout] test ui::markdown::tests::blank_line_before_paragraph_doesnt_cause_blank_before_later_list_item ... ok [INFO] [stdout] test ui::markdown::tests::code_block_spans_have_metadata ... ok [INFO] [stdout] test ui::markdown::tests::blockquote_followed_by_heading_has_single_blank_line ... ok [INFO] [stdout] test ui::markdown::tests::cell_wraps_at_space_across_spans ... ok [INFO] [stdout] test ui::markdown::tests::code_and_link_metadata_coexist ... ok [INFO] [stdout] test ui::markdown::tests::debug_table_events ... ok [INFO] [stdout] test ui::markdown::tests::code_blocks_dont_shift_list_item_indices ... ok [INFO] [stdout] test ui::markdown::tests::cell_wraps_after_hyphen ... ok [INFO] [stdout] test ui::markdown::tests::blockquote_with_code_block_followed_by_paragraph ... ok [INFO] [stdout] test ui::markdown::tests::code_with_closing_paren_at_width ... ok [INFO] [stdout] test ui::markdown::tests::complex_nested_lists_with_long_text_preserve_blank_lines ... ok [INFO] [stdout] test ui::markdown::tests::emphasis_fills_entire_width_with_adjacent_punct ... ok [INFO] [stdout] test ui::markdown::tests::emphasis_preserves_style_during_backtracking ... ok [INFO] [stdout] test ui::markdown::tests::emphasis_ending_one_after_width ... ok [INFO] [stdout] test ui::markdown::tests::emphasis_with_paren_outside_one_past_width ... ok [INFO] [stdout] test ui::markdown::tests::emphasis_with_multiple_adjacent_punctuation ... ok [INFO] [stdout] test ui::markdown::tests::emphasis_with_paren_inside_at_width ... ok [INFO] [stdout] test ui::markdown::tests::emphasis_with_punctuation_at_width ... ok [INFO] [stdout] test ui::markdown::tests::gfm_callout_blockquotes_render_content ... ok [INFO] [stdout] test ui::markdown::tests::emphasis_with_standalone_paren ... ok [INFO] [stdout] test ui::markdown::tests::empty_code_block_has_metadata ... ok [INFO] [stdout] test ui::markdown::tests::list_items_preserve_blank_lines_before_all_block_elements ... ok [INFO] [stdout] test ui::markdown::tests::list_items_with_multiple_paragraphs_preserve_blank_lines ... ok [INFO] [stdout] test ui::markdown::tests::horizontal_rules_render_as_centered_lines ... ok [INFO] [stdout] test ui::markdown::tests::link_ending_at_width ... ok [INFO] [stdout] test ui::markdown::tests::list_followed_by_paragraph_has_blank_line_after ... ok [INFO] [stdout] test ui::markdown::tests::list_paragraphs_keep_indent_after_blank_lines ... ok [INFO] [stdout] test ui::markdown::tests::list_paragraphs_with_soft_breaks_keep_indent ... ok [INFO] [stdout] test ui::markdown::tests::list_preceded_by_heading_has_blank_line_before ... ok [INFO] [stdout] test ui::markdown::tests::list_preceded_by_paragraph_has_blank_line_before ... ok [INFO] [stdout] test ui::markdown::tests::list_with_source_blank_lines_preserves_spacing_between_top_level_items ... ok [INFO] [stdout] test ui::markdown::tests::list_without_source_blank_lines_has_no_spacing_between_top_level_items ... ok [INFO] [stdout] test ui::markdown::tests::lists_with_plus_markers_preserve_blank_lines ... ok [INFO] [stdout] test ui::markdown::tests::code_block_without_language_has_metadata ... ok [INFO] [stdout] test ui::markdown::tests::markdown_details_metadata_matches_lines_and_tags ... ok [INFO] [stdout] test ui::markdown::tests::markdown_links_wrap_at_word_boundaries_with_width ... ok [INFO] [stdout] test ui::markdown::tests::markdown_images_emit_clickable_links ... ok [INFO] [stdout] test ui::markdown::tests::metadata_marks_table_links ... ok [INFO] [stdout] test ui::markdown::tests::lists_with_numeric_text_before_them_dont_shift_indices ... ok [INFO] [stdout] test ui::markdown::tests::multi_item_ordered_list_keeps_code_block_with_correct_item ... ok [INFO] [stdout] test ui::markdown::tests::metadata_marks_user_prefix ... ok [INFO] [stdout] test ui::markdown::tests::nested_bullet_lists_render_with_indentation ... ok [INFO] [stdout] test ui::markdown::tests::nested_code_blocks_have_metadata ... ok [INFO] [stdout] test ui::markdown::tests::list_followed_by_heading_has_blank_line_after ... ok [INFO] [stdout] test ui::markdown::tests::inline_code_ending_at_width ... ok [INFO] [stdout] test ui::markdown::tests::nested_lists_dont_add_blank_lines_between_same_level_items ... ok [INFO] [stdout] test ui::markdown::tests::nested_lists_with_single_blank_line_dont_double_space ... ok [INFO] [stdout] test ui::markdown::tests::markdown_links_wrap_in_long_paragraph_without_mid_word_break ... ok [INFO] [stdout] test ui::markdown::tests::metadata_marks_app_prefix ... ok [INFO] [stdout] test ui::markdown::tests::strong_emphasis_ending_at_width ... ok [INFO] [stdout] test ui::markdown::tests::ordered_list_item_code_block_is_indented_under_marker ... ok [INFO] [stdout] test ui::markdown::tests::multiple_code_blocks_have_unique_indices ... ok [INFO] [stdout] test ui::markdown::tests::shared_renderer_with_metadata_matches_details_wrapper ... ok [INFO] [stdout] test ui::markdown::tests::table_rendering_works ... ok [INFO] [stdout] test ui::markdown::tests::strikethrough_ending_at_width ... ok [INFO] [stdout] test ui::markdown::tests::superscript_and_subscript_render_without_markers ... ok [INFO] [stdout] test ui::markdown::tests::test_table_balancing_performance ... ok [INFO] [stdout] test ui::markdown::tests::test_extremely_narrow_terminal_no_truncation ... ok [INFO] [stdout] test ui::markdown::tests::table_preserves_words_with_available_space ... ok [INFO] [stdout] test ui::markdown::tests::test_table_column_width_balancing ... ok [INFO] [stdout] test ui::markdown::tests::table_renders_emoji_and_br_correctly ... ok [INFO] [stdout] test ui::markdown::tests::test_table_cell_word_wrapping_regression ... ok [INFO] [stdout] test ui::markdown::tests::test_table_content_wrapping_medium_terminal ... ok [INFO] [stdout] test ui::markdown::tests::test_styled_words_wrap_at_boundaries_in_table ... ok [INFO] [stdout] test ui::markdown::tests::test_table_balancing_with_terminal_width ... ok [INFO] [stdout] test ui::markdown::tests::test_table_no_content_truncation_wide_terminal ... ok [INFO] [stdout] test ui::markdown::tests::test_table_should_not_wrap_borders ... ok [INFO] [stdout] test ui::markdown::tests::test_table_with_emoji_and_unicode_no_truncation ... ok [INFO] [stdout] test ui::markdown::tests::test_government_systems_table_from_testcase ... ok [INFO] [stdout] test ui::markdown::tests::user_message_code_blocks_have_metadata ... ok [INFO] [stdout] test ui::markdown::wrap::tests::wrap_preserves_skin_tone_modifiers ... ok [INFO] [stdout] test ui::markdown::tests::test_table_wrapping_with_mixed_content ... ok [INFO] [stdout] test ui::markdown::wrap::tests::wrap_preserves_zwj_clusters ... ok [INFO] [stdout] test ui::markdown::wrap::tests::wrap_splits_at_spaces ... ok [INFO] [stdout] test ui::osc::tests::encode_hyperlink_rejects_control_bytes ... ok [INFO] [stdout] test ui::markdown::tests::test_logical_row_continuation ... ok [INFO] [stdout] test ui::osc::tests::encode_hyperlink_wraps_text_with_balanced_sequences ... ok [INFO] [stdout] test ui::osc::tests::encode_hyperlink_rejects_empty_segments ... ok [INFO] [stdout] test ui::osc::tests::encode_line_with_links_returns_plain_text_without_metadata ... ok [INFO] [stdout] test ui::markdown::tests::wrapped_list_items_align_under_text ... ok [INFO] [stdout] test ui::osc::tests::encode_lines_with_links_wraps_each_link_segment ... ok [INFO] [stdout] test ui::osc::tests::lines_with_underline_fallback_apply_to_each_link ... ok [INFO] [stdout] test ui::osc::tests::underline_fallback_wraps_link_text_with_sgr_sequences ... ok [INFO] [stdout] test ui::osc_backend::tests::closes_hyperlink_removed_by_scroll_without_touching_endpoint ... ok [INFO] [stdout] test ui::osc_backend::tests::closes_stale_hyperlink_even_without_cell_diff ... ok [INFO] [stdout] test ui::osc_state::tests::compute_render_state_accounts_for_emoji_presentation_sequences ... ok [INFO] [stdout] test ui::osc_state::tests::compute_render_state_tracks_visible_link_segment ... ok [INFO] [stdout] test ui::osc_backend::tests::redraws_cell_when_hyperlink_changes_without_buffer_diff ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_character_with_default_selected ... ok [INFO] [stdout] test ui::osc::tests::control_detection_catches_bel_and_escape ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_character_picker ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_character_with_filter ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_theme_picker ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_model_with_filter ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_no_picker ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_theme_with_default_selected ... ok [INFO] [stdout] test ui::renderer::tests::title_does_not_show_character_when_none ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_with_default_selected ... ok [INFO] [stdout] test ui::markdown::tests::wrapped_code_preserves_metadata_across_lines ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_model_with_default_selected ... ok [INFO] [stdout] test ui::renderer::tests::title_places_preset_after_character_when_active ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_active_preset_when_set ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_model_when_not_in_transition ... ok [INFO] [stdout] test ui::span::tests::code_block_meta_stores_language ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_no_model_selected_during_transition ... ok [INFO] [stdout] test ui::span::tests::extract_code_block_content_retrieves_code ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_model_no_filter_no_default ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_computes_line_ranges ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_finds_all_blocks ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_handles_empty_metadata ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_preserves_language ... ok [INFO] [stdout] test ui::span::tests::extract_content_handles_multiple_spans_per_line ... ok [INFO] [stdout] test ui::span::tests::extract_content_preserves_blank_lines ... ok [INFO] [stdout] test ui::span::tests::code_block_meta_handles_no_language ... ok [INFO] [stdout] test ui::span::tests::extract_content_returns_none_for_invalid_index ... ok [INFO] [stdout] test ui::span::tests::extract_content_selects_correct_block ... ok [INFO] [stdout] test ui::span::tests::span_kind_recognizes_code_blocks ... ok [INFO] [stdout] test ui::span::tests::text_spans_are_not_code_blocks ... ok [INFO] [stdout] test ui::theme::tests::defaults_cursor_color_from_background ... ok [INFO] [stdout] test ui::theme::tests::parses_cursor_color_from_spec ... ok [INFO] [stdout] test utils::auth::tests::test_anthropic_auth_headers ... ok [INFO] [stdout] test ui::span::tests::extract_content_omits_list_indent ... ok [INFO] [stdout] test ui::span::tests::extract_content_preserves_line_breaks ... ok [INFO] [stdout] test utils::auth::tests::test_openai_auth_headers ... ok [INFO] [stdout] test utils::color::tests::detects_256_from_term ... ok [INFO] [stdout] test utils::color::tests::detects_truecolor_from_env ... ok [INFO] [stdout] test utils::color::tests::quantize_rgb_to_256_index ... ok [INFO] [stdout] test utils::color::tests::quantize_rgb_to_ansi16 ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_basic ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_carriage_returns ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_filters_control_chars ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_handles_no_code_blocks ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_mixed_control_chars ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_preserves_newlines ... ok [INFO] [stdout] test utils::auth::tests::test_custom_provider_auth_headers ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_character_name_when_active ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_tabs ... ok [INFO] [stdout] test utils::scroll::tests::assistant_selection_highlight_changes_rendered_lines ... ok [INFO] [stdout] test utils::scroll::tests::test_app_message_formatting ... ok [INFO] [stdout] test utils::scroll::tests::test_build_display_lines_up_to ... ok [INFO] [stdout] test utils::scroll::tests::test_build_display_lines_basic ... ok [INFO] [stdout] test utils::scroll::tests::table_scroll_height_matches_rendered ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_scroll_to_bottom_no_scroll_needed ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_max_scroll_offset ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_scroll_to_bottom_scroll_needed ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_word_wrapped_lines_exact_fit ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_scroll_to_message ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_word_wrapped_lines_single_word_too_long ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_wrapped_line_count_empty_lines ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_word_wrapped_lines_single_line ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_wrapped_line_count_mixed_content ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_wrapped_line_count_zero_width ... ok [INFO] [stdout] test utils::scroll::tests::test_layout_engine_and_prewrap_preserve_link_words ... ok [INFO] [stdout] test utils::scroll::tests::test_markdown_link_wraps_on_nbsp ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_word_wrapped_lines_multiple_lines ... ok [INFO] [stdout] test utils::scroll::tests::test_empty_message_content ... ok [INFO] [stdout] test utils::scroll::tests::test_multiline_user_message ... ok [INFO] [stdout] test utils::scroll::tests::test_markdown_link_wraps_on_spaces ... ok [INFO] [stdout] test utils::scroll::tests::test_plain_text_long_line_wrapping ... ok [INFO] [stdout] test utils::scroll::tests::test_prewrap_paragraph_no_leading_spaces_or_lonely_dot ... ok [INFO] [stdout] test utils::scroll::tests::test_multiline_assistant_message ... ok [INFO] [stdout] test utils::scroll::tests::test_prewrap_zwj_sequence_respects_width ... ok [INFO] [stdout] test utils::scroll::tests::test_scroll_offset_to_line_start_basic ... ok [INFO] [stdout] test utils::scroll::tests::test_prewrap_wide_emoji_respects_width ... ok [INFO] [stdout] test utils::scroll::tests::test_prewrap_wraps_entire_link_word_when_width_exhausted ... ok [INFO] [stdout] test utils::scroll::tests::perf_prewrap_short_history ... ok [INFO] [stdout] test utils::scroll::tests::test_selection_highlight_builds_same_number_of_lines ... ok [INFO] [stdout] test utils::syntax::tests::normalize_lang_hint_maps_common_aliases ... ok [INFO] [stdout] test utils::scroll::tests::test_trimming_behavior ... ok [INFO] [stdout] test utils::scroll::tests::test_word_wrapping_with_long_paragraph ... ok [INFO] [stdout] test utils::syntax::tests::dark_background_heuristic_basic ... ok [INFO] [stdout] test utils::url::tests::test_construct_api_url ... ok [INFO] [stdout] test utils::url::tests::test_normalize_base_url ... ok [INFO] [stdout] test utils::syntax::tests::theme_signature_changes_with_theme ... ok [INFO] [stdout] test ui::renderer::tests::title_abbreviates_and_hides_fields_based_on_width ... ok [INFO] [stdout] test ui::markdown::tests::various_language_tags_preserved ... ok [INFO] [stdout] test utils::syntax::tests::theme_selection_matches_brightness ... ok [INFO] [stdout] test utils::scroll::tests::perf_prewrap_large_history ... ok [INFO] [stdout] test core::config::tests::config_orchestrator_detects_external_updates ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 629 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 2.77s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/chabeau-6edca663f2a60195) [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stderr] Doc-tests chabeau [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] [stdout] [INFO] [stdout] running 12 tests [INFO] [stdout] test src/auth/mod.rs - auth::AuthManager::resolve_authentication (line 206) - compile ... ok [INFO] [stdout] test src/character/service.rs - character::service::CharacterService::resolve (line 168) - compile ... ok [INFO] [stdout] test src/core/app/mod.rs - core::app::new_with_auth (line 147) - compile ... ok [INFO] [stdout] test src/commands/mod.rs - commands::process_input (line 90) - compile ... ok [INFO] [stdout] test src/core/chat_stream.rs - core::chat_stream::ChatStreamService::spawn_stream (line 402) - compile ... ok [INFO] [stdout] test src/ui/span.rs - ui::span::extract_code_block_content (line 281) ... ok [INFO] [stdout] test src/ui/span.rs - ui::span (line 14) ... ok [INFO] [stdout] test src/ui/span.rs - ui::span (line 29) ... ok [INFO] [stdout] test src/utils/url.rs - utils::url::construct_api_url (line 31) ... ok [INFO] [stdout] test src/utils/url.rs - utils::url::normalize_base_url (line 13) ... ok [INFO] [stdout] test src/core/chat_stream.rs - core::chat_stream::ChatStreamService::new (line 368) ... ok [INFO] [stdout] test src/ui/span.rs - ui::span::extract_code_blocks (line 219) ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 12 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 25.39s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "afe3cfe0ae22df075d05b951987508a0c9a9de2fb03738199bf623a46705ef58", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "afe3cfe0ae22df075d05b951987508a0c9a9de2fb03738199bf623a46705ef58", kill_on_drop: false }` [INFO] [stdout] afe3cfe0ae22df075d05b951987508a0c9a9de2fb03738199bf623a46705ef58