[INFO] fetching crate chabeau 0.5.1... [INFO] testing chabeau-0.5.1 against master#c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38 for pr-146098-7 [INFO] extracting crate chabeau 0.5.1 into /workspace/builds/worker-5-tc1/source [INFO] started tweaking crates.io crate chabeau 0.5.1 [INFO] finished tweaking crates.io crate chabeau 0.5.1 [INFO] tweaked toml for crates.io crate chabeau 0.5.1 written to /workspace/builds/worker-5-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate chabeau 0.5.1 on toolchain c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate chabeau 0.5.1 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" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded winreg v0.52.0 [INFO] [stderr] Downloaded windows-interface v0.57.0 [INFO] [stderr] Downloaded windows-result v0.1.2 [INFO] [stderr] Downloaded vergen-lib v0.1.6 [INFO] [stderr] Downloaded lru v0.12.5 [INFO] [stderr] Downloaded vergen v9.0.6 [INFO] [stderr] Downloaded dbus-secret-service v4.1.0 [INFO] [stderr] Downloaded cassowary v0.3.0 [INFO] [stderr] Downloaded criterion-plot v0.6.0 [INFO] [stderr] Downloaded onig v6.5.1 [INFO] [stderr] Downloaded half v2.7.1 [INFO] [stderr] Downloaded keyring v3.6.3 [INFO] [stderr] Downloaded dbus v0.9.9 [INFO] [stderr] Downloaded criterion v0.7.0 [INFO] [stderr] Downloaded rustls-webpki v0.103.7 [INFO] [stderr] Downloaded pulldown-cmark v0.13.0 [INFO] [stderr] Downloaded crossterm v0.28.1 [INFO] [stderr] Downloaded objc2-core-foundation v0.3.2 [INFO] [stderr] Downloaded sysinfo v0.34.2 [INFO] [stderr] Downloaded ntapi v0.4.1 [INFO] [stderr] Downloaded webpki-roots v1.0.3 [INFO] [stderr] Downloaded compact_str v0.8.1 [INFO] [stderr] Downloaded flate2 v1.1.4 [INFO] [stderr] Downloaded tui-textarea v0.7.0 [INFO] [stderr] Downloaded cargo_metadata v0.19.2 [INFO] [stderr] Downloaded windows-core v0.57.0 [INFO] [stderr] Downloaded rustls v0.23.33 [INFO] [stderr] Downloaded windows-implement v0.57.0 [INFO] [stderr] Downloaded unicode-truncate v1.1.0 [INFO] [stderr] Downloaded castaway v0.2.4 [INFO] [stderr] Downloaded instability v0.3.9 [INFO] [stderr] Downloaded pulldown-cmark-escape v0.11.0 [INFO] [stderr] Downloaded strum_macros v0.26.4 [INFO] [stderr] Downloaded vergen-git2 v1.0.7 [INFO] [stderr] Downloaded strum v0.26.3 [INFO] [stderr] Downloaded ratatui v0.29.0 [INFO] [stderr] Downloaded onig_sys v69.9.1 [INFO] [stderr] Downloaded syntect v5.3.0 [INFO] [stderr] Downloaded libdbus-sys v0.2.6 [INFO] [stderr] Downloaded windows v0.57.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 224e64f0ddac4628a53419284583e550de86dc2006c317eb6347f3894ac8f9da [INFO] running `Command { std: "docker" "start" "-a" "224e64f0ddac4628a53419284583e550de86dc2006c317eb6347f3894ac8f9da", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "224e64f0ddac4628a53419284583e550de86dc2006c317eb6347f3894ac8f9da", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "224e64f0ddac4628a53419284583e550de86dc2006c317eb6347f3894ac8f9da", kill_on_drop: false }` [INFO] [stdout] 224e64f0ddac4628a53419284583e550de86dc2006c317eb6347f3894ac8f9da [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] f759c222924c50adf9a4fd70b88cd9e1c00e81d878a1d7b2544a4f5c11d199f3 [INFO] running `Command { std: "docker" "start" "-a" "f759c222924c50adf9a4fd70b88cd9e1c00e81d878a1d7b2544a4f5c11d199f3", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.177 [INFO] [stderr] Compiling stable_deref_trait v1.2.1 [INFO] [stderr] Compiling rustversion v1.0.22 [INFO] [stderr] Compiling proc-macro2 v1.0.101 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling bitflags v2.9.4 [INFO] [stderr] Compiling thiserror v2.0.17 [INFO] [stderr] Compiling deranged v0.5.4 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling camino v1.2.1 [INFO] [stderr] Compiling regex-syntax v0.8.8 [INFO] [stderr] Compiling serde_json v1.0.145 [INFO] [stderr] Compiling aho-corasick v1.1.3 [INFO] [stderr] Compiling anyhow v1.0.100 [INFO] [stderr] Compiling percent-encoding v2.3.2 [INFO] [stderr] Compiling signal-hook v0.3.18 [INFO] [stderr] Compiling libdbus-sys v0.2.6 [INFO] [stderr] Compiling rustls v0.23.33 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling num_threads v0.1.7 [INFO] [stderr] Compiling form_urlencoded v1.2.2 [INFO] [stderr] Compiling quote v1.0.41 [INFO] [stderr] Compiling futures-channel v0.3.31 [INFO] [stderr] Compiling foldhash v0.1.5 [INFO] [stderr] Compiling unicode-width v0.2.0 [INFO] [stderr] Compiling allocator-api2 v0.2.21 [INFO] [stderr] Compiling linux-raw-sys v0.4.15 [INFO] [stderr] Compiling instability v0.3.9 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling tracing v0.1.41 [INFO] [stderr] Compiling syn v2.0.106 [INFO] [stderr] Compiling static_assertions v1.1.0 [INFO] [stderr] Compiling unicode-segmentation v1.12.0 [INFO] [stderr] Compiling unicode-width v0.1.14 [INFO] [stderr] Compiling quick-xml v0.38.3 [INFO] [stderr] Compiling clap_lex v0.7.6 [INFO] [stderr] Compiling pulldown-cmark v0.13.0 [INFO] [stderr] Compiling cassowary v0.3.0 [INFO] [stderr] Compiling linked-hash-map v0.5.6 [INFO] [stderr] Compiling winnow v0.7.13 [INFO] [stderr] Compiling option-ext v0.2.0 [INFO] [stderr] Compiling same-file v1.0.6 [INFO] [stderr] Compiling rustix v1.1.2 [INFO] [stderr] Compiling hashbrown v0.15.5 [INFO] [stderr] Compiling unicode-truncate v1.1.0 [INFO] [stderr] Compiling yaml-rust v0.4.5 [INFO] [stderr] Compiling walkdir v2.5.0 [INFO] [stderr] Compiling time v0.3.44 [INFO] [stderr] Compiling clap_builder v4.5.49 [INFO] [stderr] Compiling vergen-lib v0.1.6 [INFO] [stderr] Compiling vergen v9.0.6 [INFO] [stderr] Compiling vergen-git2 v1.0.7 [INFO] [stderr] Compiling castaway v0.2.4 [INFO] [stderr] Compiling getopts v0.2.24 [INFO] [stderr] Compiling compact_str v0.8.1 [INFO] [stderr] Compiling flate2 v1.1.4 [INFO] [stderr] Compiling lru v0.12.5 [INFO] [stderr] Compiling toml_datetime v0.7.3 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Compiling mio v1.0.4 [INFO] [stderr] Compiling socket2 v0.6.1 [INFO] [stderr] Compiling getrandom v0.2.16 [INFO] [stderr] Compiling signal-hook-registry v1.4.6 [INFO] [stderr] Compiling sysinfo v0.34.2 [INFO] [stderr] Compiling cc v1.2.41 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling regex-automata v0.4.13 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling dbus v0.9.9 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling signal-hook-mio v0.2.4 [INFO] [stderr] Compiling crossterm v0.28.1 [INFO] [stderr] Compiling toml_parser v1.0.4 [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 directories v6.0.0 [INFO] [stderr] Compiling toml v0.9.8 [INFO] [stderr] Compiling tempfile v3.23.0 [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 semver v1.0.27 [INFO] [stderr] Compiling rustc_version v0.4.1 [INFO] [stderr] Compiling regex v1.12.2 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling darling_core v0.20.11 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.0 [INFO] [stderr] Compiling zerovec-derive v0.11.1 [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 tokio-macros v2.6.0 [INFO] [stderr] Compiling thiserror-impl v2.0.17 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling zeroize v1.8.2 [INFO] [stderr] Compiling rustls-pki-types v1.12.0 [INFO] [stderr] Compiling tokio v1.48.0 [INFO] [stderr] Compiling strum_macros v0.26.4 [INFO] [stderr] Compiling rustls-webpki v0.103.7 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling webpki-roots v1.0.3 [INFO] [stderr] Compiling dbus-secret-service v4.1.0 [INFO] [stderr] Compiling onig v6.5.1 [INFO] [stderr] Compiling clap_derive v4.5.49 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling yoke v0.8.0 [INFO] [stderr] Compiling zerovec v0.11.4 [INFO] [stderr] Compiling zerotrie v0.2.2 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling darling_macro v0.20.11 [INFO] [stderr] Compiling keyring v3.6.3 [INFO] [stderr] Compiling darling v0.20.11 [INFO] [stderr] Compiling derive_builder_core v0.20.2 [INFO] [stderr] Compiling strum v0.26.3 [INFO] [stderr] Compiling ratatui v0.29.0 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling bincode v1.3.3 [INFO] [stderr] Compiling plist v1.8.0 [INFO] [stderr] Compiling tinystr v0.8.1 [INFO] [stderr] Compiling potential_utf v0.1.3 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling icu_collections v2.0.0 [INFO] [stderr] Compiling chrono v0.4.42 [INFO] [stderr] Compiling icu_locale_core v2.0.0 [INFO] [stderr] Compiling derive_builder_macro v0.20.2 [INFO] [stderr] Compiling cargo-platform v0.1.9 [INFO] [stderr] Compiling derive_builder v0.20.2 [INFO] [stderr] Compiling cargo_metadata v0.19.2 [INFO] [stderr] Compiling clap v4.5.49 [INFO] [stderr] Compiling syntect v5.3.0 [INFO] [stderr] Compiling icu_provider v2.0.0 [INFO] [stderr] Compiling icu_properties v2.0.1 [INFO] [stderr] Compiling icu_normalizer v2.0.0 [INFO] [stderr] Compiling tui-textarea v0.7.0 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling url v2.5.7 [INFO] [stderr] Compiling git2 v0.20.2 [INFO] [stderr] Compiling hyper v1.7.0 [INFO] [stderr] Compiling tower v0.5.2 [INFO] [stderr] Compiling tokio-util v0.7.16 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling tower-http v0.6.6 [INFO] [stderr] Compiling hyper-util v0.1.17 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling reqwest v0.12.24 [INFO] [stderr] Compiling chabeau v0.5.1 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 59s [INFO] running `Command { std: "docker" "inspect" "f759c222924c50adf9a4fd70b88cd9e1c00e81d878a1d7b2544a4f5c11d199f3", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f759c222924c50adf9a4fd70b88cd9e1c00e81d878a1d7b2544a4f5c11d199f3", kill_on_drop: false }` [INFO] [stdout] f759c222924c50adf9a4fd70b88cd9e1c00e81d878a1d7b2544a4f5c11d199f3 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 6a16fc46d8a86645a0934fe284367cd5d861fb6639eb47b10598014f1c420457 [INFO] running `Command { std: "docker" "start" "-a" "6a16fc46d8a86645a0934fe284367cd5d861fb6639eb47b10598014f1c420457", kill_on_drop: false }` [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling zerocopy v0.8.27 [INFO] [stderr] Compiling zerocopy-derive v0.8.27 [INFO] [stderr] Compiling plotters-backend v0.3.7 [INFO] [stderr] Compiling regex-automata v0.4.13 [INFO] [stderr] Compiling cast v0.3.0 [INFO] [stderr] Compiling rayon v1.11.0 [INFO] [stderr] Compiling anes v0.1.6 [INFO] [stderr] Compiling oorandom v11.1.5 [INFO] [stderr] Compiling criterion-plot v0.6.0 [INFO] [stderr] Compiling plotters-svg v0.3.7 [INFO] [stderr] Compiling plotters v0.3.7 [INFO] [stderr] Compiling cargo-platform v0.1.9 [INFO] [stderr] Compiling url v2.5.7 [INFO] [stderr] Compiling cargo_metadata v0.19.2 [INFO] [stderr] Compiling bincode v1.3.3 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling plist v1.8.0 [INFO] [stderr] Compiling chrono v0.4.42 [INFO] [stderr] Compiling tinytemplate v1.2.1 [INFO] [stderr] Compiling git2 v0.20.2 [INFO] [stderr] Compiling reqwest v0.12.24 [INFO] [stderr] Compiling vergen v9.0.6 [INFO] [stderr] Compiling syntect v5.3.0 [INFO] [stderr] Compiling regex v1.12.2 [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] Compiling vergen-git2 v1.0.7 [INFO] [stderr] Compiling chabeau v0.5.1 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 57.41s [INFO] running `Command { std: "docker" "inspect" "6a16fc46d8a86645a0934fe284367cd5d861fb6639eb47b10598014f1c420457", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6a16fc46d8a86645a0934fe284367cd5d861fb6639eb47b10598014f1c420457", kill_on_drop: false }` [INFO] [stdout] 6a16fc46d8a86645a0934fe284367cd5d861fb6639eb47b10598014f1c420457 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 80cecfe5af3622044fdd30199e4459f52d27b79222e3a79f6bf88f56db341bf1 [INFO] running `Command { std: "docker" "start" "-a" "80cecfe5af3622044fdd30199e4459f52d27b79222e3a79f6bf88f56db341bf1", 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-d5b81f99924037ed) [INFO] [stdout] [INFO] [stdout] running 489 tests [INFO] [stdout] test auth::ui::tests::delete_last_word_handles_spaces_only ... ok [INFO] [stdout] test auth::ui::tests::masked_input_cancel ... ok [INFO] [stdout] test auth::ui::tests::masked_input_submit_after_paste_with_newline ... 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 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 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_optional_fields ... ok [INFO] [stdout] test character::card::tests::test_optional_fields_not_serialized_when_none ... 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::cache::tests::test_cache_miss_reloads_data ... ok [INFO] [stdout] test character::card::tests::test_system_prompt_with_substitutions ... ok [INFO] [stdout] test auth::ui::tests::confirmation_parsing_handles_empty_and_cancel ... ok [INFO] [stdout] test auth::tests::env_fallback_sets_openai_provider_for_default_base ... ok [INFO] [stdout] test character::import::tests::test_import_and_verify_in_temp_dir ... ok [INFO] [stdout] test auth::tests::resolve_deauth_target_normalizes_builtin_provider ... ok [INFO] [stdout] test character::import::tests::test_import_card_preserves_filename ... ok [INFO] [stdout] test auth::tests::env_fallback_sets_openai_compatible_for_custom_base ... ok [INFO] [stdout] test auth::ui::tests::masked_input_insert_and_backspace ... ok [INFO] [stdout] test auth::ui::tests::delete_last_word_removes_trailing_word ... ok [INFO] [stdout] test character::import::tests::test_import_card_creates_directory ... 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 character::import::tests::test_import_card_validation_before_copy ... ok [INFO] [stdout] test character::import::tests::test_import_valid_card ... ok [INFO] [stdout] test character::import::tests::test_import_invalid_card ... 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 ... 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::import::tests::test_import_with_force_flag ... ok [INFO] [stdout] test character::loader::tests::test_card_discovery_prefers_json_over_png ... ok [INFO] [stdout] test character::loader::tests::test_list_cards_ignores_subdirectories ... 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_list_available_cards_with_test_cards ... 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 auth::tests::collect_configured_providers_skips_duplicate_custom_entries ... ok [INFO] [stdout] test character::cache::tests::test_compute_cache_key_empty_directory ... ok [INFO] [stdout] test character::import::tests::test_import_card_success_message_format ... ok [INFO] [stdout] test character::loader::tests::test_load_card_png ... 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::import::tests::test_import_overwrite_protection ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_file_not_found ... ok [INFO] [stdout] test character::loader::tests::test_load_hypatia_json ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_invalid_json ... ok [INFO] [stdout] test character::loader::tests::test_load_hypatia_png ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_with_optional_fields ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_invalid_base64 ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_file_not_found ... ok [INFO] [stdout] test character::loader::tests::test_png_and_json_equivalence ... 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::import::tests::test_import_error_display ... ok [INFO] [stdout] test character::loader::tests::test_load_spec_v2_png_cards ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_missing_required_field ... ok [INFO] [stdout] test character::loader::tests::test_load_valid_json_card ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_not_a_png ... 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_load_png_card_with_metadata ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_empty_name ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_multiple_errors ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_valid ... ok [INFO] [stdout] test character::png_text::tests::rejects_invalid_crc ... ok [INFO] [stdout] test character::test_helpers::helpers::tests::test_valid_card_json ... ok [INFO] [stdout] test character::png_text::tests::extracts_requested_text ... 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_create_temp_cards_dir_with_cards ... ok [INFO] [stdout] test character::test_helpers::helpers::tests::test_create_test_character ... 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_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_config_persistence_with_multiple_defaults ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_error_case_missing_required_fields ... ok [INFO] [stdout] test character::test_helpers::helpers::tests::test_invalid_card_json ... ok [INFO] [stdout] test character::loader::tests::test_load_invalid_test_card ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_error_case_wrong_spec_version ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_invalid_json ... ok [INFO] [stdout] test character::png_text::tests::reports_missing_keyword ... ok [INFO] [stdout] test character::test_helpers::helpers::tests::test_create_temp_cards_dir ... ok [INFO] [stdout] test cli::tests::test_character_flag_with_other_flags ... 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_full_conversation_flow_with_character ... 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_character_switching_during_session ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_character_with_empty_optional_fields ... ok [INFO] [stdout] test cli::tests::test_character_flag_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_preset_flag_parsing ... ok [INFO] [stdout] test auth::tests::resolve_deauth_target_normalizes_custom_provider ... ok [INFO] [stdout] test cli::tests::test_persona_validation_with_valid_config ... ok [INFO] [stdout] test commands::tests::character_command_registered_in_help ... 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 commands::tests::character_command_opens_picker ... ok [INFO] [stdout] test commands::tests::persona_command_opens_picker ... ok [INFO] [stdout] test commands::tests::model_command_returns_open_picker_result ... ok [INFO] [stdout] test commands::tests::help_command_includes_registry_metadata ... ok [INFO] [stdout] test commands::tests::persona_command_with_invalid_id_shows_error ... 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::model_command_with_id_sets_model ... ok [INFO] [stdout] test commands::tests::persona_command_with_valid_id_updates_user_display_name ... ok [INFO] [stdout] test commands::tests::character_command_with_invalid_name_shows_error ... ok [INFO] [stdout] test commands::tests::test_process_input_dump_with_filename ... ok [INFO] [stdout] test commands::tests::test_dump_conversation ... ok [INFO] [stdout] test commands::tests::test_process_input_dump_empty_conversation ... ok [INFO] [stdout] test commands::tests::test_dump_conversation_file_exists ... ok [INFO] [stdout] test commands::tests::theme_command_opens_picker ... ok [INFO] [stdout] test commands::tests::picker_supports_home_end_navigation_and_metadata ... ok [INFO] [stdout] test core::app::actions::file_prompt::tests::file_prompt_dump_success_sets_status_and_closes_prompt ... 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 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 commands::tests::dump_conversation_uses_persona_display_name ... ok [INFO] [stdout] test core::app::actions::input::tests::process_command_submits_message ... 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::character_picker_closes_after_selection ... 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::tests::stream_app_message_adds_trimmed_content_and_keeps_stream_alive ... ok [INFO] [stdout] test core::app::actions::streaming::tests::stream_errored_drops_empty_assistant_placeholder ... ok [INFO] [stdout] test core::app::conversation::tests::add_user_message_omits_trailing_empty_assistant_turns ... ok [INFO] [stdout] test core::app::actions::picker::tests::test_load_default_preset_if_configured ... ok [INFO] [stdout] test core::app::conversation::tests::test_add_user_message_with_character_active ... 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_add_user_message_without_character ... ok [INFO] [stdout] test core::app::conversation::tests::add_user_message_logs_persona_display_name ... ok [INFO] [stdout] test core::app::conversation::tests::test_character_greeting_included_in_api_messages ... 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_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::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::conversation::tests::test_character_messages_with_transcript_system_messages ... 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_without_character ... ok [INFO] [stdout] test core::app::conversation::tests::test_prepare_retry_with_character_active ... 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::actions::picker::tests::theme_picker_escape_reverts_preview ... ok [INFO] [stdout] test core::app::picker::tests::test_filter_characters_preserves_special_entry_and_selection_bounds ... 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_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_show_character_greeting_empty_greeting ... ok [INFO] [stdout] test core::app::picker::tests::test_character_picker_highlights_active_character ... ok [INFO] [stdout] test core::app::conversation::tests::test_show_character_greeting_if_needed ... ok [INFO] [stdout] test core::app::conversation::tests::test_show_character_greeting_no_character ... ok [INFO] [stdout] test core::app::picker::tests::test_persona_picker_sanitizes_bio_metadata ... 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_mixed_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_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_persona_picker_highlights_active_persona ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_handles_empty_string ... ok [INFO] [stdout] test core::app::picker::tests::test_preset_picker_highlights_active_preset ... 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_removes_newlines ... 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::initialize_logging_with_file_writes_initial_entry ... 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::load_character_for_session_cards_dir_priority ... ok [INFO] [stdout] test core::app::session::tests::load_character_for_session_filepath_fallback ... 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_no_character ... ok [INFO] [stdout] test core::app::session::tests::resolve_theme_prefers_configured_theme ... ok [INFO] [stdout] test core::app::session::tests::session_context_clear_character ... ok [INFO] [stdout] test core::app::session::tests::session_context_get_character_returns_none_initially ... ok [INFO] [stdout] test core::app::conversation::tests::test_retry_character_greeting_updates_after_persona_change ... ok [INFO] [stdout] test cli::tests::test_cli_set_default_model_with_mixed_case_provider ... ok [INFO] [stdout] test core::app::session::tests::session_context_selecting_different_character_resets_greeting_flag ... ok [INFO] [stdout] test core::app::session::tests::session_context_greeting_lifecycle ... ok [INFO] [stdout] test core::app::session::tests::session_context_set_character ... 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_reselecting_same_character_preserves_greeting_flag ... ok [INFO] [stdout] test core::app::session::tests::session_context_should_show_greeting ... ok [INFO] [stdout] test core::app::session::tests::theme_from_appearance_matches_light_theme ... ok [INFO] [stdout] test core::app::session::tests::theme_from_appearance_matches_dark_theme ... ok [INFO] [stdout] test core::app::settings::tests::apply_theme_session_only_updates_ui ... ok [INFO] [stdout] test core::app::settings::tests::apply_provider_reuses_existing_session_credentials ... ok [INFO] [stdout] test core::app::settings::tests::preview_theme_preserves_current_theme_id ... ok [INFO] [stdout] test core::app::tests::calculate_available_height_matches_expected_layout_rules ... ok [INFO] [stdout] test core::app::session::tests::prepare_with_auth_uses_pre_resolved_session ... ok [INFO] [stdout] test core::app::tests::default_sort_mode_helper_behaviour ... ok [INFO] [stdout] test core::app::settings::tests::apply_model_clears_transition_state ... ok [INFO] [stdout] test core::app::tests::model_picker_title_uses_az_when_no_dates ... ok [INFO] [stdout] test core::app::tests::narrow_terminal_exposes_scroll_height_mismatch ... ok [INFO] [stdout] test core::app::tests::prewrap_cache_invalidates_on_width_change ... 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::prewrap_height_matches_renderer_with_tables ... ok [INFO] [stdout] test core::app::tests::prewrap_cache_reuse_no_changes ... ok [INFO] [stdout] test core::app::tests::provider_model_cancel_reverts_base_url_and_state ... ok [INFO] [stdout] test core::app::tests::streaming_table_with_cache_invalidation_consistency ... ok [INFO] [stdout] test core::app::tests::test_backspace_at_start_noop ... ok [INFO] [stdout] test core::app::tests::streaming_table_autoscroll_stays_consistent ... ok [INFO] [stdout] test core::app::tests::test_backspace_with_alt_modifier_deletes_single_char ... ok [INFO] [stdout] test core::app::tests::test_last_and_first_user_message_index ... ok [INFO] [stdout] test core::app::tests::test_backspace_at_line_start_joins_lines ... ok [INFO] [stdout] test core::app::tests::test_page_up_down_and_home_end_behavior ... ok [INFO] [stdout] test core::app::tests::test_prev_next_user_message_index_navigation ... ok [INFO] [stdout] test core::app::tests::test_recompute_input_layout_after_edit_updates_scroll ... 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_set_input_text_places_cursor_at_end ... ok [INFO] [stdout] test core::app::tests::test_sync_cursor_mapping_single_and_multi_line ... ok [INFO] [stdout] test core::app::tests::test_cursor_mapping_blankline_insert_no_desync ... ok [INFO] [stdout] test core::app::tests::test_turn_off_character_mode_from_picker ... ok [INFO] [stdout] test core::app::tests::test_update_input_scroll_keeps_cursor_visible ... ok [INFO] [stdout] test core::app::ui_state::tests::block_select_mode_transitions_round_trip ... ok [INFO] [stdout] test core::app::tests::theme_picker_highlights_active_theme_over_default ... ok [INFO] [stdout] test core::app::ui_state::tests::exit_edit_select_mode_returns_to_typing ... ok [INFO] [stdout] test core::builtin_presets::tests::load_has_expected_builtins ... 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::enter_edit_select_mode_focuses_last_user_message ... ok [INFO] [stdout] test core::builtin_providers::tests::test_find_builtin_provider ... 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::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::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::chat_stream::tests::simple_sse_framer_flushes_end_of_stream ... 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::chat_stream::tests::simple_sse_framer_suppresses_repeated_invalid_utf8 ... ok [INFO] [stdout] test core::config::tests::test_case_insensitive_provider_normalization ... ok [INFO] [stdout] test core::config::tests::test_config_with_personas ... ok [INFO] [stdout] test core::config::tests::test_custom_provider_auth_modes ... ok [INFO] [stdout] test core::config::tests::test_change_default_provider ... ok [INFO] [stdout] test core::config::tests::test_custom_theme_save_load ... ok [INFO] [stdout] test core::config::tests::test_default_character_case_insensitive_provider ... ok [INFO] [stdout] test core::config::tests::test_custom_provider_management ... ok [INFO] [stdout] test core::config::tests::test_default_model_lookup_uses_provider_id ... ok [INFO] [stdout] test core::config::tests::test_empty_personas_array ... ok [INFO] [stdout] test core::app::tests::block_selection_offset_matches_renderer_with_tables ... ok [INFO] [stdout] test core::config::tests::test_overwrite_default_character ... ok [INFO] [stdout] test core::config::tests::test_multiple_provider_default_models ... ok [INFO] [stdout] test core::config::tests::test_load_nonexistent_config ... 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_optional_bio ... ok [INFO] [stdout] test core::config::tests::test_persona_serialization ... ok [INFO] [stdout] test core::config::tests::test_print_default_characters_empty ... ok [INFO] [stdout] test core::config::tests::test_print_default_characters_with_data ... ok [INFO] [stdout] test core::config::tests::test_save_and_load_default_characters ... ok [INFO] [stdout] test core::config::tests::test_set_and_get_default_character ... ok [INFO] [stdout] test core::config::tests::test_save_and_load_config ... ok [INFO] [stdout] test core::config::tests::test_overwrite_default_persona ... 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::persona::test_message_rendering_with_persona_display_name ... ok [INFO] [stdout] test core::persona::test_persona_display_name_in_codeblock_ranges_bugfix ... ok [INFO] [stdout] test core::persona::tests::test_default_persona_loading_from_config ... ok [INFO] [stdout] test core::config::tests::test_set_and_load_theme ... 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_no_persona ... ok [INFO] [stdout] test core::persona::tests::test_invalid_persona_id_error_handling ... ok [INFO] [stdout] test core::persona::tests::test_display_name_with_active_persona ... ok [INFO] [stdout] test core::config::tests::test_unset_default_provider ... ok [INFO] [stdout] test core::persona::tests::test_persona_activation_and_deactivation ... ok [INFO] [stdout] test core::persona::tests::test_substitution_logic_with_active_persona ... 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_system_prompt_modification_ignores_empty_or_whitespace_bio ... ok [INFO] [stdout] test core::persona::tests::test_substitution_logic_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_no_bio ... ok [INFO] [stdout] test core::persona::tests::test_system_prompt_modification_with_persona_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_cli_persona_command_updates_ui_and_status ... ok [INFO] [stdout] test core::persona::tests::test_ui_display_name_integration ... 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_config_persistence ... 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_interactive_persona_command_workflow ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_display_name_in_conversation ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_error_recovery ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_picker_turn_off_updates_ui_state ... 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::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::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::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::persona_integration_tests::integration_tests::test_persona_picker_with_active_persona ... ok [INFO] [stdout] test character::service::tests::resolves_updates_after_file_change ... 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 core::app::actions::picker::tests::model_selection_loads_default_character ... ok [INFO] [stdout] test core::app::picker::tests::test_turn_off_character_entry_added_when_character_active ... ok [INFO] [stdout] test core::app::picker::tests::test_turn_off_character_entry_not_added_when_no_character ... ok [INFO] [stdout] test core::text_wrapping::tests::test_basic_wrapping ... 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_preserve_multiple_spaces ... ok [INFO] [stdout] test core::text_wrapping::tests::test_extra_padding ... ok [INFO] [stdout] test core::text_wrapping::tests::test_wrap_with_double_width_emoji ... ok [INFO] [stdout] test core::app::picker::tests::test_turn_off_character_stays_at_top_after_sort ... ok [INFO] [stdout] test core::text_wrapping::tests::test_cursor_position_calculation ... ok [INFO] [stdout] test core::text_wrapping::tests::test_cursor_mapping_with_double_width_emoji ... ok [INFO] [stdout] test ui::builtin_themes::tests::find_builtin_theme_works_case_insensitive ... ok [INFO] [stdout] test core::text_wrapping::tests::test_long_word_breaking ... 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::retry_last_message_returns_none_without_history ... ok [INFO] [stdout] test ui::builtin_themes::tests::load_has_expected_builtins ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::submit_message_returns_spawn_command ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::end_messages_finalize_responses ... ok [INFO] [stdout] test ui::chat_loop::event_loop::tests::process_stream_updates_dispatches_actions ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::escape_handler_cancels_file_prompt_via_action ... 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::error_messages_add_system_entries_and_stop_streaming ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::f4_handler_toggles_compose_mode_via_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::setup_terminal_enables_raw_mode ... 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::language_extension_detection ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::escape_handler_cancels_streaming_via_action ... ok [INFO] [stdout] test cli::tests::test_cli_set_default_character_with_cached_service ... ok [INFO] [stdout] test ui::layout::tests::layout_lines_can_be_encoded_with_osc_links ... ok [INFO] [stdout] test ui::layout::tests::layout_codeblock_ranges_skip_app_messages ... ok [INFO] [stdout] test ui::layout::tests::link_metadata_spans_cover_spaces_within_link_text ... 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::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 commands::tests::commands_dispatch_case_insensitively ... ok [INFO] [stdout] test ui::markdown::tests::cell_wraps_after_hyphen ... ok [INFO] [stdout] test ui::markdown::tests::debug_table_events ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::ctrl_l_handler_emits_clear_status_action ... ok [INFO] [stdout] test ui::markdown::tests::codeblock_ranges_map_correctly ... ok [INFO] [stdout] test ui::markdown::tests::gfm_callout_blockquotes_render_content ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::enter_key_dispatches_process_command_action ... ok [INFO] [stdout] test ui::markdown::tests::markdown_details_metadata_matches_lines_and_tags ... ok [INFO] [stdout] test ui::markdown::tests::cell_wraps_at_space_across_spans ... ok [INFO] [stdout] test ui::markdown::tests::markdown_links_wrap_at_word_boundaries_with_width ... ok [INFO] [stdout] test ui::markdown::tests::markdown_links_wrap_in_long_paragraph_without_mid_word_break ... ok [INFO] [stdout] test commands::tests::syntax_command_updates_state_and_persists ... ok [INFO] [stdout] test commands::tests::markdown_command_rejects_invalid_argument ... ok [INFO] [stdout] test ui::markdown::tests::metadata_marks_user_prefix ... ok [INFO] [stdout] test commands::tests::markdown_command_updates_state_and_persists ... ok [INFO] [stdout] test core::providers::tests::permanent_keyring_failure_is_propagated ... ok [INFO] [stdout] test ui::markdown::tests::multi_item_ordered_list_keeps_code_block_with_correct_item ... 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 ui::markdown::tests::metadata_marks_table_links ... ok [INFO] [stdout] test ui::markdown::tests::shared_renderer_with_metadata_matches_details_wrapper ... ok [INFO] [stdout] test ui::markdown::tests::ordered_list_item_code_block_is_indented_under_marker ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::tab_completion_multiple_matches_extends_prefix_and_sets_status ... ok [INFO] [stdout] test ui::markdown::tests::metadata_marks_app_prefix ... ok [INFO] [stdout] test ui::markdown::tests::shared_renderer_without_metadata_matches_legacy_ranges ... ok [INFO] [stdout] test ui::markdown::tests::test_table_balancing_performance ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::tab_completion_single_match_completes_command ... ok [INFO] [stdout] test ui::markdown::tests::table_rendering_works ... ok [INFO] [stdout] test ui::markdown::tests::table_preserves_words_with_available_space ... ok [INFO] [stdout] test ui::markdown::tests::table_renders_emoji_and_br_correctly ... ok [INFO] [stdout] test ui::markdown::tests::test_table_balancing_with_terminal_width ... ok [INFO] [stdout] test ui::markdown::tests::test_styled_words_wrap_at_boundaries_in_table ... ok [INFO] [stdout] test ui::markdown::tests::test_logical_row_continuation ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::enter_key_completes_file_prompt_dump ... ok [INFO] [stdout] test ui::markdown::tests::test_extremely_narrow_terminal_no_truncation ... ok [INFO] [stdout] test ui::markdown::tests::superscript_and_subscript_render_without_markers ... ok [INFO] [stdout] test ui::markdown::tests::test_government_systems_table_from_testcase ... ok [INFO] [stdout] test ui::markdown::tests::test_table_column_width_balancing ... ok [INFO] [stdout] test ui::markdown::tests::test_table_cell_word_wrapping_regression ... ok [INFO] [stdout] test ui::markdown::tests::width_aware_ranges_align_with_render_wrapping ... ok [INFO] [stdout] test ui::markdown::tests::test_table_should_not_wrap_borders ... ok [INFO] [stdout] test ui::markdown::tests::test_table_no_content_truncation_wide_terminal ... 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_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::markdown::tests::width_aware_ranges_account_for_preceding_table ... ok [INFO] [stdout] test ui::markdown::tests::test_table_with_emoji_and_unicode_no_truncation ... ok [INFO] [stdout] test ui::osc::tests::encode_lines_with_links_wraps_each_link_segment ... ok [INFO] [stdout] test ui::markdown::tests::test_table_content_wrapping_medium_terminal ... ok [INFO] [stdout] test ui::osc::tests::control_detection_catches_bel_and_escape ... 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_hyperlink_wraps_text_with_balanced_sequences ... ok [INFO] [stdout] test ui::markdown::wrap::tests::wrap_preserves_skin_tone_modifiers ... ok [INFO] [stdout] test ui::osc_backend::tests::redraws_cell_when_hyperlink_changes_without_buffer_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::closes_stale_hyperlink_even_without_cell_diff ... 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_with_default_selected ... ok [INFO] [stdout] test ui::renderer::tests::title_places_preset_after_character_when_active ... 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_picker ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_no_picker ... ok [INFO] [stdout] test utils::auth::tests::test_anthropic_auth_headers ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_model_with_default_selected ... 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 ui::renderer::tests::test_generate_picker_help_text_character_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_model_with_filter ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_model_no_filter_no_default ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_model_when_not_in_transition ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_active_preset_when_set ... ok [INFO] [stdout] test utils::color::tests::detects_truecolor_from_env ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_basic ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_no_model_selected_during_transition ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_carriage_returns ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_tabs ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_filters_control_chars ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_mixed_control_chars ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_character_name_when_active ... ok [INFO] [stdout] test utils::color::tests::quantize_rgb_to_256_index ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_preserves_newlines ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_theme_picker ... ok [INFO] [stdout] test utils::scroll::tests::test_build_display_lines_up_to ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_word_wrapped_lines_exact_fit ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_max_scroll_offset ... ok [INFO] [stdout] test utils::color::tests::quantize_rgb_to_ansi16 ... ok [INFO] [stdout] test utils::scroll::tests::test_build_display_lines_basic ... ok [INFO] [stdout] test utils::scroll::tests::highlight_is_correct_after_table ... 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_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_wrapped_line_count_zero_width ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_scroll_to_message ... ok [INFO] [stdout] test utils::scroll::tests::test_markdown_link_wraps_on_spaces ... ok [INFO] [stdout] test utils::scroll::tests::test_empty_message_content ... ok [INFO] [stdout] test utils::scroll::tests::test_markdown_link_wraps_on_nbsp ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_wrapped_line_count_mixed_content ... 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_single_line ... 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_wraps_entire_link_word_when_width_exhausted ... ok [INFO] [stdout] test utils::scroll::tests::test_layout_engine_and_prewrap_preserve_link_words ... 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::scroll::tests::test_app_message_formatting ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_scroll_to_bottom_no_scroll_needed ... 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::table_scroll_height_matches_rendered ... ok [INFO] [stdout] test utils::color::tests::detects_256_from_term ... ok [INFO] [stdout] test utils::scroll::tests::highlight_is_correct_after_wrapped_paragraph ... ok [INFO] [stdout] test utils::scroll::tests::test_trimming_behavior ... ok [INFO] [stdout] test utils::syntax::tests::dark_background_heuristic_basic ... ok [INFO] [stdout] test utils::url::tests::test_normalize_base_url ... 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::normalize_lang_hint_maps_common_aliases ... ok [INFO] [stdout] test utils::scroll::tests::test_word_wrapping_with_long_paragraph ... ok [INFO] [stdout] test utils::url::tests::test_construct_api_url ... ok [INFO] [stdout] test utils::syntax::tests::theme_signature_changes_with_theme ... ok [INFO] [stdout] test utils::scroll::tests::perf_prewrap_short_history ... ok [INFO] [stdout] test core::config::tests::config_orchestrator_detects_external_updates ... ok [INFO] [stdout] test ui::renderer::tests::title_abbreviates_and_hides_fields_based_on_width ... ok [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/chabeau-342fa88b882e2013) [INFO] [stdout] test utils::scroll::tests::perf_prewrap_large_history ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 489 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 2.05s [INFO] [stdout] [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 2 tests [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] [INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.76s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "80cecfe5af3622044fdd30199e4459f52d27b79222e3a79f6bf88f56db341bf1", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "80cecfe5af3622044fdd30199e4459f52d27b79222e3a79f6bf88f56db341bf1", kill_on_drop: false }` [INFO] [stdout] 80cecfe5af3622044fdd30199e4459f52d27b79222e3a79f6bf88f56db341bf1