[INFO] fetching crate chabeau 0.7.3... [INFO] testing chabeau-0.7.3 against try#b8e88e5ddf5521a9f43ee3f62a702388c713e4bb for pr-155114 [INFO] extracting crate chabeau 0.7.3 into /workspace/builds/worker-7-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-7-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate chabeau 0.7.3 on toolchain b8e88e5ddf5521a9f43ee3f62a702388c713e4bb [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "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" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] f8b435ae60550e5ed4972671c3fd6a7547c92d33f6731d75f2543ce6b20afd2e [INFO] running `Command { std: "docker" "start" "-a" "f8b435ae60550e5ed4972671c3fd6a7547c92d33f6731d75f2543ce6b20afd2e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "f8b435ae60550e5ed4972671c3fd6a7547c92d33f6731d75f2543ce6b20afd2e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f8b435ae60550e5ed4972671c3fd6a7547c92d33f6731d75f2543ce6b20afd2e", kill_on_drop: false }` [INFO] [stdout] f8b435ae60550e5ed4972671c3fd6a7547c92d33f6731d75f2543ce6b20afd2e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 702fca1f4b97ca103c8ef2b23bc5e830d7499e8d45a98897a424c21f6f242e45 [INFO] running `Command { std: "docker" "start" "-a" "702fca1f4b97ca103c8ef2b23bc5e830d7499e8d45a98897a424c21f6f242e45", kill_on_drop: false }` [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling regex-syntax v0.8.9 [INFO] [stderr] Compiling syn v2.0.116 [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 deranged v0.5.6 [INFO] [stderr] Compiling anyhow v1.0.101 [INFO] [stderr] Compiling camino v1.2.2 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling vergen-lib v0.1.6 [INFO] [stderr] Compiling tracing-core v0.1.36 [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 signal-hook-registry v1.4.8 [INFO] [stderr] Compiling form_urlencoded v1.2.2 [INFO] [stderr] Compiling libdbus-sys v0.2.7 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Compiling rustls v0.23.36 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling num_threads v0.1.7 [INFO] [stderr] Compiling signal-hook v0.3.18 [INFO] [stderr] Compiling sysinfo v0.34.2 [INFO] [stderr] Compiling vergen-git2 v1.0.7 [INFO] [stderr] Compiling bitflags v2.11.0 [INFO] [stderr] Compiling linux-raw-sys v0.4.15 [INFO] [stderr] Compiling signal-hook-mio v0.2.5 [INFO] [stderr] Compiling itertools v0.13.0 [INFO] [stderr] Compiling getrandom v0.4.1 [INFO] [stderr] Compiling compact_str v0.8.1 [INFO] [stderr] Compiling quick-xml v0.38.4 [INFO] [stderr] Compiling winnow v0.7.14 [INFO] [stderr] Compiling dbus v0.9.10 [INFO] [stderr] Compiling pulldown-cmark v0.13.0 [INFO] [stderr] Compiling clap_lex v1.0.0 [INFO] [stderr] Compiling yaml-rust v0.4.5 [INFO] [stderr] Compiling clap_builder v4.5.59 [INFO] [stderr] Compiling time v0.3.47 [INFO] [stderr] Compiling crossterm v0.28.1 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling rustix v1.1.3 [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 regex-automata v0.4.14 [INFO] [stderr] Compiling onig_sys v69.9.1 [INFO] [stderr] Compiling unicode-truncate v1.1.0 [INFO] [stderr] Compiling semver v1.0.27 [INFO] [stderr] Compiling rustc_version v0.4.1 [INFO] [stderr] Compiling toml_parser v1.0.9+spec-1.1.0 [INFO] [stderr] Compiling walkdir v2.5.0 [INFO] [stderr] Compiling getopts v0.2.24 [INFO] [stderr] Compiling tracing-log v0.2.0 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling serde_spanned v1.0.4 [INFO] [stderr] Compiling toml_datetime v0.7.5+spec-1.1.0 [INFO] [stderr] Compiling toml_writer v1.0.6+spec-1.1.0 [INFO] [stderr] Compiling unicase v2.9.0 [INFO] [stderr] Compiling tempfile v3.25.0 [INFO] [stderr] Compiling directories v6.0.0 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling toml v0.9.12+spec-1.1.0 [INFO] [stderr] Compiling regex v1.12.3 [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 strum_macros v0.26.4 [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling zeroize v1.8.2 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling rustls-pki-types v1.14.0 [INFO] [stderr] Compiling dbus-secret-service v4.1.0 [INFO] [stderr] Compiling onig v6.5.1 [INFO] [stderr] Compiling darling_macro v0.20.11 [INFO] [stderr] Compiling clap_derive v4.5.55 [INFO] [stderr] Compiling webpki-roots v1.0.6 [INFO] [stderr] Compiling keyring v3.6.3 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling thiserror v2.0.18 [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 rustls-webpki v0.103.9 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling darling_macro v0.23.0 [INFO] [stderr] Compiling strum v0.26.3 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling darling v0.23.0 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling instability v0.3.11 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling derive_builder_macro v0.20.2 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling derive_builder v0.20.2 [INFO] [stderr] Compiling clap v4.5.59 [INFO] [stderr] Compiling ratatui v0.29.0 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling cargo-platform v0.1.9 [INFO] [stderr] Compiling bincode v1.3.3 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling cargo_metadata v0.19.2 [INFO] [stderr] Compiling plist v1.8.0 [INFO] [stderr] Compiling chrono v0.4.43 [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 hyper v1.8.1 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tui-textarea v0.7.0 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [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 git2 v0.20.4 [INFO] [stderr] Compiling chabeau v0.7.3 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 50.95s [INFO] running `Command { std: "docker" "inspect" "702fca1f4b97ca103c8ef2b23bc5e830d7499e8d45a98897a424c21f6f242e45", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "702fca1f4b97ca103c8ef2b23bc5e830d7499e8d45a98897a424c21f6f242e45", kill_on_drop: false }` [INFO] [stdout] 702fca1f4b97ca103c8ef2b23bc5e830d7499e8d45a98897a424c21f6f242e45 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 69cd8cfcd6fca9645821f75b95acf54663354745ba8d78cb2118a4c1147e4095 [INFO] running `Command { std: "docker" "start" "-a" "69cd8cfcd6fca9645821f75b95acf54663354745ba8d78cb2118a4c1147e4095", kill_on_drop: false }` [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling zerocopy v0.8.39 [INFO] [stderr] Compiling zerocopy-derive v0.8.39 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling ciborium-io v0.2.2 [INFO] [stderr] Compiling plotters-backend v0.3.7 [INFO] [stderr] Compiling cast v0.3.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 serde_urlencoded v0.7.1 [INFO] [stderr] Compiling bincode v1.3.3 [INFO] [stderr] Compiling plist v1.8.0 [INFO] [stderr] Compiling tinytemplate v1.2.1 [INFO] [stderr] Compiling rust-mcp-schema v0.9.5 [INFO] [stderr] Compiling cargo-platform v0.1.9 [INFO] [stderr] Compiling cargo_metadata v0.19.2 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling plotters v0.3.7 [INFO] [stderr] Compiling chrono v0.4.43 [INFO] [stderr] Compiling syntect v5.3.0 [INFO] [stderr] Compiling vergen v9.0.6 [INFO] [stderr] Compiling vergen-git2 v1.0.7 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling chabeau v0.7.3 (/opt/rustwide/workdir) [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [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 29.78s [INFO] running `Command { std: "docker" "inspect" "69cd8cfcd6fca9645821f75b95acf54663354745ba8d78cb2118a4c1147e4095", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "69cd8cfcd6fca9645821f75b95acf54663354745ba8d78cb2118a4c1147e4095", kill_on_drop: false }` [INFO] [stdout] 69cd8cfcd6fca9645821f75b95acf54663354745ba8d78cb2118a4c1147e4095 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 678167ca65171750741282ac9c85cf7b15ded8cd143877e2cf45dc83dcb2675a [INFO] running `Command { std: "docker" "start" "-a" "678167ca65171750741282ac9c85cf7b15ded8cd143877e2cf45dc83dcb2675a", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.36s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/chabeau-faba9ffa15b1d0bc) [INFO] [stdout] [INFO] [stdout] running 723 tests [INFO] [stdout] test auth::tests::collect_configured_providers_skips_duplicate_custom_entries ... ok [INFO] [stdout] test auth::ui::tests::provider_selection_handles_custom_option ... ok [INFO] [stdout] test auth::ui::tests::provider_selection_handles_cancel_option ... ok [INFO] [stdout] test auth::ui::tests::confirmation_parsing_handles_empty_and_cancel ... ok [INFO] [stdout] test auth::ui::tests::resolve_provider_id_detects_duplicates ... ok [INFO] [stdout] test auth::ui::tests::provider_selection_rejects_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 character::cache::tests::test_cache_reuses_data_on_second_call ... ok [INFO] [stdout] test character::card::tests::test_character_card_structure ... ok [INFO] [stdout] test character::cache::tests::test_metadata_sorted_by_name ... ok [INFO] [stdout] test character::card::tests::test_greeting_with_substitutions ... ok [INFO] [stdout] test character::cache::tests::test_compute_cache_key_empty_directory ... ok [INFO] [stdout] test character::card::tests::test_optional_fields ... ok [INFO] [stdout] test character::cache::tests::test_new_cache_is_empty ... ok [INFO] [stdout] test character::cache::tests::test_default_creates_empty_cache ... ok [INFO] [stdout] test character::card::tests::test_optional_fields_not_serialized_when_none ... ok [INFO] [stdout] test character::card::tests::test_serialization_deserialization ... ok [INFO] [stdout] test character::card::tests::test_post_history_instructions_with_substitutions ... ok [INFO] [stdout] test character::card::tests::test_system_prompt_with_substitutions ... ok [INFO] [stdout] test character::import::tests::test_import_error_display ... ok [INFO] [stdout] test auth::tests::env_fallback_sets_openai_compatible_for_custom_base ... ok [INFO] [stdout] test character::import::tests::test_import_card_missing_file ... ok [INFO] [stdout] test auth::tests::env_fallback_sets_openai_provider_for_default_base ... ok [INFO] [stdout] test character::import::tests::test_import_valid_card ... 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::import::tests::test_import_invalid_card ... ok [INFO] [stdout] test character::loader::tests::test_card_discovery_prefers_json_over_png ... ok [INFO] [stdout] test character::import::tests::test_import_card_creates_directory ... ok [INFO] [stdout] test character::loader::tests::test_card_discovery_with_temp_directory ... ok [INFO] [stdout] test character::loader::tests::test_load_card_invalid_extension ... ok [INFO] [stdout] test character::import::tests::test_import_with_force_flag ... ok [INFO] [stdout] test character::import::tests::test_import_card_success_message_format ... ok [INFO] [stdout] test character::loader::tests::test_get_cards_dir ... ok [INFO] [stdout] test character::loader::tests::test_list_cards_ignores_subdirectories ... ok [INFO] [stdout] test character::loader::tests::test_load_hypatia_json ... ok [INFO] [stdout] test character::import::tests::test_import_and_verify_in_temp_dir ... ok [INFO] [stdout] test character::import::tests::test_import_card_wrong_extension ... ok [INFO] [stdout] test character::loader::tests::test_load_card_json ... 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::import::tests::test_import_card_validation_before_copy ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_invalid_json ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_file_not_found ... ok [INFO] [stdout] test character::loader::tests::test_load_card_png ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_file_not_found ... ok [INFO] [stdout] test character::loader::tests::test_load_hypatia_png ... ok [INFO] [stdout] test character::loader::tests::test_load_invalid_test_card ... ok [INFO] [stdout] test character::loader::tests::test_load_spec_v2_png_cards ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_invalid_json ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_not_a_png ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_with_metadata ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_empty_fields_allowed ... ok [INFO] [stdout] test character::loader::tests::test_list_available_cards_with_test_cards ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_empty_name ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_with_optional_fields ... ok [INFO] [stdout] test character::loader::tests::test_png_and_json_equivalence ... ok [INFO] [stdout] test character::loader::tests::test_load_valid_json_card ... ok [INFO] [stdout] test character::loader::tests::test_load_png_card_invalid_base64 ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_invalid_spec ... ok [INFO] [stdout] test character::import::tests::test_import_overwrite_protection ... ok [INFO] [stdout] test character::loader::tests::test_load_json_card_missing_required_field ... 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::loader::tests::test_load_png_card_without_metadata ... ok [INFO] [stdout] test character::import::tests::test_import_card_preserves_filename ... ok [INFO] [stdout] test auth::tests::resolve_deauth_target_normalizes_custom_provider ... ok [INFO] [stdout] test character::loader::tests::test_load_simple_test_card ... ok [INFO] [stdout] test auth::tests::resolve_deauth_target_normalizes_builtin_provider ... ok [INFO] [stdout] test character::loader::tests::test_validate_card_multiple_errors ... ok [INFO] [stdout] test character::png_text::tests::rejects_invalid_signature ... ok [INFO] [stdout] test character::png_text::tests::rejects_invalid_crc ... ok [INFO] [stdout] test character::png_text::tests::reports_missing_keyword ... 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_error_case_invalid_card_format ... 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_character_precedence_cli_over_default ... ok [INFO] [stdout] test cli::say::tests::plain_stream_state_inserts_newline_for_redirected_streams ... 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_config_persistence_with_multiple_defaults ... ok [INFO] [stdout] test cli::say::tests::plain_stream_state_writes_errors_on_new_lines ... ok [INFO] [stdout] test cli::say::tests::resolve_prompt_prefers_cli_args ... ok [INFO] [stdout] test cli::say::tests::resolve_prompt_handles_empty_sources ... ok [INFO] [stdout] test cli::say::tests::resolve_prompt_reads_from_piped_stdin ... 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::tests::test_character_flag_with_other_flags ... ok [INFO] [stdout] test cli::tests::test_mcp_edit_advanced_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_edit_command_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_add_advanced_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_oauth_add_command_parsing ... ok [INFO] [stdout] test cli::tests::test_disable_mcp_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_oauth_add_advanced_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_oauth_list_command_parsing ... ok [INFO] [stdout] test cli::tests::test_character_flag_parsing ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_character_with_empty_optional_fields ... 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_persona_validation_with_valid_config ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_character_switching_during_session ... ok [INFO] [stdout] test cli::tests::test_mcp_token_add_command_parsing ... ok [INFO] [stdout] test cli::tests::test_mcp_token_list_command_parsing ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_full_conversation_flow_with_character ... ok [INFO] [stdout] test commands::tests::character_command_registered_in_help ... ok [INFO] [stdout] test commands::mcp_prompt_parser::tests::table_driven_prompt_parsing ... ok [INFO] [stdout] test cli::tests::test_persona_flag_with_other_flags ... 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 cli::tests::test_preset_flag_parsing ... ok [INFO] [stdout] test cli::tests::test_provider_token_list_command_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 cli::tests::test_provider_add_command_parsing ... ok [INFO] [stdout] test commands::tests::character_command_opens_picker ... ok [INFO] [stdout] test commands::tests::character_command_with_invalid_name_shows_error ... ok [INFO] [stdout] test commands::tests::clear_command_shows_character_greeting_when_available ... ok [INFO] [stdout] test commands::tests::clear_command_resets_transcript_state ... ok [INFO] [stdout] test commands::tests::help_command_includes_registry_metadata ... ok [INFO] [stdout] test commands::tests::dump_conversation_uses_persona_display_name ... ok [INFO] [stdout] test commands::tests::mcp_command_highlights_disabled_servers ... 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_includes_allowed_tools ... ok [INFO] [stdout] test commands::tests::mcp_command_lists_empty_config ... ok [INFO] [stdout] test commands::tests::mcp_command_skips_refresh_for_disabled_server ... ok [INFO] [stdout] test commands::tests::model_command_returns_open_picker_result ... ok [INFO] [stdout] test commands::tests::mcp_command_toggle_off_clears_runtime_state ... 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::parse_prompt_args_single_argument_accepts_unquoted_spaces ... 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::registry_lists_commands ... ok [INFO] [stdout] test commands::tests::provider_command_with_same_id_reuses_session ... ok [INFO] [stdout] test commands::tests::picker_supports_home_end_navigation_and_metadata ... 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::validate_prompt_args_rejects_unknown_keys ... 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_dump_success_sets_status_and_closes_prompt ... 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::help_command_focuses_transcript ... ok [INFO] [stdout] test core::app::actions::input::command::tests::mcp_command_focuses_transcript ... ok [INFO] [stdout] test core::app::actions::input::command::tests::process_command_opens_theme_picker ... ok [INFO] [stdout] test core::app::actions::input::command::tests::process_command_submits_message ... 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::inspect_tool_calls_prefers_pending_prompt ... 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::nested_json_detection_matches_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::input::inspect::tests::tool_call_inspect_copy_data_uses_response_payload ... 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::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 character::tests_integration::integration_tests::test_import_set_default_start_session_workflow ... ok [INFO] [stdout] test character::tests_integration::integration_tests::test_import_overwrite_protection ... ok [INFO] [stdout] test character::service::tests::resolves_updates_after_file_change ... ok [INFO] [stdout] test core::app::actions::picker::tests::test_load_default_persona_if_configured ... ok [INFO] [stdout] test core::app::actions::picker::tests::test_load_default_preset_if_configured ... ok [INFO] [stdout] test core::app::actions::picker::tests::test_load_default_persona_respects_existing_active_persona ... ok [INFO] [stdout] test core::app::actions::picker::tests::test_load_default_preset_respects_existing_active_preset ... ok [INFO] [stdout] test core::app::actions::picker::tests::model_selection_loads_default_character ... ok [INFO] [stdout] test cli::tests::test_cli_set_default_character_with_cached_service ... 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::sampling::tests::sampling_finished_clears_active_request ... 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_app_message_adds_trimmed_content_and_keeps_stream_alive ... ok [INFO] [stdout] test core::app::actions::streaming::stream_lifecycle::tests::finalize_stream_clears_interrupt_token_when_done ... ok [INFO] [stdout] test core::app::actions::picker::tests::theme_picker_escape_reverts_preview ... ok [INFO] [stdout] test cli::tests::test_cli_set_default_model_with_mixed_case_provider ... 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::streaming::stream_lifecycle::tests::stream_tool_call_delta_flushes_on_complete ... ok [INFO] [stdout] test core::app::actions::streaming::tool_calls::tests::tool_call_completed_flags_tool_error_payloads ... 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 cli::tests::test_resolve_provider_id_builtin_and_custom ... ok [INFO] [stdout] test core::app::conversation::tests::add_user_message_omits_trailing_empty_assistant_turns ... ok [INFO] [stdout] test core::app::conversation::tests::test_add_user_message_with_character_active ... ok [INFO] [stdout] test core::app::conversation::tests::test_add_user_message_without_character ... 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_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_character_greeting_with_persona_substitutions ... ok [INFO] [stdout] test core::app::conversation::tests::test_character_messages_with_transcript_system_messages ... ok [INFO] [stdout] test core::app::conversation::tests::log_rewrite_excludes_app_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_with_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_retry_character_greeting_reinserts_locally ... ok [INFO] [stdout] test core::app::conversation::tests::test_prepare_retry_with_character_active ... 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_prepare_retry_without_character ... ok [INFO] [stdout] test core::app::conversation::tests::test_show_character_greeting_empty_greeting ... 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_retry_character_greeting_updates_after_persona_change ... 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_picker_data_variant_footprint_is_normalized ... 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_sanitize_picker_metadata_collapses_whitespace ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_handles_empty_string ... ok [INFO] [stdout] test core::app::picker::tests::test_sanitize_picker_metadata_handles_mixed_whitespace ... ok [INFO] [stdout] test core::app::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_character_picker_highlights_active_character ... 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_removes_newlines ... ok [INFO] [stdout] test cli::tests::test_resolve_theme_id_builtin_and_custom ... ok [INFO] [stdout] test core::app::picker::tests::test_persona_picker_sanitizes_bio_metadata ... ok [INFO] [stdout] test core::app::picker::tests::test_persona_picker_highlights_active_persona ... ok [INFO] [stdout] test core::app::picker::tests::test_persona_picker_metadata_defaults_to_no_bio_when_empty ... ok [INFO] [stdout] test core::app::picker::tests::test_preset_picker_highlights_active_preset ... 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_no_character ... ok [INFO] [stdout] test core::app::session::tests::load_character_for_session_cards_dir_priority ... 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_reset_restores_default ... 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::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::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::session::tests::session_context_greeting_lifecycle ... ok [INFO] [stdout] test core::app::session::tests::session_context_reselecting_same_character_preserves_greeting_flag ... 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_selecting_different_character_resets_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_not_show_empty_greeting ... ok [INFO] [stdout] test core::app::session::tests::session_context_should_show_greeting ... ok [INFO] [stdout] test core::app::session::tests::theme_from_appearance_matches_light_theme ... 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::session::tests::theme_from_appearance_matches_dark_theme ... 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::tool_pipeline_reset_clears_active_and_queues ... ok [INFO] [stdout] test core::app::session::tests::resolve_theme_prefers_configured_theme ... ok [INFO] [stdout] test commands::tests::commands_dispatch_case_insensitively ... ok [INFO] [stdout] test core::app::settings::tests::apply_model_clears_transition_state ... ok [INFO] [stdout] test commands::tests::markdown_command_rejects_invalid_argument ... 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::settings::tests::apply_theme_session_only_updates_ui ... ok [INFO] [stdout] test core::app::tests::build_stream_params_includes_mcp_resources ... ok [INFO] [stdout] test core::app::tests::build_stream_params_includes_mcp_tools ... ok [INFO] [stdout] test core::app::tests::build_stream_params_includes_tool_history_and_payloads ... ok [INFO] [stdout] test core::app::tests::calculate_available_height_matches_expected_layout_rules ... ok [INFO] [stdout] test commands::tests::markdown_command_updates_state_and_persists ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_completes_mcp_server ... ok [INFO] [stdout] test core::app::tests::clear_transcript_resets_transcript_state ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_completes_yolo_server ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_lists_mcp_servers ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_fills_unique_match ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_lists_multiple_matches ... ok [INFO] [stdout] test core::app::tests::complete_slash_command_reports_unknown_prefix ... ok [INFO] [stdout] test core::app::tests::model_picker_title_uses_az_when_no_dates ... ok [INFO] [stdout] test core::app::tests::parse_resource_list_kind_accepts_templates ... ok [INFO] [stdout] test core::app::tests::parse_resource_list_kind_defaults_to_resources_and_passes_cursor ... ok [INFO] [stdout] test core::app::tests::default_sort_mode_helper_behaviour ... ok [INFO] [stdout] test core::app::tests::parse_resource_list_kind_rejects_empty_cursor ... ok [INFO] [stdout] test commands::tests::mcp_command_forget_clears_permissions_and_history ... ok [INFO] [stdout] test core::app::tests::page_cursor_movement_skips_multiple_wrapped_lines ... 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::paste_inserts_cursor_at_end_of_insert ... ok [INFO] [stdout] test core::app::tests::prewrap_cache_updates_metadata_for_plain_text_last_message ... ok [INFO] [stdout] test core::app::tests::provider_model_cancel_reverts_base_url_and_state ... 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 commands::tests::mcp_command_toggle_enabled_persists ... ok [INFO] [stdout] test core::app::tests::test_backspace_at_line_start_joins_lines ... ok [INFO] [stdout] test core::app::tests::test_backspace_at_start_noop ... ok [INFO] [stdout] test core::app::tests::test_backspace_with_alt_modifier_deletes_single_char ... ok [INFO] [stdout] test core::app::tests::streaming_table_with_cache_invalidation_consistency ... ok [INFO] [stdout] test core::app::tests::test_cursor_mapping_blankline_insert_no_desync ... ok [INFO] [stdout] test core::app::tests::test_last_and_first_user_message_index ... ok [INFO] [stdout] test core::app::tests::test_prev_next_user_message_index_navigation ... ok [INFO] [stdout] test core::app::tests::test_page_up_down_and_home_end_behavior ... ok [INFO] [stdout] test core::app::tests::test_recompute_input_layout_after_edit_updates_scroll ... ok [INFO] [stdout] test core::app::tests::test_prewrap_cache_reuse_when_unchanged ... ok [INFO] [stdout] test commands::tests::mcp_command_toggle_on_triggers_refresh ... ok [INFO] [stdout] test core::app::tests::test_set_input_text_places_cursor_at_end ... ok [INFO] [stdout] test core::app::tests::test_scroll_height_consistency_narrow_terminal_regression ... ok [INFO] [stdout] test core::app::tests::test_scroll_height_consistency_with_tables_regression ... ok [INFO] [stdout] test core::app::tests::test_shift_like_left_right_moves_one_char ... ok [INFO] [stdout] test core::app::tests::test_sync_cursor_mapping_single_and_multi_line ... 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_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::tests::test_wrapped_vertical_navigation_clamps_to_shorter_line ... ok [INFO] [stdout] test core::app::tests::test_wrapped_vertical_navigation_handles_multiple_paragraphs ... ok [INFO] [stdout] test core::app::tests::test_wrapped_vertical_navigation_keeps_column_zero_on_descend ... ok [INFO] [stdout] test core::app::tests::test_wrapped_vertical_navigation_preserves_visual_column ... ok [INFO] [stdout] test commands::tests::syntax_command_updates_state_and_persists ... ok [INFO] [stdout] test core::app::tests::visual_line_controls_handle_blank_lines ... ok [INFO] [stdout] test core::app::tests::visual_line_start_end_track_wrapped_columns ... ok [INFO] [stdout] test core::app::tests::wrapped_cursor_crosses_paragraph_boundaries ... ok [INFO] [stdout] test core::app::tests::wrapped_cursor_moves_through_blank_lines ... ok [INFO] [stdout] test core::app::tests::theme_picker_highlights_active_theme_over_default ... 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::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::app::ui_state::tests::block_select_mode_transitions_round_trip ... 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_providers::tests::test_anthropic_mode ... ok [INFO] [stdout] test core::app::ui_state::tests::default_focus_is_transcript ... ok [INFO] [stdout] test core::builtin_providers::tests::test_builtin_providers_cached_slice ... ok [INFO] [stdout] test core::builtin_providers::tests::test_find_builtin_provider ... ok [INFO] [stdout] test core::builtin_providers::tests::test_load_builtin_providers ... ok [INFO] [stdout] test core::builtin_presets::tests::load_has_expected_builtins ... 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::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::simple_sse_framer_flushes_end_of_stream ... ok [INFO] [stdout] test core::chat_stream::tests::process_sse_line_routes_stream_errors ... ok [INFO] [stdout] test core::chat_stream::tests::simple_sse_framer_handles_crlf_and_blank_lines ... ok [INFO] [stdout] test core::chat_stream::tests::simple_sse_framer_reports_invalid_utf8 ... ok [INFO] [stdout] test core::chat_stream::tests::simple_sse_framer_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::config::tests::test_custom_provider_auth_modes ... ok [INFO] [stdout] test core::app::ui_state::tests::focus_transitions_round_trip ... ok [INFO] [stdout] test core::app::ui_state::tests::exit_edit_select_mode_returns_to_typing ... 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_custom_theme_save_load ... ok [INFO] [stdout] test core::config::tests::test_config_with_personas ... 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 commands::tests::yolo_command_shows_and_persists ... ok [INFO] [stdout] test core::config::tests::test_empty_personas_array ... 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_load_nonexistent_config ... ok [INFO] [stdout] test core::config::tests::test_path_display_with_config_dir ... ok [INFO] [stdout] test core::config::tests::test_persona_optional_bio ... ok [INFO] [stdout] test core::config::tests::test_persona_serialization ... ok [INFO] [stdout] test core::config::tests::test_set_and_get_default_character ... ok [INFO] [stdout] test core::config::tests::test_set_and_get_default_persona ... ok [INFO] [stdout] test core::config::tests::test_set_multiple_default_characters ... ok [INFO] [stdout] test core::config::tests::test_suggest_provider_id ... ok [INFO] [stdout] test core::config::tests::test_unset_default_character ... ok [INFO] [stdout] test core::config::tests::test_unset_default_persona ... ok [INFO] [stdout] test core::config::tests::test_unset_default_persona_cleans_up_empty_provider ... ok [INFO] [stdout] test core::config::tests::test_unset_last_character_cleans_up_provider ... ok [INFO] [stdout] test core::mcp_sampling::tests::build_sampling_messages_includes_system_prompt ... ok [INFO] [stdout] test core::mcp_sampling::tests::build_sampling_messages_rejects_image_content ... ok [INFO] [stdout] test core::mcp_sampling::tests::sampling_timeout_accepts_timeout_seconds ... ok [INFO] [stdout] test core::mcp_sampling::tests::sampling_timeout_ignores_invalid_values ... ok [INFO] [stdout] test core::mcp_sampling::tests::sampling_timeout_prefers_timeout_ms ... ok [INFO] [stdout] test core::message::tests::invalid_role_strings_are_rejected ... ok [INFO] [stdout] test core::message::tests::tool_messages_set_roles ... ok [INFO] [stdout] test core::message::tests::tool_roles_are_not_app_roles ... ok [INFO] [stdout] test core::config::tests::test_mcp_server_config_persistence ... ok [INFO] [stdout] test core::oauth::tests::test_apply_oauth_token_response_preserves_existing_refresh_token ... ok [INFO] [stdout] test core::oauth::tests::test_build_authorization_url_includes_required_params ... ok [INFO] [stdout] test core::config::tests::test_config_persistence_lifecycle ... ok [INFO] [stdout] test core::oauth::tests::test_build_authorization_url_includes_scope ... ok [INFO] [stdout] test core::config::tests::test_provider_id_normalization ... ok [INFO] [stdout] test core::config::tests::test_mcp_server_stdio_config_persistence ... ok [INFO] [stdout] test core::config::tests::test_save_and_load_default_characters ... ok [INFO] [stdout] test core::oauth::tests::test_oauth_grant_needs_refresh_with_safety_window ... ok [INFO] [stdout] test core::oauth::tests::test_pkce_s256_matches_rfc_example ... ok [INFO] [stdout] test core::oauth::tests::test_random_urlsafe_is_urlsafe ... ok [INFO] [stdout] test core::oauth::tests::test_build_authorization_url_omits_empty_client_id ... ok [INFO] [stdout] test core::oauth::tests::test_refresh_token_response_deserializes_expected_fields ... ok [INFO] [stdout] test core::persona::tests::test_default_persona_loading_from_config ... ok [INFO] [stdout] test core::persona::tests::test_default_persona_lookup_case_and_underscores ... ok [INFO] [stdout] test core::persona::tests::test_display_name_with_active_persona ... ok [INFO] [stdout] test core::persona::tests::test_display_name_with_no_persona ... ok [INFO] [stdout] test core::persona::tests::test_invalid_persona_id_error_handling ... ok [INFO] [stdout] test core::persona::tests::test_persona_activation_and_deactivation ... ok [INFO] [stdout] test core::persona::tests::test_persona_loading_from_configuration ... ok [INFO] [stdout] test core::persona::tests::test_substitution_logic_with_active_persona ... ok [INFO] [stdout] test core::persona::tests::test_substitution_logic_with_no_persona ... ok [INFO] [stdout] test core::persona::tests::test_persona_bio_substitution ... ok [INFO] [stdout] test core::persona::tests::test_system_prompt_modification_ignores_empty_or_whitespace_bio ... ok [INFO] [stdout] test core::persona::tests::test_system_prompt_modification_no_persona ... ok [INFO] [stdout] test core::persona::tests::test_system_prompt_modification_with_persona_bio ... ok [INFO] [stdout] test core::persona::tests::test_system_prompt_modification_with_persona_no_bio ... ok [INFO] [stdout] test core::app::tests::test_prewrap_cache_invalidates_on_width_change ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_cli_persona_overrides_default ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_default_persona_loading_from_config ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_config_persistence ... ok [INFO] [stdout] test core::persona::test_message_rendering_with_persona_display_name ... ok [INFO] [stdout] test core::persona::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_interactive_persona_command_workflow ... 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_end_to_end_persona_workflow ... 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_command_variations ... ok [INFO] [stdout] test core::preset::tests::test_builtin_presets_can_be_disabled ... 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_enabled_by_default ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_error_recovery ... ok [INFO] [stdout] test core::preset::tests::test_get_default_for_provider_model ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_display_name_in_conversation ... 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::text_wrapping::tests::cursor_layout_reports_line_count_and_line_search ... ok [INFO] [stdout] test core::preset::tests::test_user_presets_override_builtins ... ok [INFO] [stdout] test core::providers::tests::permanent_keyring_failure_is_propagated ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_picker_turn_off_updates_ui_state ... ok [INFO] [stdout] test core::text_wrapping::tests::cursor_layout_tracks_consecutive_blank_lines ... ok [INFO] [stdout] test core::text_wrapping::tests::multiple_spaces_preserved_across_wrap ... ok [INFO] [stdout] test core::text_wrapping::tests::elided_space_maps_cursor_to_next_line_start ... ok [INFO] [stdout] test core::text_wrapping::tests::single_space_elided_when_wrap_occurs ... ok [INFO] [stdout] test core::text_wrapping::tests::position_map_lines_are_monotonic ... ok [INFO] [stdout] test core::persona_integration_tests::integration_tests::test_persona_picker_with_active_persona ... 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_basic_wrapping ... ok [INFO] [stdout] test core::text_wrapping::tests::test_cursor_position_map_soft_wrap_column_zero ... 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_preserve_multiple_spaces ... ok [INFO] [stdout] test core::text_wrapping::tests::test_wrap_with_double_width_emoji ... ok [INFO] [stdout] test mcp::client::protocol::tests::effective_protocol_prefers_negotiated ... ok [INFO] [stdout] test core::text_wrapping::tests::test_long_word_breaking ... ok [INFO] [stdout] test mcp::client::tests::effective_protocol_version_prefers_negotiated_value ... ok [INFO] [stdout] test mcp::client::tests::server_capability_defaults_to_supported ... ok [INFO] [stdout] test mcp::client::protocol::tests::parse_initialize_rejects_blank_protocol_version ... ok [INFO] [stdout] test mcp::client::tests::paginate_tools_list_caps_and_preserves_cursor ... 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_flags_disable_missing_lists ... ok [INFO] [stdout] test mcp::client::tests::server_capability_flags_enable_present_lists ... ok [INFO] [stdout] test mcp::client::tests::streamable_http_client_post_headers_include_json_and_sse_accept ... ok [INFO] [stdout] test mcp::client::tests::streamable_http_protocol_version_header_is_applied_when_present ... ok [INFO] [stdout] test mcp::client::tests::connect_all_attempts_each_enabled_server_when_one_fails ... ok [INFO] [stdout] test mcp::permissions::tests::allow_once_is_consumed_after_query ... ok [INFO] [stdout] test mcp::permissions::tests::allow_session_is_retained ... ok [INFO] [stdout] test mcp::client::transport_stdio::tests::stdio_requires_connected_client ... ok [INFO] [stdout] test mcp::permissions::tests::clear_server_removes_decisions ... ok [INFO] [stdout] test mcp::permissions::tests::block_is_retained ... ok [INFO] [stdout] test mcp::permissions::tests::deny_once_is_not_recorded ... ok [INFO] [stdout] test mcp::transport::streamable_http::tests::detects_event_stream_content_type ... ok [INFO] [stdout] test mcp::transport::streamable_http::tests::extracts_sse_payload ... ok [INFO] [stdout] test mcp::transport::streamable_http::tests::sse_buffer_handles_partial_lines ... ok [INFO] [stdout] test core::app::session::tests::prepare_with_auth_uses_pre_resolved_session ... ok [INFO] [stdout] test mcp::client::tests::streamable_http_end_to_end_handles_json_and_sse_responses ... ok [INFO] [stdout] test mcp::client::transport_http::tests::ensure_session_requires_http_client ... ok [INFO] [stdout] test ui::builtin_themes::tests::find_builtin_theme_works_case_insensitive ... ok [INFO] [stdout] test ui::builtin_themes::tests::load_has_expected_builtins ... ok [INFO] [stdout] test core::app::session::tests::prepare_with_auth_uses_env_session_when_env_only ... 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::sanitize_paste_text_removes_control_characters ... ok [INFO] [stdout] test core::app::picker::tests::test_turn_off_character_entry_not_added_when_no_character ... ok [INFO] [stdout] test core::providers::tests::provider_override_falls_back_to_env_on_keyring_failure ... ok [INFO] [stdout] test core::app::picker::tests::test_turn_off_character_stays_at_top_after_sort ... ok [INFO] [stdout] test core::providers::tests::recoverable_keyring_failure_uses_env_credentials ... ok [INFO] [stdout] test core::app::picker::tests::test_turn_off_character_entry_added_when_character_active ... 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::process_stream_updates_dispatches_actions ... 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::executors::mcp_tools::tests::run_cancellable_returns_cancelled_error ... ok [INFO] [stdout] test ui::chat_loop::event_loop::event_loop_tests::tab_autocompletes_slash_commands ... 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::tab_does_not_switch_focus_in_assistant_edit_select_mode ... 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::tab_toggles_focus_without_slash_prefix ... 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_block_select_mode ... 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 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::handle_paste_event_dispatches_insert_action ... 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::keybindings::handlers::tests::arrow_key_handler_moves_cursor_when_input_focused ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::wrap_next_index_wraps_to_start ... ok [INFO] [stdout] test ui::chat_loop::lifecycle::tests::apply_cursor_color_writes_sequence ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::wrap_previous_index_wraps_to_end ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::arrow_key_handler_scrolls_when_transcript_focused ... ok [INFO] [stdout] test ui::chat_loop::lifecycle::tests::apply_cursor_reset_writes_sequence ... ok [INFO] [stdout] test ui::chat_loop::lifecycle::tests::cursor_color_payload_is_hex ... ok [INFO] [stdout] test 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::metadata_contains_code_blocks_after_cache ... ok [INFO] [stdout] test ui::chat_loop::lifecycle::tests::queues_cursor_color_sequence ... ok [INFO] [stdout] test ui::chat_loop::lifecycle::tests::setup_terminal_enables_raw_mode ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::ctrl_l_handler_emits_clear_status_action ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::ctrl_n_handler_dispatches_refine_action ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::escape_handler_cancels_streaming_via_action ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::language_extension_detection ... 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::keybindings::handlers::tests::ctrl_n_handler_sets_status_when_cannot_retry ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::escape_handler_cancels_file_prompt_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::test_exact_user_scenario_two_assistant_code_blocks ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_block_navigation_cycles_through_multiple_blocks ... ok [INFO] [stdout] test ui::chat_loop::keybindings::handlers::tests::escape_handler_cancels_interruptible_mcp_activity ... 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::f4_handler_toggles_compose_mode_via_action ... 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_allows_mixed_text_and_emoji ... ok [INFO] [stdout] test ui::markdown::table::tests::clip_text_to_width_keeps_entire_graphemes ... ok [INFO] [stdout] test ui::layout::tests::link_metadata_spans_cover_spaces_within_link_text ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_incremental_cache_update_preserves_global_indices ... ok [INFO] [stdout] test ui::layout::tests::markdown_layout_populates_span_metadata ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_interleaved_blocks_have_unique_indices ... ok [INFO] [stdout] test ui::markdown::tests::lists::blockquote_followed_by_paragraph_has_single_blank_line ... ok [INFO] [stdout] test ui::markdown::tests::lists::blank_line_before_paragraph_doesnt_cause_blank_before_later_list_item ... ok [INFO] [stdout] test ui::markdown::tests::lists::blockquote_followed_by_list_has_single_blank_line ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::test_block_extraction_returns_consistent_results ... ok [INFO] [stdout] test ui::layout::tests::plain_text_layout_synthesizes_metadata ... 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_heading_has_single_blank_line ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::enter_key_completes_file_prompt_dump ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::enter_key_dispatches_process_command_action ... ok [INFO] [stdout] test ui::markdown::tests::lists::code_blocks_dont_shift_list_item_indices ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::edit_select_enter_refocuses_input ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::assistant_edit_submission_appends_message_without_resend ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::assistant_edit_select_enter_loads_message_into_input ... ok [INFO] [stdout] test ui::chat_loop::modes::tests::assistant_edit_select_delete_truncates_without_flag ... 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::lists_with_numeric_text_before_them_dont_shift_indices ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_followed_by_heading_has_blank_line_after ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_paragraphs_keep_indent_after_blank_lines ... 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::lists::list_followed_by_paragraph_has_blank_line_after ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_items_with_multiple_paragraphs_preserve_blank_lines ... 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::gfm_callout_blockquotes_render_content ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_preceded_by_heading_has_blank_line_before ... ok [INFO] [stdout] test ui::markdown::tests::lists::list_paragraphs_with_soft_breaks_keep_indent ... 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_with_source_blank_lines_preserves_spacing_between_top_level_items ... ok [INFO] [stdout] test ui::markdown::tests::lists::lists_with_plus_markers_preserve_blank_lines ... ok [INFO] [stdout] test ui::markdown::tests::lists::ordered_list_item_code_block_is_indented_under_marker ... ok [INFO] [stdout] test ui::markdown::tests::misc::markdown_images_emit_clickable_links ... ok [INFO] [stdout] test ui::markdown::tests::lists::nested_lists_with_single_blank_line_dont_double_space ... ok [INFO] [stdout] test ui::markdown::tests::misc::superscript_and_subscript_render_without_markers ... ok [INFO] [stdout] test ui::markdown::tests::misc::test_extremely_narrow_terminal_no_truncation ... ok [INFO] [stdout] test ui::markdown::tests::misc::emphasis_with_standalone_paren ... ok [INFO] [stdout] test ui::markdown::tests::misc::horizontal_rules_render_as_centered_lines ... ok [INFO] [stdout] test ui::markdown::tests::misc::tool_call_arguments_do_not_render_markdown ... ok [INFO] [stdout] test ui::markdown::tests::lists::nested_bullet_lists_render_with_indentation ... ok [INFO] [stdout] test ui::markdown::tests::misc::test_logical_row_continuation ... 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::wrapped_list_items_align_under_text ... 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::syntax_spans::code_and_link_metadata_coexist ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::code_block_without_language_has_metadata ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::code_block_spans_have_metadata ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::empty_code_block_has_metadata ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::markdown_details_metadata_matches_lines_and_tags ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::metadata_marks_app_prefix ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::multiple_code_blocks_have_unique_indices ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_balancing_performance ... ok [INFO] [stdout] test ui::markdown::tests::tables::table_parser_emits_expected_event_sequence ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::metadata_marks_user_prefix ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_column_width_balancing ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::nested_code_blocks_have_metadata ... ok [INFO] [stdout] test ui::markdown::tests::tables::metadata_marks_table_links ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::user_message_code_blocks_have_metadata ... ok [INFO] [stdout] test ui::markdown::tests::tables::table_renders_emoji_and_br_correctly ... ok [INFO] [stdout] test ui::markdown::tests::tables::table_rendering_works ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_balancing_with_terminal_width ... ok [INFO] [stdout] test ui::markdown::tests::tables::table_preserves_words_with_available_space ... 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_with_emoji_and_unicode_no_truncation ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_content_wrapping_medium_terminal ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_styled_words_wrap_at_boundaries_in_table ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_cell_word_wrapping_regression ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_should_not_wrap_borders ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::cell_wraps_after_hyphen ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::cell_wraps_at_space_across_spans ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_ending_one_after_width ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_government_systems_table_from_testcase ... ok [INFO] [stdout] test ui::markdown::tests::tables::test_table_wrapping_with_mixed_content ... 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::wrapping::emphasis_with_paren_outside_one_past_width ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_fills_entire_width_with_adjacent_punct ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_with_multiple_adjacent_punctuation ... ok [INFO] [stdout] test ui::markdown::wrap::tests::wrap_preserves_skin_tone_modifiers ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::inline_code_ending_at_width ... ok [INFO] [stdout] test ui::osc::tests::control_detection_catches_bel_and_escape ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_with_paren_inside_at_width ... ok [INFO] [stdout] test ui::markdown::wrap::tests::wrap_preserves_zwj_clusters ... ok [INFO] [stdout] test ui::markdown::wrap::tests::wrap_splits_at_spaces ... ok [INFO] [stdout] test ui::osc::tests::encode_hyperlink_rejects_control_bytes ... ok [INFO] [stdout] test ui::osc::tests::encode_hyperlink_rejects_empty_segments ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::emphasis_with_punctuation_at_width ... ok [INFO] [stdout] test ui::osc::tests::encode_lines_with_links_wraps_each_link_segment ... ok [INFO] [stdout] test ui::osc::tests::lines_with_underline_fallback_apply_to_each_link ... ok [INFO] [stdout] test ui::osc::tests::encode_hyperlink_wraps_text_with_balanced_sequences ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::link_ending_at_width ... 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::wrapping::markdown_links_wrap_at_word_boundaries_with_width ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::strikethrough_ending_at_width ... ok [INFO] [stdout] test ui::osc::tests::underline_fallback_wraps_link_text_with_sgr_sequences ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::markdown_links_wrap_in_long_paragraph_without_mid_word_break ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::shared_renderer_with_metadata_matches_details_wrapper ... ok [INFO] [stdout] test ui::osc_state::tests::compute_render_state_accounts_for_emoji_presentation_sequences ... ok [INFO] [stdout] test ui::osc_backend::tests::closes_stale_hyperlink_even_without_cell_diff ... ok [INFO] [stdout] test ui::osc_state::tests::compute_render_state_tracks_visible_link_segment ... ok [INFO] [stdout] test ui::osc_backend::tests::redraws_cell_when_hyperlink_changes_without_buffer_diff ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::strong_emphasis_ending_at_width ... ok [INFO] [stdout] test ui::markdown::tests::wrapping::wrapped_code_preserves_metadata_across_lines ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_model_with_default_selected ... ok [INFO] [stdout] test ui::renderer::tests::input_title_resets_after_stream_completion ... 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_character_with_filter ... 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_character_picker ... 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::renderer::tests::test_generate_picker_help_text_model_no_filter_no_default ... 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_no_picker ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_theme_picker ... 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::span::tests::extract_code_block_content_retrieves_code ... 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::extract_code_blocks_handles_no_code_blocks ... ok [INFO] [stdout] test ui::span::tests::extract_content_handles_multiple_spans_per_line ... ok [INFO] [stdout] test ui::renderer::tests::test_generate_picker_help_text_with_default_selected ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_active_preset_when_set ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_preserves_language ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_model_when_not_in_transition ... ok [INFO] [stdout] test ui::span::tests::extract_code_blocks_finds_all_blocks ... 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 ui::theme::tests::defaults_cursor_color_from_background ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_no_model_selected_during_transition ... ok [INFO] [stdout] test ui::theme::tests::parses_cursor_color_from_spec ... ok [INFO] [stdout] test ui::renderer::tests::title_shows_character_name_when_active ... ok [INFO] [stdout] test ui::span::tests::text_spans_are_not_code_blocks ... ok [INFO] [stdout] test ui::span::tests::extract_content_selects_correct_block ... ok [INFO] [stdout] test utils::color::tests::detects_256_from_term ... ok [INFO] [stdout] test ui::span::tests::span_kind_recognizes_code_blocks ... ok [INFO] [stdout] test utils::auth::tests::test_custom_provider_auth_headers ... ok [INFO] [stdout] test utils::auth::tests::test_anthropic_auth_headers ... 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 utils::input::tests::test_sanitize_text_input_carriage_returns ... ok [INFO] [stdout] test utils::auth::tests::test_openai_auth_headers ... ok [INFO] [stdout] test utils::color::tests::quantize_rgb_to_256_index ... ok [INFO] [stdout] test utils::color::tests::quantize_rgb_to_ansi16 ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_filters_control_chars ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_mixed_control_chars ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_preserves_newlines ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_tabs ... 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::ctrl_k_deletes_to_end ... ok [INFO] [stdout] test utils::input::tests::test_sanitize_text_input_long_mixed_input ... ok [INFO] [stdout] test utils::line_editor::tests::f2_maps_to_toggle_only_with_reveal_tail_mask ... ok [INFO] [stdout] test utils::line_editor::tests::insert_and_move_cursor ... ok [INFO] [stdout] test ui::span::tests::extract_content_omits_list_indent ... ok [INFO] [stdout] test utils::line_editor::tests::paste_newline_submits ... ok [INFO] [stdout] test utils::line_editor::tests::masked_display_can_reveal_tail ... ok [INFO] [stdout] test utils::scroll::tests::assistant_selection_highlight_changes_rendered_lines ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_scroll_to_message ... ok [INFO] [stdout] test utils::scroll::tests::table_scroll_height_matches_rendered ... ok [INFO] [stdout] test utils::scroll::tests::test_app_message_formatting ... ok [INFO] [stdout] test utils::scroll::tests::test_build_display_lines_basic ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_word_wrapped_lines_exact_fit ... 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_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_markdown_link_wraps_on_nbsp ... ok [INFO] [stdout] test utils::scroll::tests::test_markdown_link_wraps_on_spaces ... ok [INFO] [stdout] test utils::scroll::tests::test_prewrap_paragraph_no_leading_spaces_or_lonely_dot ... ok [INFO] [stdout] test utils::scroll::tests::test_build_display_lines_up_to ... ok [INFO] [stdout] test utils::scroll::tests::test_empty_message_content ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_wrapped_line_count_mixed_content ... ok [INFO] [stdout] test utils::scroll::tests::test_multiline_user_message ... ok [INFO] [stdout] test utils::scroll::tests::test_prewrap_wide_emoji_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_wraps_entire_link_word_when_width_exhausted ... ok [INFO] [stdout] test utils::scroll::tests::test_prewrap_zwj_sequence_respects_width ... ok [INFO] [stdout] test utils::scroll::tests::test_trimming_behavior ... ok [INFO] [stdout] test utils::scroll::tests::test_word_wrapping_with_long_paragraph ... ok [INFO] [stdout] test utils::syntax::tests::dark_background_heuristic_basic ... ok [INFO] [stdout] test utils::syntax::tests::normalize_lang_hint_maps_common_aliases ... ok [INFO] [stdout] test utils::url::tests::test_construct_api_url ... ok [INFO] [stdout] test utils::scroll::tests::test_layout_engine_and_prewrap_preserve_link_words ... ok [INFO] [stdout] test utils::scroll::tests::test_multiline_assistant_message ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_max_scroll_offset ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_scroll_to_bottom_scroll_needed ... ok [INFO] [stdout] test utils::scroll::tests::test_calculate_scroll_to_bottom_no_scroll_needed ... ok [INFO] [stdout] test utils::scroll::tests::test_selection_highlight_builds_same_number_of_lines ... ok [INFO] [stdout] test utils::url::tests::test_normalize_base_url ... ok [INFO] [stdout] test utils::scroll::tests::test_plain_text_long_line_wrapping ... ok [INFO] [stdout] test utils::syntax::tests::theme_selection_matches_brightness ... ok [INFO] [stdout] test utils::syntax::tests::theme_signature_changes_with_theme ... ok [INFO] [stdout] test ui::markdown::tests::syntax_spans::various_language_tags_preserved ... ok [INFO] [stdout] test utils::scroll::tests::perf_prewrap_short_history ... 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.30s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/chabeau-c3fca4fa5c4c570a) [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/character/service.rs - character::service::CharacterService::resolve (line 168) - compile ... ok [INFO] [stdout] test src/core/chat_stream.rs - core::chat_stream::ChatStreamService::spawn_stream (line 475) - 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::new (line 441) ... FAILED [INFO] [stdout] test src/utils/url.rs - utils::url::construct_api_url (line 31) ... FAILED [INFO] [stdout] test src/ui/span.rs - ui::span::extract_code_blocks (line 219) ... ok [INFO] [stdout] test src/ui/span.rs - ui::span::extract_code_block_content (line 281) ... ok [INFO] [stdout] test src/ui/span.rs - ui::span (line 29) ... 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 (line 14) ... ok [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- src/core/chat_stream.rs - core::chat_stream::ChatStreamService::new (line 441) stdout ---- [INFO] [stdout] error: linking with `cc` failed: exit status: 1 [INFO] [stdout] | [INFO] [stdout] = note: "cc" "-m64" "/tmp/rustdoctest5ewSHS/rustcog30nr/symbols.o" "<2 object files omitted>" "-Wl,--as-needed" "-Wl,-Bstatic" "/opt/rustwide/target/debug/deps/{libchabeau-16015e00ba7f8ecc,libsyntect-74304fe7b64c7e6a,libthiserror-95e5eb4daf792da5,libwalkdir-fe31fa9f1b59a72f,libsame_file-e946870f1310cc9c,libonig-3688d9a754132905,libonig_sys-a01199bd58fc1d22,libyaml_rust-260ebaa441834338,liblinked_hash_map-b7c8a9e7b45c620f,libfnv-2a26f5d3b9cd4973,libplist-8dcccece56de9d5b,libtime-99908384ae4b053f,libtime_core-388d6e02ed0f4b60,libnum_conv-0f40d69e12852f0a,libderanged-e9869c25991b04cc,libpowerfmt-521a460cc2ff4e45,libquick_xml-cd76ecc5c7acdcab,libindexmap-b32e6afe26051abc,libhashbrown-d0fb47154dd694bf,libflate2-0e4accef8a46377b,libminiz_oxide-4cf62e918dcfb87a,libsimd_adler32-4fe4b4c59464bded,libbincode-b5122308767f04a4,libtoml-ca0012cc30df21c3,libtoml_writer-35ab0ce8e30b4b5b,libtoml_parser-a74ec8672d694fc1,libwinnow-c21eb4c23d6c59bb,libserde_spanned-40c7b94147ede52b,libtoml_datetime-0ba7f3896065f45a,libpulldown_cmark-84005915aa2781ea,libunicase-39c350669888fd67,libpulldown_cmark_escape-a63533ebaef0d1d8,libtempfile-c004ee12a90a19b3,libgetrandom-ce383aa2864d1759,libfastrand-74ae4622d963d882,librustix-adfa3bcee7914d18,liblinux_raw_sys-468f3136534c61a1,libdirectories-b3e276246f92fd25,libdirs_sys-cfb1d8aca88de039,liboption_ext-38791eff9acb757e,libtui_textarea-e759f32429f05263,libreqwest-d00d2899c59c7b5b,libserde_urlencoded-0255fc05c0395b4b,libhyper_rustls-95706d06a0bdf4d4,libwebpki_roots-e9a07f90f667481e,libtokio_rustls-f2d02d974b2f9902,librustls-e9d82567e982a2c1,libsubtle-e2f0af8959bd7889,libwebpki-eeaab377f79040ba,libring-051342a85de72fce,libgetrandom-60c0a86da80d3291,libuntrusted-151845769873c416,librustls_pki_types-e111b9082dd87a73,libtower_http-8bde65db9bb3b1df,libiri_string-f1c5413b54c99d2e,libtower-1e53f4e57e0992b0,libtower_layer-5699d784b4449e00,libhyper_util-749f3dc2b56698d2,libipnet-7f24c5b85fa70b77,libtower_service-222788e4f5219726,libhyper-e0056c3f07994d18,libwant-4a0be0a267c8825f,libtry_lock-b2ba3b7879656042,libhttparse-2dcf90c780aed9d3,libpin_utils-edd6e294c1e21a4f,libatomic_waker-f98c2fb1596910db,libfutures_channel-673eba4cd2f1a4af,libfutures_util-adba78d149223955,libslab-f5fed19216a24be8,libfutures_task-02cf0fb977266c2e,libhttp_body_util-51ac6181adb5452a,libhttp_body-112e6cca9463065d,liburl-b6a3e8b685b2634e,libidna-7d3577851ec171a2,libutf8_iter-efb3984ee203d151,libidna_adapter-a492212e0961f86c,libicu_properties-965891c29e2878fc,libicu_properties_data-7e155758dd6ea0a4,libicu_normalizer-8e8cc829c69fc69a,libicu_normalizer_data-e4349eb9146e5fe1,libicu_collections-d336a746685c9e49,libpotential_utf-a08ea77aa518589e,libicu_provider-632560efc7359e3f,libicu_locale_core-8198e189c0779372,libtinystr-e781cb59ae1fa234,liblitemap-d0ce52a8e9251912,libwriteable-9b3c58e63c9ae012,libzerovec-5d3f6a3f0b03d4d4,libzerotrie-d922ecf9575ca75c,libyoke-1f5c479702b070b4,libstable_deref_trait-646f6b28b9520b3d,libzerofrom-6aed673e3378898c,libform_urlencoded-e63e84c134db7b31,libpercent_encoding-99cdb00cefa02ca0,libhttp-db17fbb5ab25270d,libsync_wrapper-096429d0b7f46333,libtokio_util-ceeff8183a29891c,libfutures_core-3e8ff8c6a8ead7f1,libfutures_sink-59b73d2c5a0fb80d,libtokio-248825dbcfb1126b,libsocket2-b4690ac25538134d,libbytes-a6415339708e1154,librust_mcp_schema-cec8e5c646ee3782,libtracing_subscriber-3eed66fe6890274f,libsharded_slab-a43bbfc0e39c291b,liblazy_static-afffdbb119bd9ac1,libmatchers-4abdf90835c54fe2,libregex_automata-459ff98ca88c72df,libregex_syntax-762daa43d7cf4e3e,libnu_ansi_term-93d8ee8dec5a4017,libtracing-8fe5ea6b70365722,libpin_project_lite-5ffafa3f2ed0bb57,libthread_local-18638dcf05a3c55a,libtracing_log-fdc254d2911c833a,libtracing_core-5bf54009919d6314,libonce_cell-db8f3eed2a1f3f7b,libclap-5be6a152df6828c2,libclap_builder-cb9270c2089c3561,libstrsim-f574d476d7d1a6ac,libanstream-4e5206a633f6e11c,libanstyle_query-39b86009b9b8dd8a,libis_terminal_polyfill-090e57e4b8c850d2,libcolorchoice-0b50abc860a6bcad,libanstyle_parse-8a8fb41415b00427,libutf8parse-ae3caf0a878928ed,libclap_lex-ba64047a148e58f8,libanstyle-1f7f6180e797cb80,libratatui-7ed6d884675e15d3,libunicode_truncate-5c60f7c4b7b380a8,libunicode_width-c57d0dcadf6efd33,liblru-4f30ecbc259dd4f2,libhashbrown-e2d7c798925d0e5c,libfoldhash-675ca81b23a745d6,libequivalent-9631f206a02b9f54,liballocator_api2-61425620d8bdad59,libitertools-dfe6d24b877629bb,libeither-f9cfe41df9eac463,libcassowary-244fb82557458a01,libcompact_str-596ba57ab58dc65c,libryu-96e4827cb8e74ef1,libstatic_assertions-acd18841cc36d7c2,libcastaway-c2828b035f4874cf,libunicode_segmentation-bd9208f0886bf29c,libunicode_width-bc270aad86d5ab5d,libstrum-45a43d86e79e0ef7,libcrossterm-e6de2317a5eedbce,librustix-5c4a8870fb38fe4e,liblinux_raw_sys-ecd8c3651f5555d1,libbitflags-5009bb8c2d6ccbe4,libparking_lot-745da6643f91b65d,libparking_lot_core-0fcbac7f789b0f80,libsmallvec-128704011005142e,liblock_api-ff2db0b8acf8234a,libscopeguard-88d64e99d3001c2a,libsignal_hook_mio-cd08c4cbf87a8628,libsignal_hook-1e06011d7c1fe610,libsignal_hook_registry-2756cfcce0011620,liberrno-d9c69987c87e1467,libmio-909f886775e9d41c,libchrono-e670ba1900e2545b,libiana_time_zone-fc58c626b0bdfc25,libnum_traits-bc0ce776a8f3d154,libcrc32fast-5906a57d877d687d,libcfg_if-cad248e7066eec15,libbase64-fff42f7554bbeb90,libkeyring-0c78859fadf74bdb,libdbus_secret_service-c29ed9a630ff7215,libzeroize-66a407426b325dfe,libdbus-952edb7ca8817d5d,liblibdbus_sys-36a320d987ddff1b,liblibc-0e890954913dc77e,liblog-753a0cb3f11b08fe,libserde_json-137ffebd9e375e42,libmemchr-d8218b780a78fe0a,libitoa-d7c2333f8dedd037,libzmij-d2f562b84b927b2e,libserde-e0e29ab35b2bd804,libserde_core-3babf6f5a9b2410c}.rlib" "/lib/rustlib/x86_64-unknown-linux-gnu/lib/{libstd-*,libpanic_unwind-*,libobject-*,libmemchr-*,libaddr2line-*,libgimli-*,libcfg_if-*,librustc_demangle-*,libstd_detect-*,libhashbrown-*,librustc_std_workspace_alloc-*,libminiz_oxide-*,libadler2-*,libunwind-*,liblibc-*,librustc_std_workspace_core-*,liballoc-*,libcore-*,libcompiler_builtins-*}.rlib" "-Wl,-Bdynamic" "-ldbus-1" "-lgcc_s" "-lutil" "-lrt" "-lpthread" "-lm" "-ldl" "-lc" "-L" "/tmp/rustdoctest5ewSHS/rustcog30nr/raw-dylibs" "-B/lib/rustlib/x86_64-unknown-linux-gnu/bin/gcc-ld" "-fuse-ld=lld" "-Wl,--eh-frame-hdr" "-Wl,-z,noexecstack" "-L" "/opt/rustwide/target/debug/build/libgit2-sys-3b110142dda4c070/out/build" "-L" "/opt/rustwide/target/debug/build/onig_sys-18c23ccc6a88f256/out" "-L" "/opt/rustwide/target/debug/build/ring-0333f046746c760c/out" "-L" "/usr/lib/x86_64-linux-gnu" "-L" "/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-o" "/tmp/rustdoctest5ewSHS/rust_out" "-Wl,--gc-sections" "-pie" "-Wl,-z,relro,-z,now" "-nodefaultlibs" [INFO] [stdout] = note: some arguments are omitted. use `--verbose` to show all linker arguments [INFO] [stdout] = note: collect2: fatal error: ld terminated with signal 9 [Killed] [INFO] [stdout] compilation terminated. [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: aborting due to 1 previous error [INFO] [stdout] [INFO] [stdout] Couldn't compile the test. [INFO] [stdout] ---- src/utils/url.rs - utils::url::construct_api_url (line 31) stdout ---- [INFO] [stdout] error: linking with `cc` failed: exit status: 1 [INFO] [stdout] | [INFO] [stdout] = note: "cc" "-m64" "/tmp/rustdoctesttxfa2x/rustc1Z4T7C/symbols.o" "<2 object files omitted>" "-Wl,--as-needed" "-Wl,-Bstatic" "/opt/rustwide/target/debug/deps/{libchabeau-16015e00ba7f8ecc,libsyntect-74304fe7b64c7e6a,libthiserror-95e5eb4daf792da5,libwalkdir-fe31fa9f1b59a72f,libsame_file-e946870f1310cc9c,libonig-3688d9a754132905,libonig_sys-a01199bd58fc1d22,libyaml_rust-260ebaa441834338,liblinked_hash_map-b7c8a9e7b45c620f,libfnv-2a26f5d3b9cd4973,libplist-8dcccece56de9d5b,libtime-99908384ae4b053f,libtime_core-388d6e02ed0f4b60,libnum_conv-0f40d69e12852f0a,libderanged-e9869c25991b04cc,libpowerfmt-521a460cc2ff4e45,libquick_xml-cd76ecc5c7acdcab,libindexmap-b32e6afe26051abc,libhashbrown-d0fb47154dd694bf,libflate2-0e4accef8a46377b,libminiz_oxide-4cf62e918dcfb87a,libsimd_adler32-4fe4b4c59464bded,libbincode-b5122308767f04a4,libtoml-ca0012cc30df21c3,libtoml_writer-35ab0ce8e30b4b5b,libtoml_parser-a74ec8672d694fc1,libwinnow-c21eb4c23d6c59bb,libserde_spanned-40c7b94147ede52b,libtoml_datetime-0ba7f3896065f45a,libpulldown_cmark-84005915aa2781ea,libunicase-39c350669888fd67,libpulldown_cmark_escape-a63533ebaef0d1d8,libtempfile-c004ee12a90a19b3,libgetrandom-ce383aa2864d1759,libfastrand-74ae4622d963d882,librustix-adfa3bcee7914d18,liblinux_raw_sys-468f3136534c61a1,libdirectories-b3e276246f92fd25,libdirs_sys-cfb1d8aca88de039,liboption_ext-38791eff9acb757e,libtui_textarea-e759f32429f05263,libreqwest-d00d2899c59c7b5b,libserde_urlencoded-0255fc05c0395b4b,libhyper_rustls-95706d06a0bdf4d4,libwebpki_roots-e9a07f90f667481e,libtokio_rustls-f2d02d974b2f9902,librustls-e9d82567e982a2c1,libsubtle-e2f0af8959bd7889,libwebpki-eeaab377f79040ba,libring-051342a85de72fce,libgetrandom-60c0a86da80d3291,libuntrusted-151845769873c416,librustls_pki_types-e111b9082dd87a73,libtower_http-8bde65db9bb3b1df,libiri_string-f1c5413b54c99d2e,libtower-1e53f4e57e0992b0,libtower_layer-5699d784b4449e00,libhyper_util-749f3dc2b56698d2,libipnet-7f24c5b85fa70b77,libtower_service-222788e4f5219726,libhyper-e0056c3f07994d18,libwant-4a0be0a267c8825f,libtry_lock-b2ba3b7879656042,libhttparse-2dcf90c780aed9d3,libpin_utils-edd6e294c1e21a4f,libatomic_waker-f98c2fb1596910db,libfutures_channel-673eba4cd2f1a4af,libfutures_util-adba78d149223955,libslab-f5fed19216a24be8,libfutures_task-02cf0fb977266c2e,libhttp_body_util-51ac6181adb5452a,libhttp_body-112e6cca9463065d,liburl-b6a3e8b685b2634e,libidna-7d3577851ec171a2,libutf8_iter-efb3984ee203d151,libidna_adapter-a492212e0961f86c,libicu_properties-965891c29e2878fc,libicu_properties_data-7e155758dd6ea0a4,libicu_normalizer-8e8cc829c69fc69a,libicu_normalizer_data-e4349eb9146e5fe1,libicu_collections-d336a746685c9e49,libpotential_utf-a08ea77aa518589e,libicu_provider-632560efc7359e3f,libicu_locale_core-8198e189c0779372,libtinystr-e781cb59ae1fa234,liblitemap-d0ce52a8e9251912,libwriteable-9b3c58e63c9ae012,libzerovec-5d3f6a3f0b03d4d4,libzerotrie-d922ecf9575ca75c,libyoke-1f5c479702b070b4,libstable_deref_trait-646f6b28b9520b3d,libzerofrom-6aed673e3378898c,libform_urlencoded-e63e84c134db7b31,libpercent_encoding-99cdb00cefa02ca0,libhttp-db17fbb5ab25270d,libsync_wrapper-096429d0b7f46333,libtokio_util-ceeff8183a29891c,libfutures_core-3e8ff8c6a8ead7f1,libfutures_sink-59b73d2c5a0fb80d,libtokio-248825dbcfb1126b,libsocket2-b4690ac25538134d,libbytes-a6415339708e1154,librust_mcp_schema-cec8e5c646ee3782,libtracing_subscriber-3eed66fe6890274f,libsharded_slab-a43bbfc0e39c291b,liblazy_static-afffdbb119bd9ac1,libmatchers-4abdf90835c54fe2,libregex_automata-459ff98ca88c72df,libregex_syntax-762daa43d7cf4e3e,libnu_ansi_term-93d8ee8dec5a4017,libtracing-8fe5ea6b70365722,libpin_project_lite-5ffafa3f2ed0bb57,libthread_local-18638dcf05a3c55a,libtracing_log-fdc254d2911c833a,libtracing_core-5bf54009919d6314,libonce_cell-db8f3eed2a1f3f7b,libclap-5be6a152df6828c2,libclap_builder-cb9270c2089c3561,libstrsim-f574d476d7d1a6ac,libanstream-4e5206a633f6e11c,libanstyle_query-39b86009b9b8dd8a,libis_terminal_polyfill-090e57e4b8c850d2,libcolorchoice-0b50abc860a6bcad,libanstyle_parse-8a8fb41415b00427,libutf8parse-ae3caf0a878928ed,libclap_lex-ba64047a148e58f8,libanstyle-1f7f6180e797cb80,libratatui-7ed6d884675e15d3,libunicode_truncate-5c60f7c4b7b380a8,libunicode_width-c57d0dcadf6efd33,liblru-4f30ecbc259dd4f2,libhashbrown-e2d7c798925d0e5c,libfoldhash-675ca81b23a745d6,libequivalent-9631f206a02b9f54,liballocator_api2-61425620d8bdad59,libitertools-dfe6d24b877629bb,libeither-f9cfe41df9eac463,libcassowary-244fb82557458a01,libcompact_str-596ba57ab58dc65c,libryu-96e4827cb8e74ef1,libstatic_assertions-acd18841cc36d7c2,libcastaway-c2828b035f4874cf,libunicode_segmentation-bd9208f0886bf29c,libunicode_width-bc270aad86d5ab5d,libstrum-45a43d86e79e0ef7,libcrossterm-e6de2317a5eedbce,librustix-5c4a8870fb38fe4e,liblinux_raw_sys-ecd8c3651f5555d1,libbitflags-5009bb8c2d6ccbe4,libparking_lot-745da6643f91b65d,libparking_lot_core-0fcbac7f789b0f80,libsmallvec-128704011005142e,liblock_api-ff2db0b8acf8234a,libscopeguard-88d64e99d3001c2a,libsignal_hook_mio-cd08c4cbf87a8628,libsignal_hook-1e06011d7c1fe610,libsignal_hook_registry-2756cfcce0011620,liberrno-d9c69987c87e1467,libmio-909f886775e9d41c,libchrono-e670ba1900e2545b,libiana_time_zone-fc58c626b0bdfc25,libnum_traits-bc0ce776a8f3d154,libcrc32fast-5906a57d877d687d,libcfg_if-cad248e7066eec15,libbase64-fff42f7554bbeb90,libkeyring-0c78859fadf74bdb,libdbus_secret_service-c29ed9a630ff7215,libzeroize-66a407426b325dfe,libdbus-952edb7ca8817d5d,liblibdbus_sys-36a320d987ddff1b,liblibc-0e890954913dc77e,liblog-753a0cb3f11b08fe,libserde_json-137ffebd9e375e42,libmemchr-d8218b780a78fe0a,libitoa-d7c2333f8dedd037,libzmij-d2f562b84b927b2e,libserde-e0e29ab35b2bd804,libserde_core-3babf6f5a9b2410c}.rlib" "/lib/rustlib/x86_64-unknown-linux-gnu/lib/{libstd-*,libpanic_unwind-*,libobject-*,libmemchr-*,libaddr2line-*,libgimli-*,libcfg_if-*,librustc_demangle-*,libstd_detect-*,libhashbrown-*,librustc_std_workspace_alloc-*,libminiz_oxide-*,libadler2-*,libunwind-*,liblibc-*,librustc_std_workspace_core-*,liballoc-*,libcore-*,libcompiler_builtins-*}.rlib" "-Wl,-Bdynamic" "-ldbus-1" "-lgcc_s" "-lutil" "-lrt" "-lpthread" "-lm" "-ldl" "-lc" "-L" "/tmp/rustdoctesttxfa2x/rustc1Z4T7C/raw-dylibs" "-B/lib/rustlib/x86_64-unknown-linux-gnu/bin/gcc-ld" "-fuse-ld=lld" "-Wl,--eh-frame-hdr" "-Wl,-z,noexecstack" "-L" "/opt/rustwide/target/debug/build/libgit2-sys-3b110142dda4c070/out/build" "-L" "/opt/rustwide/target/debug/build/onig_sys-18c23ccc6a88f256/out" "-L" "/opt/rustwide/target/debug/build/ring-0333f046746c760c/out" "-L" "/usr/lib/x86_64-linux-gnu" "-L" "/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-o" "/tmp/rustdoctesttxfa2x/rust_out" "-Wl,--gc-sections" "-pie" "-Wl,-z,relro,-z,now" "-nodefaultlibs" [INFO] [stdout] = note: some arguments are omitted. use `--verbose` to show all linker arguments [INFO] [stdout] = note: collect2: fatal error: ld terminated with signal 9 [Killed] [INFO] [stdout] compilation terminated. [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: aborting due to 1 previous error [INFO] [stdout] [INFO] [stdout] Couldn't compile the test. [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] src/core/chat_stream.rs - core::chat_stream::ChatStreamService::new (line 441) [INFO] [stdout] src/utils/url.rs - utils::url::construct_api_url (line 31) [INFO] [stdout] [INFO] [stdout] test result: FAILED. 9 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 8.99s [INFO] [stdout] [INFO] [stderr] error: doctest failed, to rerun pass `--doc` [INFO] running `Command { std: "docker" "inspect" "678167ca65171750741282ac9c85cf7b15ded8cd143877e2cf45dc83dcb2675a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "678167ca65171750741282ac9c85cf7b15ded8cd143877e2cf45dc83dcb2675a", kill_on_drop: false }` [INFO] [stdout] 678167ca65171750741282ac9c85cf7b15ded8cd143877e2cf45dc83dcb2675a