[INFO] fetching crate chabeau 0.7.3... [INFO] testing chabeau-0.7.3 against beta-2026-04-21 for beta-1.96-1 [INFO] extracting crate chabeau 0.7.3 into /workspace/builds/worker-5-tc2/source [INFO] started tweaking crates.io crate chabeau 0.7.3 [INFO] finished tweaking crates.io crate chabeau 0.7.3 [INFO] tweaked toml for crates.io crate chabeau 0.7.3 written to /workspace/builds/worker-5-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate chabeau 0.7.3 on toolchain beta-2026-04-21 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate chabeau 0.7.3 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" "+beta-2026-04-21" "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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 1730564b9f1f12086ab03a9b83f88dbb0afd432dfd0531c22e6ebe554cb8a443 [INFO] running `Command { std: "docker" "start" "-a" "1730564b9f1f12086ab03a9b83f88dbb0afd432dfd0531c22e6ebe554cb8a443", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "1730564b9f1f12086ab03a9b83f88dbb0afd432dfd0531c22e6ebe554cb8a443", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "1730564b9f1f12086ab03a9b83f88dbb0afd432dfd0531c22e6ebe554cb8a443", kill_on_drop: false }` [INFO] [stdout] 1730564b9f1f12086ab03a9b83f88dbb0afd432dfd0531c22e6ebe554cb8a443 [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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 564494ad2c01eaa50fa3772e4c0c8889dbfa9314515676e4646906900e7f39a1 [INFO] running `Command { std: "docker" "start" "-a" "564494ad2c01eaa50fa3772e4c0c8889dbfa9314515676e4646906900e7f39a1", kill_on_drop: false }` [INFO] [stderr] Compiling quote v1.0.44 [INFO] [stderr] Compiling libc v0.2.182 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling regex-syntax v0.8.9 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling deranged v0.5.6 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling anyhow v1.0.101 [INFO] [stderr] Compiling camino v1.2.2 [INFO] [stderr] Compiling vergen-lib v0.1.6 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling percent-encoding v2.3.2 [INFO] [stderr] Compiling vergen v9.0.6 [INFO] [stderr] Compiling libdbus-sys v0.2.7 [INFO] [stderr] Compiling num_threads v0.1.7 [INFO] [stderr] Compiling rustls v0.23.36 [INFO] [stderr] Compiling form_urlencoded v1.2.2 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling vergen-git2 v1.0.7 [INFO] [stderr] Compiling futures-channel v0.3.32 [INFO] [stderr] Compiling linux-raw-sys v0.4.15 [INFO] [stderr] Compiling log v0.4.29 [INFO] [stderr] Compiling unicode-width v0.2.0 [INFO] [stderr] Compiling bitflags v2.11.0 [INFO] [stderr] Compiling instability v0.3.11 [INFO] [stderr] Compiling castaway v0.2.4 [INFO] [stderr] Compiling syn v2.0.116 [INFO] [stderr] Compiling simd-adler32 v0.3.8 [INFO] [stderr] Compiling rustix v1.1.3 [INFO] [stderr] Compiling getrandom v0.4.1 [INFO] [stderr] Compiling indoc v2.0.7 [INFO] [stderr] Compiling anstream v0.6.21 [INFO] [stderr] Compiling unicode-truncate v1.1.0 [INFO] [stderr] Compiling compact_str v0.8.1 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling quick-xml v0.38.4 [INFO] [stderr] Compiling clap_lex v1.0.0 [INFO] [stderr] Compiling pulldown-cmark v0.13.0 [INFO] [stderr] Compiling winnow v0.7.14 [INFO] [stderr] Compiling linked-hash-map v0.5.6 [INFO] [stderr] Compiling clap_builder v4.5.59 [INFO] [stderr] Compiling getopts v0.2.24 [INFO] [stderr] Compiling yaml-rust v0.4.5 [INFO] [stderr] Compiling tracing-log v0.2.0 [INFO] [stderr] Compiling time v0.3.47 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling serde_spanned v1.0.4 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Compiling errno v0.3.14 [INFO] [stderr] Compiling mio v1.1.1 [INFO] [stderr] Compiling socket2 v0.6.2 [INFO] [stderr] Compiling signal-hook-registry v1.4.8 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling signal-hook v0.3.18 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling sysinfo v0.34.2 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling dbus v0.9.10 [INFO] [stderr] Compiling signal-hook-mio v0.2.5 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling crossterm v0.28.1 [INFO] [stderr] Compiling flate2 v1.1.9 [INFO] [stderr] Compiling toml_parser v1.0.9+spec-1.1.0 [INFO] [stderr] Compiling toml_datetime v0.7.5+spec-1.1.0 [INFO] [stderr] Compiling unicase v2.9.0 [INFO] [stderr] Compiling iana-time-zone v0.1.65 [INFO] [stderr] Compiling toml_writer v1.0.6+spec-1.1.0 [INFO] [stderr] Compiling pulldown-cmark-escape v0.11.0 [INFO] [stderr] Compiling semver v1.0.27 [INFO] [stderr] Compiling rustc_version v0.4.1 [INFO] [stderr] Compiling tempfile v3.25.0 [INFO] [stderr] Compiling toml v0.9.12+spec-1.1.0 [INFO] [stderr] Compiling directories v6.0.0 [INFO] [stderr] Compiling libz-sys v1.1.23 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling libgit2-sys v0.18.3+1.9.2 [INFO] [stderr] Compiling onig_sys v69.9.1 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling darling_core v0.20.11 [INFO] [stderr] Compiling darling_core v0.23.0 [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.3 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling futures-macro v0.3.32 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling zeroize v1.8.2 [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling strum_macros v0.26.4 [INFO] [stderr] Compiling rustls-pki-types v1.14.0 [INFO] [stderr] Compiling onig v6.5.1 [INFO] [stderr] Compiling dbus-secret-service v4.1.0 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling webpki-roots v1.0.6 [INFO] [stderr] Compiling clap_derive v4.5.55 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling darling_macro v0.20.11 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling rustls-webpki v0.103.9 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling darling v0.20.11 [INFO] [stderr] Compiling derive_builder_core v0.20.2 [INFO] [stderr] Compiling keyring v3.6.3 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling darling_macro v0.23.0 [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 darling v0.23.0 [INFO] [stderr] Compiling strum v0.26.3 [INFO] [stderr] Compiling derive_builder_macro v0.20.2 [INFO] [stderr] Compiling ratatui v0.29.0 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling derive_builder v0.20.2 [INFO] [stderr] Compiling clap v4.5.59 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling cargo-platform v0.1.9 [INFO] [stderr] Compiling plist v1.8.0 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling bincode v1.3.3 [INFO] [stderr] Compiling chrono v0.4.43 [INFO] [stderr] Compiling cargo_metadata v0.19.2 [INFO] [stderr] Compiling rust-mcp-schema v0.9.5 [INFO] [stderr] Compiling syntect v5.3.0 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling tui-textarea v0.7.0 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling git2 v0.20.4 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling chabeau v0.7.3 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 07s [INFO] running `Command { std: "docker" "inspect" "564494ad2c01eaa50fa3772e4c0c8889dbfa9314515676e4646906900e7f39a1", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "564494ad2c01eaa50fa3772e4c0c8889dbfa9314515676e4646906900e7f39a1", kill_on_drop: false }` [INFO] [stdout] 564494ad2c01eaa50fa3772e4c0c8889dbfa9314515676e4646906900e7f39a1 [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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] cdc50587ee3b2f764773d5f09bc753441621afa030123dc1de4cc519beb6c344 [INFO] running `Command { std: "docker" "start" "-a" "cdc50587ee3b2f764773d5f09bc753441621afa030123dc1de4cc519beb6c344", kill_on_drop: false }` [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling zerocopy v0.8.39 [INFO] [stderr] Compiling zerocopy-derive v0.8.39 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling cargo-platform v0.1.9 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling bincode v1.3.3 [INFO] [stderr] Compiling plist v1.8.0 [INFO] [stderr] Compiling rust-mcp-schema v0.9.5 [INFO] [stderr] Compiling chrono v0.4.43 [INFO] [stderr] Compiling tinytemplate v1.2.1 [INFO] [stderr] Compiling cargo_metadata v0.19.2 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling syntect v5.3.0 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling vergen v9.0.6 [INFO] [stderr] Compiling vergen-git2 v1.0.7 [INFO] [stderr] Compiling chabeau v0.7.3 (/opt/rustwide/workdir) [INFO] [stderr] Compiling half v2.7.1 [INFO] [stderr] Compiling ciborium-ll v0.2.2 [INFO] [stderr] Compiling ciborium v0.2.2 [INFO] [stderr] Compiling criterion v0.7.0 [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 1m 13s [INFO] running `Command { std: "docker" "inspect" "cdc50587ee3b2f764773d5f09bc753441621afa030123dc1de4cc519beb6c344", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "cdc50587ee3b2f764773d5f09bc753441621afa030123dc1de4cc519beb6c344", kill_on_drop: false }` [INFO] [stdout] cdc50587ee3b2f764773d5f09bc753441621afa030123dc1de4cc519beb6c344 [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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] a7ec2a3f8a6915114e29c1abc50c23d7300bdeee538a18cee55121b50c2a9417 [INFO] running `Command { std: "docker" "start" "-a" "a7ec2a3f8a6915114e29c1abc50c23d7300bdeee538a18cee55121b50c2a9417", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.49s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/chabeau-4cc76fb62de960ec) [INFO] [stdout] [INFO] [stdout] running 723 tests [INFO] [stdout] test auth::ui::tests::provider_selection_rejects_duplicates ... ok [INFO] [stdout] test auth::tests::collect_configured_providers_skips_duplicate_custom_entries ... ok [INFO] [stdout] test auth::ui::tests::provider_selection_handles_cancel_option ... 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::cache::tests::test_cache_miss_reloads_data ... ok [INFO] [stdout] test auth::ui::tests::provider_selection_handles_custom_option ... ok [INFO] [stdout] test character::cache::tests::test_cache_reuses_data_on_second_call ... 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::cache::tests::test_compute_cache_key_empty_directory ... ok [INFO] [stdout] test character::card::tests::test_post_history_instructions_with_substitutions ... ok [INFO] [stdout] test character::card::tests::test_optional_fields_not_serialized_when_none ... ok [INFO] [stdout] test character::card::tests::test_greeting_with_substitutions ... ok [INFO] [stdout] test character::card::tests::test_system_prompt_with_substitutions ... ok [INFO] [stdout] test character::card::tests::test_serialization_deserialization ... ok [INFO] [stdout] test character::card::tests::test_optional_fields ... ok [INFO] [stdout] test auth::tests::env_fallback_sets_openai_compatible_for_custom_base ... ok [INFO] [stdout] test character::card::tests::test_character_card_structure ... ok [INFO] [stdout] test auth::tests::env_fallback_sets_openai_provider_for_default_base ... ok [INFO] [stdout] test auth::tests::resolve_deauth_target_normalizes_builtin_provider ... ok [INFO] [stdout] test character::import::tests::test_import_error_display ... ok [INFO] [stdout] test character::import::tests::test_import_card_success_message_format ... ok [INFO] [stdout] test character::import::tests::test_import_and_verify_in_temp_dir ... ok [INFO] [stdout] test character::import::tests::test_import_card_preserves_filename ... ok [INFO] [stdout] test character::import::tests::test_import_invalid_card ... ok [INFO] [stdout] test character::import::tests::test_import_card_validation_before_copy ... 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::loader::tests::test_card_load_error_display_png_errors ... ok [INFO] [stdout] test character::import::tests::test_import_valid_card ... ok [INFO] [stdout] test character::loader::tests::test_load_card_invalid_extension ... ok [INFO] [stdout] test character::loader::tests::test_load_card_json ... ok [INFO] [stdout] test character::loader::tests::test_load_card_png ... ok [INFO] [stdout] test character::loader::tests::test_card_load_error_display ... ok [INFO] [stdout] test character::loader::tests::test_get_cards_dir ... ok [INFO] [stdout] test character::import::tests::test_import_card_missing_file ... ok [INFO] [stdout] test character::loader::tests::test_load_hypatia_png ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_file_not_found ... ok [INFO] [stdout] test character::loader::tests::test_load_invalid_test_card ... ok [INFO] [stdout] test character::loader::tests::test_load_hypatia_json ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_file_not_found ... ok [INFO] [stdout] test character::import::tests::test_import_overwrite_protection ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_with_optional_fields ... ok [INFO] [stdout] test character::import::tests::test_import_card_wrong_extension ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_invalid_json ... ok [INFO] [stdout] test character::import::tests::test_import_with_force_flag ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_missing_required_field ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_with_metadata ... ok [INFO] [stdout] test character::loader::tests::test_list_available_cards_empty_directory ... ok [INFO] [stdout] test character::loader::tests::test_load_spec_v2_png_cards ... 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::loader::tests::test_validate_card_multiple_errors ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_empty_name ... ok [INFO] [stdout] test character::loader::tests::test_png_and_json_equivalence ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_invalid_base64 ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_not_a_png ... ok [INFO] [stdout] test character::loader::tests::test_load_simple_test_card ... ok [INFO] [stdout] test character::loader::tests::test_list_cards_ignores_subdirectories ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_valid ... ok [INFO] [stdout] test character::png_text::tests::extracts_requested_text ... 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::loader::tests::test_load_png_card_invalid_json ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_without_metadata ... ok [INFO] [stdout] test character::loader::tests::test_load_valid_json_card ... ok [INFO] [stdout] test character::png_text::tests::rejects_invalid_crc ... ok [INFO] [stdout] test character::png_text::tests::rejects_invalid_signature ... ok [INFO] [stdout] test character::png_text::tests::reports_missing_keyword ... ok [INFO] [stdout] test character::loader::tests::test_list_available_cards_with_test_cards ... ok [INFO] [stdout] test character::test_helpers::helpers::tests::smoke_test_helper_fixtures_remain_usable ... 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_required_fields ... 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_wrong_spec_version ... 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_error_case_invalid_card_format ... ok [INFO] [stdout] test cli::say::tests::plain_prefix_rendering_stays_escape_free_when_redirected ... 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 cli::say::tests::resolve_prompt_reads_from_piped_stdin ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_character_switching_during_session ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_full_conversation_flow_with_character ... 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_handles_empty_sources ... ok [INFO] [stdout] test cli::tests::test_character_flag_with_other_flags ... ok [INFO] [stdout] test cli::say::tests::resolve_prompt_prefers_cli_args ... ok [INFO] [stdout] test cli::tests::test_disable_mcp_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_add_advanced_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_edit_command_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_edit_advanced_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_oauth_add_advanced_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_oauth_add_command_parsing ... ok [INFO] [stdout] test cli::tests::test_parse_key_value_pairs_accepts_headers ... ok [INFO] [stdout] test cli::tests::test_parse_key_value_pairs_rejects_invalid_entry ... ok [INFO] [stdout] test cli::tests::test_mcp_oauth_list_command_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_token_add_command_parsing ... ok [INFO] [stdout] test cli::tests::test_persona_flag_with_other_flags ... ok [INFO] [stdout] test cli::tests::test_mcp_token_list_command_parsing ... ok [INFO] [stdout] test cli::tests::test_persona_validation_with_valid_config ... ok [INFO] [stdout] test cli::tests::test_provider_add_command_parsing ... ok [INFO] [stdout] test cli::tests::test_preset_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_provider_token_add_command_parsing ... ok [INFO] [stdout] test cli::tests::test_persona_flag_parsing ... ok [INFO] [stdout] test commands::mcp_prompt_parser::tests::table_driven_prompt_parsing ... ok [INFO] [stdout] test cli::tests::test_provider_token_list_command_parsing ... ok [INFO] [stdout] test commands::tests::character_command_registered_in_help ... ok [INFO] [stdout] test commands::tests::character_command_opens_picker ... ok [INFO] [stdout] test cli::tests::test_character_flag_parsing ... ok [INFO] [stdout] test commands::tests::dispatch_provides_multi_word_arguments ... ok [INFO] [stdout] test commands::tests::dispatch_reports_unknown_commands ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_character_with_empty_optional_fields ... 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 commands::tests::character_command_with_invalid_name_shows_error ... ok [INFO] [stdout] test commands::tests::dump_conversation_uses_persona_display_name ... ok [INFO] [stdout] test commands::tests::help_command_includes_registry_metadata ... ok [INFO] [stdout] test commands::tests::mcp_command_highlights_disabled_state ... ok [INFO] [stdout] test commands::tests::mcp_command_highlights_yolo_servers ... ok [INFO] [stdout] test commands::tests::mcp_command_lists_empty_config ... ok [INFO] [stdout] test commands::tests::mcp_command_includes_allowed_tools ... ok [INFO] [stdout] test commands::tests::mcp_command_skips_refresh_for_disabled_server ... ok [INFO] [stdout] test commands::tests::mcp_command_highlights_disabled_servers ... ok [INFO] [stdout] test commands::tests::mcp_command_toggle_off_clears_runtime_state ... ok [INFO] [stdout] test commands::tests::model_command_returns_open_picker_result ... ok [INFO] [stdout] test auth::ui::tests::confirmation_parsing_handles_empty_and_cancel ... 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 commands::tests::parse_prompt_args_multiple_arguments_requires_key_value ... ok [INFO] [stdout] test commands::tests::parse_prompt_args_single_argument_accepts_bare_value ... ok [INFO] [stdout] test commands::tests::parse_prompt_args_single_argument_accepts_quoted_value ... ok [INFO] [stdout] test commands::tests::model_command_with_id_sets_model ... 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::provider_command_with_same_id_reuses_session ... ok [INFO] [stdout] test commands::tests::registry_lists_commands ... ok [INFO] [stdout] test commands::tests::parse_prompt_args_single_argument_accepts_unquoted_spaces ... ok [INFO] [stdout] test commands::tests::test_dump_conversation ... ok [INFO] [stdout] test commands::tests::test_dump_conversation_file_exists ... ok [INFO] [stdout] test commands::tests::test_process_input_dump_empty_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_shows_a_z_sort_indicators ... ok [INFO] [stdout] test commands::tests::theme_picker_supports_filtering ... ok [INFO] [stdout] test commands::tests::validate_prompt_args_rejects_unknown_keys ... ok [INFO] [stdout] test character::service::tests::resolves_updates_after_file_change ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_import_overwrite_protection ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_import_set_default_start_session_workflow ... ok [INFO] [stdout] test core::app::actions::file_prompt::tests::file_prompt_dump_existing_without_overwrite_sets_status ... ok [INFO] [stdout] test core::app::actions::file_prompt::tests::file_prompt_save_block_success_writes_file ... ok [INFO] [stdout] test core::app::actions::input::command::tests::mcp_command_focuses_transcript ... 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::command::tests::process_command_submits_message ... ok [INFO] [stdout] test core::app::actions::input::command::tests::help_command_focuses_transcript ... ok [INFO] [stdout] test core::app::actions::input::command::tests::process_command_opens_theme_picker ... ok [INFO] [stdout] test character::loader::tests::test_get_cards_dir_env_override ... ok [INFO] [stdout] test cli::tests::test_cli_set_default_character_with_cached_service ... ok [INFO] [stdout] test core::app::actions::input::inspect::tests::nested_json_detection_matches_payload ... ok [INFO] [stdout] test core::app::actions::input::inspect::tests::inspect_tool_calls_labels_completed ... ok [INFO] [stdout] test core::app::actions::input::inspect::tests::nested_json_detection_handles_fenced_json ... ok [INFO] [stdout] test core::app::actions::input::inspect::tests::tool_request_inspect_formats_arguments ... ok [INFO] [stdout] test core::app::actions::input::inspect::tests::tool_request_inspect_handles_missing_arguments ... ok [INFO] [stdout] test core::app::actions::picker::tests::character_picker_closes_after_selection ... ok [INFO] [stdout] test core::app::actions::input::inspect::tests::inspect_tool_calls_prefers_pending_prompt ... ok [INFO] [stdout] test core::app::actions::picker::tests::character_picker_marks_default_with_asterisk ... ok [INFO] [stdout] test core::app::actions::input::inspect::tests::tool_call_inspect_copy_data_uses_response_payload ... ok [INFO] [stdout] test core::app::actions::input::inspect::tests::tool_call_inspect_copy_data_decodes_nested_json ... ok [INFO] [stdout] test core::app::actions::input::inspect::tests::tool_call_inspect_copy_data_uses_request_payload ... ok [INFO] [stdout] test core::app::actions::picker::tests::test_load_default_persona_respects_existing_active_persona ... ok [INFO] [stdout] test core::app::actions::picker::tests::model_picker_escape_reverts_provider_transition ... ok [INFO] [stdout] test cli::tests::test_cli_set_default_model_with_mixed_case_provider ... ok [INFO] [stdout] test core::app::actions::picker::tests::test_load_default_preset_if_configured ... ok [INFO] [stdout] test cli::tests::test_resolve_provider_id_builtin_and_custom ... 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_preset_respects_existing_active_preset ... ok [INFO] [stdout] test core::app::actions::streaming::stream_lifecycle::tests::finalize_stream_clears_interrupt_token_when_done ... ok [INFO] [stdout] test cli::tests::test_resolve_theme_id_builtin_and_custom ... ok [INFO] [stdout] test core::app::actions::picker::tests::theme_picker_escape_reverts_preview ... ok [INFO] [stdout] test core::app::actions::streaming::stream_errors::tests::stream_error_trims_message_and_keeps_user_history ... ok [INFO] [stdout] test core::app::actions::streaming::stream_lifecycle::tests::stream_tool_call_delta_flushes_on_complete ... ok [INFO] [stdout] test core::app::actions::streaming::stream_lifecycle::tests::stream_app_message_adds_trimmed_content_and_keeps_stream_alive ... ok [INFO] [stdout] test core::app::actions::streaming::tool_calls::tests::tool_call_completed_ignores_stale_completion_with_mismatched_call_id ... ok [INFO] [stdout] test core::app::actions::picker::tests::model_selection_loads_default_character ... ok [INFO] [stdout] test core::app::actions::streaming::tool_calls::tests::tool_call_completed_ignores_stale_completion_without_active_request ... ok [INFO] [stdout] test core::app::conversation::tests::add_user_message_logs_persona_display_name ... ok [INFO] [stdout] test core::app::conversation::tests::add_user_message_omits_trailing_empty_assistant_turns ... ok [INFO] [stdout] test core::app::actions::streaming::mcp_gate::tests::mcp_init_completed_spawns_pending_message ... ok [INFO] [stdout] test core::app::actions::streaming::tool_calls::tests::tool_call_completed_flags_tool_error_payloads ... ok [INFO] [stdout] test core::app::conversation::tests::test_add_user_message_without_character ... ok [INFO] [stdout] test core::app::conversation::tests::test_add_user_message_with_character_active ... ok [INFO] [stdout] test commands::tests::commands_dispatch_case_insensitively ... ok [INFO] [stdout] test core::app::conversation::tests::test_add_user_message_with_character_no_post_history ... ok [INFO] [stdout] test core::app::conversation::tests::test_character_messages_with_transcript_system_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::log_rewrite_excludes_app_messages ... ok [INFO] [stdout] test core::app::actions::streaming::sampling::tests::sampling_finished_clears_active_request ... ok [INFO] [stdout] test core::app::conversation::tests::test_app_messages_excluded_from_api ... ok [INFO] [stdout] test core::app::conversation::tests::test_character_greeting_included_in_api_messages ... 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_persona_system_prompt_integration_without_character ... ok [INFO] [stdout] test core::app::conversation::tests::test_prepare_retry_excludes_system_messages ... ok [INFO] [stdout] test core::app::conversation::tests::test_prepare_retry_with_character_active ... 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::picker::tests::test_filter_models_resets_selection_and_matches_case_insensitively ... ok [INFO] [stdout] test commands::tests::markdown_command_updates_state_and_persists ... ok [INFO] [stdout] test core::app::conversation::tests::test_tool_call_argument_values_truncate_long_strings ... ok [INFO] [stdout] test core::app::conversation::tests::test_show_character_greeting_empty_greeting ... ok [INFO] [stdout] test core::app::picker::tests::test_filter_presets_preserves_special_entry_and_selection_bounds ... ok [INFO] [stdout] test core::app::picker::tests::test_filter_personas_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::picker::tests::test_filter_characters_preserves_special_entry_and_selection_bounds ... ok [INFO] [stdout] test core::app::conversation::tests::test_retry_character_greeting_updates_after_persona_change ... ok [INFO] [stdout] test core::app::conversation::tests::test_show_character_greeting_no_character ... ok [INFO] [stdout] test core::app::conversation::tests::test_show_character_greeting_if_needed ... ok [INFO] [stdout] test core::app::picker::tests::test_picker_data_variant_footprint_is_normalized ... 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_collapses_whitespace ... 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_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_sanitize_picker_metadata_preserves_normal_text ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_removes_newlines ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_handles_mixed_whitespace ... ok [INFO] [stdout] test core::app::picker::tests::test_preset_picker_highlights_active_preset ... 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::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::session::tests::load_character_for_session_no_character ... 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_persona_picker_metadata_defaults_to_no_bio_when_empty ... ok [INFO] [stdout] test core::app::session::tests::mcp_init_state_complete_returns_message_and_clears_progress ... ok [INFO] [stdout] test core::app::session::tests::mcp_init_state_should_defer_only_while_in_progress ... ok [INFO] [stdout] test core::app::session::tests::mcp_init_state_reset_restores_default ... 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_get_character_returns_none_initially ... ok [INFO] [stdout] test core::app::session::tests::session_context_greeting_lifecycle ... ok [INFO] [stdout] test core::app::picker::tests::test_character_picker_highlights_active_character ... ok [INFO] [stdout] test commands::tests::markdown_command_rejects_invalid_argument ... ok [INFO] [stdout] test core::app::session::tests::session_context_clear_character ... ok [INFO] [stdout] test core::app::session::tests::resolve_theme_prefers_configured_theme ... 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_set_character ... ok [INFO] [stdout] test core::app::session::tests::session_context_should_show_greeting ... ok [INFO] [stdout] test core::app::session::tests::session_context_selecting_different_character_resets_greeting_flag ... ok [INFO] [stdout] test core::app::session::tests::tool_pipeline_prune_for_assistant_index_removes_matching_records ... ok [INFO] [stdout] test core::app::session::tests::session_context_should_not_show_empty_greeting ... ok [INFO] [stdout] test core::app::session::tests::tool_pipeline_advance_tool_queue_handles_empty_and_item ... ok [INFO] [stdout] test core::app::session::tests::tool_pipeline_continuation_round_trip_and_drain ... ok [INFO] [stdout] test core::app::picker::tests::test_persona_picker_highlights_active_persona ... ok [INFO] [stdout] test core::app::session::tests::tool_pipeline_reset_clears_active_and_queues ... ok [INFO] [stdout] test core::app::settings::tests::apply_model_clears_transition_state ... ok [INFO] [stdout] test core::app::session::tests::theme_from_appearance_matches_dark_theme ... ok [INFO] [stdout] test core::app::picker::tests::test_persona_picker_sanitizes_bio_metadata ... ok [INFO] [stdout] test core::app::settings::tests::preview_theme_preserves_current_theme_id ... ok [INFO] [stdout] test core::app::settings::tests::apply_provider_reuses_existing_session_credentials ... ok [INFO] [stdout] test core::app::session::tests::theme_from_appearance_matches_light_theme ... ok [INFO] [stdout] test commands::tests::mcp_command_forget_clears_permissions_and_history ... ok [INFO] [stdout] test core::app::tests::build_stream_params_includes_mcp_resources ... ok [INFO] [stdout] test core::app::tests::build_stream_params_includes_tool_history_and_payloads ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_completes_mcp_server ... ok [INFO] [stdout] test core::app::tests::build_stream_params_includes_mcp_tools ... ok [INFO] [stdout] test core::app::tests::calculate_available_height_matches_expected_layout_rules ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_completes_yolo_server ... ok [INFO] [stdout] test core::app::tests::clear_transcript_resets_transcript_state ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_fills_unique_match ... ok [INFO] [stdout] test core::app::settings::tests::apply_theme_session_only_updates_ui ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_reports_unknown_prefix ... ok [INFO] [stdout] test core::app::session::tests::prepare_with_auth_uses_env_session_when_env_only ... ok [INFO] [stdout] test core::app::picker::tests::test_turn_off_character_stays_at_top_after_sort ... ok [INFO] [stdout] test core::app::tests::parse_resource_list_kind_defaults_to_resources_and_passes_cursor ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_lists_multiple_matches ... ok [INFO] [stdout] test core::app::tests::parse_resource_list_kind_rejects_empty_cursor ... ok [INFO] [stdout] test core::app::tests::model_picker_title_uses_az_when_no_dates ... ok [INFO] [stdout] test core::app::tests::page_cursor_movement_skips_multiple_wrapped_lines ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_lists_mcp_servers ... ok [INFO] [stdout] test core::app::tests::paste_inserts_cursor_at_end_of_insert ... ok [INFO] [stdout] test core::app::tests::parse_resource_list_kind_accepts_templates ... ok [INFO] [stdout] test core::app::tests::default_sort_mode_helper_behaviour ... ok [INFO] [stdout] test core::app::tests::provider_model_cancel_reverts_base_url_and_state ... 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_plain_text_last_message ... ok [INFO] [stdout] test core::app::tests::start_new_stream_preserves_tool_history_and_clears_transient_state ... ok [INFO] [stdout] test core::app::tests::streaming_table_autoscroll_stays_consistent ... ok [INFO] [stdout] test core::app::tests::prewrap_cache_updates_metadata_for_markdown_last_message ... ok [INFO] [stdout] test core::app::tests::test_backspace_at_start_noop ... ok [INFO] [stdout] test core::app::tests::streaming_table_with_cache_invalidation_consistency ... ok [INFO] [stdout] test core::app::session::tests::prepare_with_auth_uses_pre_resolved_session ... ok [INFO] [stdout] test core::app::tests::test_backspace_at_line_start_joins_lines ... ok [INFO] [stdout] test core::app::tests::test_backspace_with_alt_modifier_deletes_single_char ... ok [INFO] [stdout] test core::app::tests::test_page_up_down_and_home_end_behavior ... ok [INFO] [stdout] test core::app::tests::test_cursor_mapping_blankline_insert_no_desync ... ok [INFO] [stdout] test core::app::tests::test_prewrap_cache_invalidates_on_width_change ... ok [INFO] [stdout] test core::app::tests::test_prev_next_user_message_index_navigation ... ok [INFO] [stdout] test core::app::tests::test_scroll_height_consistency_with_tables_regression ... ok [INFO] [stdout] test core::app::tests::test_last_and_first_user_message_index ... ok [INFO] [stdout] test core::app::tests::test_recompute_input_layout_after_edit_updates_scroll ... ok [INFO] [stdout] test core::app::tests::test_set_input_text_places_cursor_at_end ... ok [INFO] [stdout] test core::app::tests::test_prewrap_cache_reuse_when_unchanged ... 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_scroll_height_consistency_narrow_terminal_regression ... ok [INFO] [stdout] test core::app::tests::test_wrapped_vertical_navigation_keeps_column_zero_on_descend ... ok [INFO] [stdout] test core::app::tests::visual_line_controls_handle_blank_lines ... ok [INFO] [stdout] test core::app::tests::metadata_contains_code_blocks_after_cache ... ok [INFO] [stdout] test commands::tests::mcp_command_toggle_enabled_persists ... ok [INFO] [stdout] test core::app::tests::wrapped_cursor_crosses_paragraph_boundaries ... ok [INFO] [stdout] test core::app::tests::block_selection_uses_cached_metadata ... ok [INFO] [stdout] test core::app::tests::cache_invalidates_on_message_change ... ok [INFO] [stdout] test core::app::tests::test_wrapped_vertical_navigation_clamps_to_shorter_line ... ok [INFO] [stdout] test core::app::tests::test_sync_cursor_mapping_single_and_multi_line ... 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_handles_multiple_paragraphs ... ok [INFO] [stdout] test core::app::ui_state::tests::assistant_edit_flag_tracks_input_usage ... ok [INFO] [stdout] test core::app::ui_state::tests::begin_streaming_forces_transcript_focus ... ok [INFO] [stdout] test core::builtin_oauth::tests::render_oauth_callback_page_escapes_html ... ok [INFO] [stdout] test core::builtin_oauth::tests::render_oauth_callback_page_includes_text_and_accent ... ok [INFO] [stdout] test core::builtin_presets::tests::load_has_expected_builtins ... ok [INFO] [stdout] test core::app::tests::wrapped_cursor_moves_through_blank_lines ... ok [INFO] [stdout] test core::builtin_providers::tests::test_builtin_providers_cached_slice ... ok [INFO] [stdout] test core::builtin_providers::tests::test_anthropic_mode ... 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_xml_and_plaintext ... ok [INFO] [stdout] test core::app::tests::test_wrapped_vertical_navigation_preserves_visual_column ... 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_prettifies_json_with_summary ... ok [INFO] [stdout] test core::chat_stream::tests::process_sse_line_handles_spacing_variants ... ok [INFO] [stdout] test core::chat_stream::tests::process_sse_line_routes_stream_errors ... ok [INFO] [stdout] test core::app::tests::visual_line_start_end_track_wrapped_columns ... ok [INFO] [stdout] test core::chat_stream::tests::simple_sse_framer_flushes_end_of_stream ... 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::chat_stream::tests::simple_sse_framer_reports_invalid_utf8 ... ok [INFO] [stdout] test core::chat_stream::tests::simple_sse_framer_handles_crlf_and_blank_lines ... ok [INFO] [stdout] test core::app::ui_state::tests::exit_edit_select_mode_returns_to_typing ... ok [INFO] [stdout] test core::app::tests::theme_picker_highlights_active_theme_over_default ... ok [INFO] [stdout] test core::builtin_providers::tests::test_load_builtin_providers ... ok [INFO] [stdout] test core::chat_stream::tests::simple_sse_framer_suppresses_repeated_invalid_utf8 ... ok [INFO] [stdout] test core::app::ui_state::tests::enter_edit_select_mode_focuses_last_user_message ... ok [INFO] [stdout] test core::app::ui_state::tests::default_focus_is_transcript ... ok [INFO] [stdout] test core::config::tests::test_custom_provider_auth_modes ... ok [INFO] [stdout] test core::config::tests::test_config_persistence_lifecycle ... 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_overwrite_default_character ... ok [INFO] [stdout] test core::config::tests::test_overwrite_default_persona ... ok [INFO] [stdout] test core::config::tests::test_path_display ... ok [INFO] [stdout] test core::config::tests::test_path_display_with_config_dir ... ok [INFO] [stdout] test core::config::tests::test_persona_serialization ... ok [INFO] [stdout] test core::config::tests::test_load_nonexistent_config ... ok [INFO] [stdout] test core::config::tests::test_config_with_personas ... ok [INFO] [stdout] test core::config::tests::test_set_and_get_default_character ... ok [INFO] [stdout] test core::config::tests::test_custom_provider_management ... ok [INFO] [stdout] test core::config::tests::test_custom_theme_save_load ... 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_persona_cleans_up_empty_provider ... ok [INFO] [stdout] test core::config::tests::test_mcp_server_stdio_config_persistence ... ok [INFO] [stdout] test core::config::tests::test_empty_personas_array ... ok [INFO] [stdout] test core::mcp_sampling::tests::build_sampling_messages_rejects_image_content ... ok [INFO] [stdout] test core::mcp_sampling::tests::build_sampling_messages_includes_system_prompt ... ok [INFO] [stdout] test core::mcp_sampling::tests::sampling_timeout_accepts_timeout_seconds ... ok [INFO] [stdout] test core::config::tests::test_mcp_server_config_persistence ... ok [INFO] [stdout] test core::mcp_sampling::tests::sampling_timeout_ignores_invalid_values ... ok [INFO] [stdout] test core::message::tests::invalid_role_strings_are_rejected ... ok [INFO] [stdout] test core::message::tests::tool_roles_are_not_app_roles ... ok [INFO] [stdout] test core::message::tests::tool_messages_set_roles ... ok [INFO] [stdout] test core::mcp_sampling::tests::sampling_timeout_prefers_timeout_ms ... ok [INFO] [stdout] test core::oauth::tests::test_apply_oauth_token_response_preserves_existing_refresh_token ... ok [INFO] [stdout] test core::config::tests::test_unset_last_character_cleans_up_provider ... ok [INFO] [stdout] test core::app::tests::test_turn_off_character_mode_from_picker ... ok [INFO] [stdout] test core::config::tests::test_unset_default_character ... ok [INFO] [stdout] test core::oauth::tests::test_build_authorization_url_omits_empty_client_id ... ok [INFO] [stdout] test core::oauth::tests::test_build_authorization_url_includes_scope ... ok [INFO] [stdout] test core::oauth::tests::test_build_authorization_url_includes_required_params ... ok [INFO] [stdout] test core::config::tests::test_persona_optional_bio ... ok [INFO] [stdout] test core::oauth::tests::test_oauth_grant_needs_refresh_with_safety_window ... ok [INFO] [stdout] test core::oauth::tests::test_random_urlsafe_is_urlsafe ... ok [INFO] [stdout] test core::persona::tests::test_display_name_with_active_persona ... ok [INFO] [stdout] test commands::tests::mcp_command_toggle_on_triggers_refresh ... ok [INFO] [stdout] test core::oauth::tests::test_pkce_s256_matches_rfc_example ... ok [INFO] [stdout] test core::persona::tests::test_persona_activation_and_deactivation ... ok [INFO] [stdout] test core::persona::tests::test_default_persona_loading_from_config ... ok [INFO] [stdout] test core::persona::tests::test_persona_bio_substitution ... ok [INFO] [stdout] test core::persona::tests::test_substitution_logic_with_active_persona ... ok [INFO] [stdout] test core::persona::tests::test_persona_loading_from_configuration ... ok [INFO] [stdout] test core::persona::tests::test_display_name_with_no_persona ... 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_ignores_empty_or_whitespace_bio ... ok [INFO] [stdout] test core::persona::tests::test_invalid_persona_id_error_handling ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_default_persona_loading_from_config ... ok [INFO] [stdout] test core::persona::tests::test_system_prompt_modification_with_persona_no_bio ... ok [INFO] [stdout] test core::oauth::tests::test_refresh_token_response_deserializes_expected_fields ... ok [INFO] [stdout] test core::persona::tests::test_default_persona_lookup_case_and_underscores ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_cli_persona_overrides_default ... 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_config_persistence ... 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::config::tests::test_provider_id_normalization ... 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_interactive_persona_command_workflow ... ok [INFO] [stdout] test core::preset::tests::test_builtin_presets_can_be_disabled ... 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_display_name_in_conversation ... ok [INFO] [stdout] test core::preset::tests::test_builtin_presets_enabled_by_default ... ok [INFO] [stdout] test core::preset::tests::test_set_active_preset_error_message_mentions_available_options ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_picker_with_active_persona ... ok [INFO] [stdout] test core::preset::tests::test_get_default_for_provider_model ... ok [INFO] [stdout] test core::preset::tests::test_user_presets_override_builtins ... ok [INFO] [stdout] test core::preset::tests::test_set_and_clear_active_preset ... ok [INFO] [stdout] test core::providers::tests::provider_override_falls_back_to_env_on_keyring_failure ... ok [INFO] [stdout] test core::text_wrapping::tests::cursor_layout_reports_line_count_and_line_search ... ok [INFO] [stdout] test core::text_wrapping::tests::elided_space_maps_cursor_to_next_line_start ... ok [INFO] [stdout] test core::text_wrapping::tests::multiple_spaces_preserved_across_wrap ... ok [INFO] [stdout] test core::text_wrapping::tests::single_space_elided_when_wrap_occurs ... ok [INFO] [stdout] test core::text_wrapping::tests::position_map_lines_are_monotonic ... 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_cursor_position_map_soft_wrap_column_zero ... ok [INFO] [stdout] test core::app::ui_state::tests::focus_transitions_round_trip ... ok [INFO] [stdout] test core::text_wrapping::tests::test_wrap_with_double_width_emoji ... ok [INFO] [stdout] test core::config::tests::test_save_and_load_default_characters ... ok [INFO] [stdout] test mcp::client::protocol::tests::effective_protocol_prefers_negotiated ... 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_persona_command_variations ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_picker_turn_off_updates_ui_state ... ok [INFO] [stdout] test commands::tests::yolo_command_shows_and_persists ... ok [INFO] [stdout] test core::providers::tests::recoverable_keyring_failure_uses_env_credentials ... ok [INFO] [stdout] test core::providers::tests::permanent_keyring_failure_is_propagated ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_error_recovery ... ok [INFO] [stdout] test core::text_wrapping::tests::cursor_layout_tracks_consecutive_blank_lines ... ok [INFO] [stdout] test mcp::client::tests::server_capability_flags_enable_present_lists ... ok [INFO] [stdout] test mcp::client::tests::streamable_http_protocol_version_header_is_applied_when_present ... ok [INFO] [stdout] test mcp::client::tests::streamable_http_client_post_headers_include_json_and_sse_accept ... ok [INFO] [stdout] test mcp::client::tests::paginate_tools_list_stops_when_first_page_is_full ... ok [INFO] [stdout] test mcp::client::tests::server_capability_defaults_to_supported ... ok [INFO] [stdout] test mcp::client::tests::server_capability_flags_disable_missing_lists ... ok [INFO] [stdout] test mcp::client::tests::effective_protocol_version_prefers_negotiated_value ... ok [INFO] [stdout] test mcp::client::protocol::tests::parse_initialize_rejects_blank_protocol_version ... ok [INFO] [stdout] test mcp::permissions::tests::allow_once_is_consumed_after_query ... ok [INFO] [stdout] test mcp::client::tests::streamable_http_end_to_end_handles_json_and_sse_responses ... ok [INFO] [stdout] test mcp::client::transport_stdio::tests::stdio_requires_connected_client ... 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::transport::streamable_http::tests::detects_event_stream_content_type ... ok [INFO] [stdout] test mcp::permissions::tests::clear_server_removes_decisions ... ok [INFO] [stdout] test mcp::transport::streamable_http::tests::sse_buffer_handles_partial_lines ... ok [INFO] [stdout] test mcp::permissions::tests::deny_once_is_not_recorded ... ok [INFO] [stdout] test mcp::transport::streamable_http::tests::extracts_sse_payload ... ok [INFO] [stdout] test ui::builtin_themes::tests::load_has_expected_builtins ... ok [INFO] [stdout] test mcp::client::tests::paginate_tools_list_caps_and_preserves_cursor ... ok [INFO] [stdout] test mcp::client::transport_http::tests::ensure_session_requires_http_client ... ok [INFO] [stdout] test mcp::client::tests::connect_all_attempts_each_enabled_server_when_one_fails ... ok [INFO] [stdout] test ui::builtin_themes::tests::find_builtin_theme_works_case_insensitive ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::sanitize_paste_text_removes_control_characters ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::end_messages_finalize_responses ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::retry_last_message_emits_command_with_history ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::arrow_key_in_file_prompt_keeps_transcript_focus ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::error_messages_add_system_entries_and_stop_streaming ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::retry_last_message_returns_none_without_history ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::process_stream_updates_dispatches_actions ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::handle_paste_event_dispatches_insert_action ... ok [INFO] [stdout] test ui::chat_loop::executors::mcp_tools::tests::run_cancellable_returns_cancelled_error ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::submit_message_returns_spawn_command ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::typing_in_file_prompt_refocuses_input ... ok [INFO] [stdout] test commands::tests::syntax_command_updates_state_and_persists ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::tab_toggles_focus_without_slash_prefix ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::tab_does_not_switch_focus_in_block_select_mode ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::tab_does_not_switch_focus_in_edit_select_mode ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::tab_does_not_switch_focus_in_assistant_edit_select_mode ... ok [INFO] [stdout] test core::persona::tests::test_substitution_logic_with_no_persona ... ok [INFO] [stdout] test core::config::tests::test_unset_default_persona ... ok [INFO] [stdout] test ui::chat_loop::executors::mcp_tools::tests::spawn_mcp_tool_call_dispatches_missing_server_error ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::tab_autocompletes_slash_commands ... 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::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::executors::mcp_init::tests::mcp_initializer_dispatches_completion_when_connection_fails ... 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_n_handler_sets_status_when_prompt_missing ... 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::modes::tests::language_extension_detection ... 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::escape_handler_cancels_interruptible_mcp_activity ... 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::escape_handler_cancels_in_place_edit_via_action ... 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::assistant_edit_select_delete_truncates_without_flag ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::ctrl_n_handler_dispatches_refine_action ... 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_block_navigation_cycles_through_multiple_blocks ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_block_extraction_returns_consistent_results ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::assistant_edit_submission_appends_message_without_resend ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::f4_handler_toggles_compose_mode_via_action ... 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::assistant_edit_select_enter_loads_message_into_input ... 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::modes::tests::edit_select_enter_refocuses_input ... 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::escape_handler_cancels_streaming_via_action ... ok [INFO] [stdout] test ui::markdown::table::tests::clip_text_to_width_allows_mixed_text_and_emoji ... ok [INFO] [stdout] test ui::layout::tests::markdown_layout_populates_span_metadata ... ok [INFO] [stdout] test ui::markdown::tests::lists::blank_line_before_paragraph_doesnt_cause_blank_before_later_list_item ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::enter_key_completes_file_prompt_dump ... ok [INFO] [stdout] test ui::markdown::tests::lists::blockquote_followed_by_heading_has_single_blank_line ... ok [INFO] [stdout] test ui::layout::tests::link_metadata_spans_cover_spaces_within_link_text ... ok [INFO] [stdout] test ui::layout::tests::layout_lines_can_be_encoded_with_osc_links ... ok [INFO] [stdout] test ui::markdown::table::tests::clip_text_to_width_keeps_entire_graphemes ... ok [INFO] [stdout] test ui::layout::tests::plain_text_layout_synthesizes_metadata ... ok [INFO] [stdout] test ui::markdown::tests::lists::blockquote_followed_by_paragraph_has_single_blank_line ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_items_with_multiple_paragraphs_preserve_blank_lines ... ok [INFO] [stdout] test ui::markdown::tests::lists::code_blocks_dont_shift_list_item_indices ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_items_preserve_blank_lines_before_all_block_elements ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_followed_by_heading_has_blank_line_after ... ok [INFO] [stdout] test ui::markdown::tests::lists::gfm_callout_blockquotes_render_content ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_interleaved_blocks_have_unique_indices ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_followed_by_paragraph_has_blank_line_after ... ok [INFO] [stdout] test ui::markdown::tests::lists::blockquote_with_code_block_followed_by_paragraph ... ok [INFO] [stdout] test ui::markdown::tests::lists::blockquote_followed_by_list_has_single_blank_line ... ok [INFO] [stdout] test ui::markdown::tests::lists::complex_nested_lists_with_long_text_preserve_blank_lines ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_paragraphs_keep_indent_after_blank_lines ... ok [INFO] [stdout] test ui::markdown::tests::lists::nested_bullet_lists_render_with_indentation ... ok [INFO] [stdout] test ui::markdown::tests::lists::nested_lists_with_single_blank_line_dont_double_space ... ok [INFO] [stdout] test ui::markdown::tests::lists::multi_item_ordered_list_keeps_code_block_with_correct_item ... ok [INFO] [stdout] test ui::markdown::tests::lists::nested_lists_dont_add_blank_lines_between_same_level_items ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_preceded_by_paragraph_has_blank_line_before ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_preceded_by_heading_has_blank_line_before ... ok [INFO] [stdout] test ui::markdown::tests::lists::lists_with_numeric_text_before_them_dont_shift_indices ... ok [INFO] [stdout] test ui::markdown::tests::lists::lists_with_plus_markers_preserve_blank_lines ... ok [INFO] [stdout] test ui::markdown::tests::misc::emphasis_with_standalone_paren ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_with_source_blank_lines_preserves_spacing_between_top_level_items ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_paragraphs_with_soft_breaks_keep_indent ... ok [INFO] [stdout] test ui::markdown::tests::lists::wrapped_list_items_align_under_text ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_without_source_blank_lines_has_no_spacing_between_top_level_items ... ok [INFO] [stdout] test ui::markdown::tests::misc::horizontal_rules_render_as_centered_lines ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::multiple_code_blocks_have_unique_indices ... ok [INFO] [stdout] test ui::markdown::tests::lists::ordered_list_item_code_block_is_indented_under_marker ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::code_block_spans_have_metadata ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::user_message_code_blocks_have_metadata ... ok [INFO] [stdout] test ui::markdown::tests::tables::table_parser_emits_expected_event_sequence ... ok [INFO] [stdout] test ui::markdown::tests::misc::test_extremely_narrow_terminal_no_truncation ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::nested_code_blocks_have_metadata ... ok [INFO] [stdout] test ui::markdown::tests::misc::tool_call_arguments_do_not_render_markdown ... ok [INFO] [stdout] test ui::markdown::tests::tables::table_rendering_works ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::empty_code_block_has_metadata ... ok [INFO] [stdout] test ui::markdown::tests::tables::table_preserves_words_with_available_space ... ok [INFO] [stdout] test ui::markdown::tests::misc::test_logical_row_continuation ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_balancing_performance ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::markdown_details_metadata_matches_lines_and_tags ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_column_width_balancing ... ok [INFO] [stdout] test ui::markdown::tests::tables::metadata_marks_table_links ... ok [INFO] [stdout] test ui::markdown::tests::tables::table_renders_emoji_and_br_correctly ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_styled_words_wrap_at_boundaries_in_table ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::code_block_without_language_has_metadata ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::metadata_marks_app_prefix ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_balancing_with_terminal_width ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::code_and_link_metadata_coexist ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_no_content_truncation_wide_terminal ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_should_not_wrap_borders ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::metadata_marks_user_prefix ... ok [INFO] [stdout] test ui::markdown::tests::misc::markdown_images_emit_clickable_links ... ok [INFO] [stdout] test ui::markdown::tests::misc::superscript_and_subscript_render_without_markers ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::cell_wraps_at_space_across_spans ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_wrapping_with_mixed_content ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_cell_word_wrapping_regression ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_content_wrapping_medium_terminal ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_with_emoji_and_unicode_no_truncation ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::cell_wraps_after_hyphen ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_ending_one_after_width ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_fills_entire_width_with_adjacent_punct ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::inline_code_ending_at_width ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_preserves_style_during_backtracking ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::code_with_closing_paren_at_width ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_government_systems_table_from_testcase ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_with_paren_outside_one_past_width ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_with_punctuation_at_width ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::shared_renderer_with_metadata_matches_details_wrapper ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::markdown_links_wrap_at_word_boundaries_with_width ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::link_ending_at_width ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::markdown_links_wrap_in_long_paragraph_without_mid_word_break ... ok [INFO] [stdout] test ui::osc::tests::control_detection_catches_bel_and_escape ... 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::osc::tests::encode_hyperlink_rejects_empty_segments ... ok [INFO] [stdout] test ui::osc::tests::encode_lines_with_links_wraps_each_link_segment ... ok [INFO] [stdout] test ui::osc::tests::encode_hyperlink_wraps_text_with_balanced_sequences ... ok [INFO] [stdout] test ui::osc::tests::lines_with_underline_fallback_apply_to_each_link ... ok [INFO] [stdout] test ui::markdown::wrap::tests::wrap_preserves_zwj_clusters ... ok [INFO] [stdout] test ui::osc::tests::underline_fallback_wraps_link_text_with_sgr_sequences ... ok [INFO] [stdout] test ui::osc_backend::tests::closes_stale_hyperlink_even_without_cell_diff ... ok [INFO] [stdout] test ui::osc::tests::encode_line_with_links_returns_plain_text_without_metadata ... ok [INFO] [stdout] test ui::osc_backend::tests::closes_hyperlink_removed_by_scroll_without_touching_endpoint ... ok [INFO] [stdout] test ui::osc_state::tests::compute_render_state_tracks_visible_link_segment ... ok [INFO] [stdout] test ui::markdown::wrap::tests::wrap_preserves_skin_tone_modifiers ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_with_multiple_adjacent_punctuation ... ok [INFO] [stdout] test ui::osc_state::tests::compute_render_state_accounts_for_emoji_presentation_sequences ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_model_no_filter_no_default ... 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_no_picker ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::strikethrough_ending_at_width ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::strong_emphasis_ending_at_width ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_model_with_filter ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_with_paren_inside_at_width ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_theme_picker ... ok [INFO] [stdout] test ui::renderer::tests::activity_indicator_label_marks_mcp_operations ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_theme_with_default_selected ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_character_with_filter ... ok [INFO] [stdout] test ui::renderer::tests::input_title_resets_after_stream_completion ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_character_with_default_selected ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_model_with_default_selected ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_with_default_selected ... ok [INFO] [stdout] test ui::renderer::tests::title_does_not_show_character_when_none ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_computes_line_ranges ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_handles_empty_metadata ... ok [INFO] [stdout] test ui::span::tests::code_block_meta_handles_no_language ... ok [INFO] [stdout] test ui::span::tests::code_block_meta_stores_language ... ok [INFO] [stdout] test ui::span::tests::extract_code_block_content_retrieves_code ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::wrapped_code_preserves_metadata_across_lines ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_finds_all_blocks ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_no_model_selected_during_transition ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_character_name_when_active ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_handles_no_code_blocks ... 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 utils::auth::tests::test_custom_provider_auth_headers ... 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 ui::renderer::tests::title_places_preset_after_character_when_active ... 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 ui::renderer::tests::title_shows_model_when_not_in_transition ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_basic ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_preserves_language ... 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::renderer::tests::test_generate_picker_help_text_character_picker ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_long_mixed_input ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_active_preset_when_set ... ok [INFO] [stdout] test ui::span::tests::extract_content_preserves_blank_lines ... ok [INFO] [stdout] test ui::span::tests::extract_content_preserves_line_breaks ... ok [INFO] [stdout] test ui::span::tests::extract_content_returns_none_for_invalid_index ... ok [INFO] [stdout] test utils::line_editor::tests::ctrl_a_and_ctrl_e_map_to_start_end ... ok [INFO] [stdout] test utils::line_editor::tests::f2_maps_to_toggle_only_with_reveal_tail_mask ... ok [INFO] [stdout] test ui::span::tests::extract_content_handles_multiple_spans_per_line ... ok [INFO] [stdout] test utils::line_editor::tests::insert_and_move_cursor ... ok [INFO] [stdout] test utils::line_editor::tests::paste_newline_submits ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_mixed_control_chars ... ok [INFO] [stdout] test utils::line_editor::tests::ctrl_k_deletes_to_end ... ok [INFO] [stdout] test utils::scroll::tests::assistant_selection_highlight_changes_rendered_lines ... ok [INFO] [stdout] test ui::span::tests::extract_content_omits_list_indent ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_preserves_newlines ... ok [INFO] [stdout] test utils::line_editor::tests::masked_display_can_reveal_tail ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_tabs ... ok [INFO] [stdout] test utils::scroll::tests::test_build_display_lines_up_to ... ok [INFO] [stdout] test utils::scroll::tests::perf_prewrap_short_history ... ok [INFO] [stdout] test utils::scroll::tests::test_build_display_lines_basic ... ok [INFO] [stdout] test utils::scroll::tests::test_app_message_formatting ... 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_wrapped_line_count_zero_width ... ok [INFO] [stdout] test utils::scroll::tests::test_markdown_link_wraps_on_nbsp ... ok [INFO] [stdout] test utils::scroll::tests::test_empty_message_content ... ok [INFO] [stdout] test utils::scroll::tests::test_layout_engine_and_prewrap_preserve_link_words ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_scroll_to_bottom_scroll_needed ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_max_scroll_offset ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::various_language_tags_preserved ... 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_line ... 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_multiple_lines ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_word_wrapped_lines_exact_fit ... ok [INFO] [stdout] test utils::scroll::tests::test_markdown_link_wraps_on_spaces ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_wrapped_line_count_mixed_content ... 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_prewrap_paragraph_no_leading_spaces_or_lonely_dot ... ok [INFO] [stdout] test utils::scroll::tests::test_trimming_behavior ... ok [INFO] [stdout] test utils::url::tests::test_normalize_base_url ... ok [INFO] [stdout] test utils::scroll::tests::test_multiline_user_message ... ok [INFO] [stdout] test utils::scroll::tests::test_plain_text_long_line_wrapping ... 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::syntax::tests::normalize_lang_hint_maps_common_aliases ... ok [INFO] [stdout] test utils::scroll::tests::test_scroll_offset_to_line_start_basic ... ok [INFO] [stdout] test utils::scroll::tests::test_word_wrapping_with_long_paragraph ... 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::syntax::tests::theme_selection_matches_brightness ... ok [INFO] [stdout] test utils::scroll::tests::test_selection_highlight_builds_same_number_of_lines ... 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 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. 723 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 2.57s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/chabeau-16ccc20e5ee6413f) [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Doc-tests chabeau [INFO] [stdout] [INFO] [stdout] running 11 tests [INFO] [stdout] test src/auth/mod.rs - auth::AuthManager::resolve_authentication (line 206) - compile ... ok [INFO] [stdout] test src/core/app/mod.rs - core::app::new_with_auth (line 144) - compile ... ok [INFO] [stdout] test src/core/chat_stream.rs - core::chat_stream::ChatStreamService::spawn_stream (line 475) - compile ... ok [INFO] [stdout] test src/character/service.rs - character::service::CharacterService::resolve (line 168) - compile ... ok [INFO] [stdout] test src/ui/span.rs - ui::span (line 29) ... ok [INFO] [stdout] test src/ui/span.rs - ui::span (line 14) ... ok [INFO] [stdout] test src/core/chat_stream.rs - core::chat_stream::ChatStreamService::new (line 441) ... ok [INFO] [stdout] test src/utils/url.rs - utils::url::normalize_base_url (line 13) ... 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::extract_code_blocks (line 219) ... ok [INFO] [stdout] test src/utils/url.rs - utils::url::construct_api_url (line 31) ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 11 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 16.69s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "a7ec2a3f8a6915114e29c1abc50c23d7300bdeee538a18cee55121b50c2a9417", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "a7ec2a3f8a6915114e29c1abc50c23d7300bdeee538a18cee55121b50c2a9417", kill_on_drop: false }` [INFO] [stdout] a7ec2a3f8a6915114e29c1abc50c23d7300bdeee538a18cee55121b50c2a9417