[INFO] cloning repository https://github.com/arclabs561/piku [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/arclabs561/piku" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Farclabs561%2Fpiku", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Farclabs561%2Fpiku'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 4c138003ffac0b8bea89ec8364764dd45682066d [INFO] testing arclabs561/piku against beta-2026-04-21 for beta-1.96-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Farclabs561%2Fpiku" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/arclabs561/piku [INFO] finished tweaking git repo https://github.com/arclabs561/piku [INFO] tweaked toml for git repo https://github.com/arclabs561/piku written to /workspace/builds/worker-5-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/arclabs561/piku on toolchain beta-2026-04-21 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Locking 229 packages to latest compatible versions [INFO] [stderr] Adding crossterm v0.28.1 (available: v0.29.0) [INFO] [stderr] Adding reqwest v0.12.28 (available: v0.13.2) [INFO] [stderr] Adding thiserror v1.0.69 (available: v2.0.18) [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-04-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] f147de11b3acd08f67373e0d0b189415d01af2f92f583f03c67ac68b2f571a5a [INFO] running `Command { std: "docker" "start" "-a" "f147de11b3acd08f67373e0d0b189415d01af2f92f583f03c67ac68b2f571a5a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "f147de11b3acd08f67373e0d0b189415d01af2f92f583f03c67ac68b2f571a5a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f147de11b3acd08f67373e0d0b189415d01af2f92f583f03c67ac68b2f571a5a", kill_on_drop: false }` [INFO] [stdout] f147de11b3acd08f67373e0d0b189415d01af2f92f583f03c67ac68b2f571a5a [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 091417c42ee7699124a9758dbe233041214ef8380cfe2f194ee8ca36878688de [INFO] running `Command { std: "docker" "start" "-a" "091417c42ee7699124a9758dbe233041214ef8380cfe2f194ee8ca36878688de", kill_on_drop: false }` [INFO] [stderr] Compiling bitflags v2.11.1 [INFO] [stderr] Compiling libc v0.2.185 [INFO] [stderr] Compiling memchr v2.8.0 [INFO] [stderr] Compiling cc v1.2.60 [INFO] [stderr] Compiling openssl v0.10.78 [INFO] [stderr] Compiling hashbrown v0.17.0 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling zerovec-derive v0.11.3 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling tokio-macros v2.7.0 [INFO] [stderr] Compiling futures-macro v0.3.32 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling icu_properties_data v2.2.0 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling icu_normalizer_data v2.2.0 [INFO] [stderr] Compiling native-tls v0.2.18 [INFO] [stderr] Compiling futures-channel v0.3.32 [INFO] [stderr] Compiling zmij v1.0.21 [INFO] [stderr] Compiling openssl-probe v0.2.1 [INFO] [stderr] Compiling sync_wrapper v1.0.2 [INFO] [stderr] Compiling ipnet v2.12.0 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling iri-string v0.7.12 [INFO] [stderr] Compiling rustls-pki-types v1.14.0 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling indexmap v2.14.0 [INFO] [stderr] Compiling async-stream-impl v0.3.6 [INFO] [stderr] Compiling rustix v1.1.4 [INFO] [stderr] Compiling getrandom v0.4.2 [INFO] [stderr] Compiling zerofrom-derive v0.1.7 [INFO] [stderr] Compiling yoke-derive v0.8.2 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling same-file v1.0.6 [INFO] [stderr] Compiling errno v0.3.14 [INFO] [stderr] Compiling signal-hook-registry v1.4.8 [INFO] [stderr] Compiling mio v1.2.0 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling socket2 v0.6.3 [INFO] [stderr] Compiling walkdir v2.5.0 [INFO] [stderr] Compiling async-stream v0.3.6 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling simd-adler32 v0.3.9 [INFO] [stderr] Compiling bit-vec v0.8.0 [INFO] [stderr] Compiling linux-raw-sys v0.12.1 [INFO] [stderr] Compiling signal-hook v0.3.18 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling tokio v1.52.1 [INFO] [stderr] Compiling openssl-sys v0.9.114 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling bit-set v0.8.0 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling glob v0.3.3 [INFO] [stderr] Compiling anyhow v1.0.102 [INFO] [stderr] Compiling fastrand v2.4.1 [INFO] [stderr] Compiling zerofrom v0.1.7 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling flate2 v1.1.9 [INFO] [stderr] Compiling signal-hook-mio v0.2.5 [INFO] [stderr] Compiling unicode-width v0.2.2 [INFO] [stderr] Compiling yoke v0.8.2 [INFO] [stderr] Compiling unicode-segmentation v1.13.2 [INFO] [stderr] Compiling zerovec v0.11.6 [INFO] [stderr] Compiling zerotrie v0.2.4 [INFO] [stderr] Compiling crossterm v0.28.1 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling tinystr v0.8.3 [INFO] [stderr] Compiling potential_utf v0.1.5 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling icu_collections v2.2.0 [INFO] [stderr] Compiling tempfile v3.27.0 [INFO] [stderr] Compiling icu_locale_core v2.2.0 [INFO] [stderr] Compiling self-replace v1.5.0 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling bincode v1.3.3 [INFO] [stderr] Compiling icu_provider v2.2.0 [INFO] [stderr] Compiling icu_properties v2.2.0 [INFO] [stderr] Compiling icu_normalizer v2.2.0 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling fancy-regex v0.16.2 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling syntect v5.3.0 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling hyper v1.9.0 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling piku-api v0.1.0 (/opt/rustwide/workdir/crates/piku-api) [INFO] [stderr] Compiling piku-tools v0.1.0 (/opt/rustwide/workdir/crates/piku-tools) [INFO] [stderr] Compiling piku-runtime v0.1.0 (/opt/rustwide/workdir/crates/piku-runtime) [INFO] [stderr] Compiling piku v0.1.0 (/opt/rustwide/workdir/crates/piku) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 00s [INFO] running `Command { std: "docker" "inspect" "091417c42ee7699124a9758dbe233041214ef8380cfe2f194ee8ca36878688de", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "091417c42ee7699124a9758dbe233041214ef8380cfe2f194ee8ca36878688de", kill_on_drop: false }` [INFO] [stdout] 091417c42ee7699124a9758dbe233041214ef8380cfe2f194ee8ca36878688de [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] dda1b321f7d4b41d7586a437ad70af2bf441d703ff28e6c6624cda49c625a72c [INFO] running `Command { std: "docker" "start" "-a" "dda1b321f7d4b41d7586a437ad70af2bf441d703ff28e6c6624cda49c625a72c", kill_on_drop: false }` [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling mio v1.2.0 [INFO] [stderr] Compiling openssl-sys v0.9.114 [INFO] [stderr] Compiling getrandom v0.4.2 [INFO] [stderr] Compiling cfg_aliases v0.2.1 [INFO] [stderr] Compiling sdd v3.0.10 [INFO] [stderr] Compiling signal-hook v0.3.18 [INFO] [stderr] Compiling futures-executor v0.3.32 [INFO] [stderr] Compiling serial_test_derive v3.4.0 [INFO] [stderr] Compiling arrayvec v0.7.6 [INFO] [stderr] Compiling comma v1.0.0 [INFO] [stderr] Compiling nix v0.31.2 [INFO] [stderr] Compiling vte v0.15.0 [INFO] [stderr] Compiling tempfile v3.27.0 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling scc v2.4.0 [INFO] [stderr] Compiling tokio v1.52.1 [INFO] [stderr] Compiling signal-hook-mio v0.2.5 [INFO] [stderr] Compiling self-replace v1.5.0 [INFO] [stderr] Compiling crossterm v0.28.1 [INFO] [stderr] Compiling vt100 v0.16.2 [INFO] [stderr] Compiling serial_test v3.4.0 [INFO] [stderr] Compiling openssl v0.10.78 [INFO] [stderr] Compiling rexpect v0.7.0 [INFO] [stderr] Compiling native-tls v0.2.18 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling hyper v1.9.0 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling piku-api v0.1.0 (/opt/rustwide/workdir/crates/piku-api) [INFO] [stderr] Compiling piku-tools v0.1.0 (/opt/rustwide/workdir/crates/piku-tools) [INFO] [stderr] Compiling piku-runtime v0.1.0 (/opt/rustwide/workdir/crates/piku-runtime) [INFO] [stderr] Compiling piku v0.1.0 (/opt/rustwide/workdir/crates/piku) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 51.30s [INFO] running `Command { std: "docker" "inspect" "dda1b321f7d4b41d7586a437ad70af2bf441d703ff28e6c6624cda49c625a72c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "dda1b321f7d4b41d7586a437ad70af2bf441d703ff28e6c6624cda49c625a72c", kill_on_drop: false }` [INFO] [stdout] dda1b321f7d4b41d7586a437ad70af2bf441d703ff28e6c6624cda49c625a72c [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-04-21" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] b7fe773a59b25c884443cdf9beeb6b7527600a756dafad3592b113b6e53e3ea2 [INFO] running `Command { std: "docker" "start" "-a" "b7fe773a59b25c884443cdf9beeb6b7527600a756dafad3592b113b6e53e3ea2", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.50s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/piku-7ad3172677580af7) [INFO] [stdout] [INFO] [stdout] running 127 tests [INFO] [stdout] test config::tests::cli_overrides_file ... ok [INFO] [stdout] test input_helper::tests::ctrl_p_n_history ... ok [INFO] [stdout] test input_helper::tests::basic_insert_and_backspace ... ok [INFO] [stdout] test config::tests::load_empty_config ... ok [INFO] [stdout] test input_helper::tests::ctrl_j_inserts_newline ... ok [INFO] [stdout] test input_helper::tests::ctrl_k_u_w ... ok [INFO] [stdout] test input_helper::tests::ctrl_a_e_home_end ... ok [INFO] [stdout] test input_helper::tests::ctrl_d_exits_on_empty_deletes_on_non_empty ... ok [INFO] [stdout] test input_helper::tests::cursor_up_down_within_multiline ... ok [INFO] [stdout] test input_helper::tests::delete_char ... ok [INFO] [stdout] test config::tests::permission_allow_exact ... ok [INFO] [stdout] test config::tests::permission_deny_overrides_allow ... ok [INFO] [stdout] test config::tests::project_overrides_global ... ok [INFO] [stdout] test config::tests::cli_beats_project ... ok [INFO] [stdout] test input_helper::tests::ghost_text_most_recent_wins ... ok [INFO] [stdout] test input_helper::tests::grapheme_movement_ascii ... ok [INFO] [stdout] test input_helper::tests::ghost_text_no_match ... ok [INFO] [stdout] test input_helper::tests::history_navigation ... ok [INFO] [stdout] test input_helper::tests::ghost_text_skips_slash_commands ... ok [INFO] [stdout] test input_helper::tests::dedup_consecutive_history ... ok [INFO] [stdout] test input_helper::tests::grapheme_backspace_multibyte ... ok [INFO] [stdout] test input_helper::tests::esc_clears_input ... ok [INFO] [stdout] test config::tests::sessions_and_traces_dirs ... ok [INFO] [stdout] test config::tests::permission_allow_glob ... ok [INFO] [stdout] test input_helper::tests::cursor_down_from_first_line ... ok [INFO] [stdout] test input_helper::tests::kill_and_yank_round_trip ... ok [INFO] [stdout] test input_helper::tests::kill_to_start ... ok [INFO] [stdout] test input_helper::tests::kill_word_back ... ok [INFO] [stdout] test input_helper::tests::newline_insertion ... ok [INFO] [stdout] test input_helper::tests::paste_converts_tabs ... ok [INFO] [stdout] test input_helper::tests::render_multiline_with_continuation ... ok [INFO] [stdout] test input_helper::tests::paste_normalizes_cr ... ok [INFO] [stdout] test input_helper::tests::paste_strips_ansi ... ok [INFO] [stdout] test input_helper::tests::shift_enter_inserts_newline ... ok [INFO] [stdout] test input_helper::tests::render_shows_placeholder_when_empty ... ok [INFO] [stdout] test input_helper::tests::slash_command_completion ... ok [INFO] [stdout] test input_helper::tests::undo_is_empty_on_fresh_buffer ... ok [INFO] [stdout] test input_helper::tests::transpose_chars ... ok [INFO] [stdout] test input_helper::tests::undo_restores_after_kill ... ok [INFO] [stdout] test input_helper::tests::kill_to_end ... ok [INFO] [stdout] test input_helper::tests::undo_after_many_inserts ... ok [INFO] [stdout] test input_helper::tests::up_arrow_works_on_single_line ... ok [INFO] [stdout] test input_helper::tests::visible_width_cjk ... ok [INFO] [stdout] test input_helper::tests::visible_width_strips_ansi ... ok [INFO] [stdout] test input_helper::tests::word_movement ... ok [INFO] [stdout] test input_helper::tests::kill_buffer_survives_clear ... ok [INFO] [stdout] test markdown::tests::block_quote ... ok [INFO] [stdout] test input_helper::tests::ghost_text_from_history ... ok [INFO] [stdout] test input_helper::tests::up_arrow_only_on_first_line ... ok [INFO] [stdout] test markdown::tests::bold_and_italic ... ok [INFO] [stdout] test markdown::tests::dash_without_space_not_list ... ok [INFO] [stdout] test markdown::tests::empty_code_block ... ok [INFO] [stdout] test markdown::tests::empty_line_passthrough ... ok [INFO] [stdout] test markdown::tests::hash_not_heading_without_space ... ok [INFO] [stdout] test markdown::tests::heading_rendered ... ok [INFO] [stdout] test markdown::tests::horizontal_rule ... ok [INFO] [stdout] test markdown::tests::indented_list_items ... ok [INFO] [stdout] test markdown::tests::inline_code_highlighted ... ok [INFO] [stdout] test markdown::tests::line_endings_are_crlf_in_tui_mode ... ok [INFO] [stdout] test markdown::tests::line_endings_are_lf_in_stdout_mode ... ok [INFO] [stdout] test markdown::tests::list_bullets ... ok [INFO] [stdout] test markdown::tests::nested_bold_in_italic_not_supported_gracefully ... ok [INFO] [stdout] test markdown::tests::ordered_list_at_line_start ... ok [INFO] [stdout] test markdown::tests::star_in_multiplication_not_italic ... ok [INFO] [stdout] test markdown::tests::ordered_list_false_positive_mid_sentence ... ok [INFO] [stdout] test markdown::tests::flush_pending ... ok [INFO] [stdout] test markdown::tests::streaming_partial_lines ... ok [INFO] [stdout] test markdown::tests::token_by_token_streaming ... ok [INFO] [stdout] test markdown::tests::unclosed_backtick_passthrough ... ok [INFO] [stdout] test self_update::tests::detect_self_build_false_for_other_crate_only ... ok [INFO] [stdout] test self_update::tests::detect_self_build_false_when_no_finished ... ok [INFO] [stdout] test markdown::tests::unclosed_bold_passthrough ... ok [INFO] [stdout] test self_update::tests::detect_self_build_false_on_failed_exit ... ok [INFO] [stdout] test self_update::tests::do_replace_fails_on_empty_new_binary ... ok [INFO] [stdout] test self_update::tests::do_replace_preserves_executable_bit ... ok [INFO] [stdout] test self_update::tests::do_replace_fails_on_missing_new_binary ... ok [INFO] [stdout] test self_update::tests::do_replace_is_atomic_target_unchanged_on_failure ... ok [INFO] [stdout] test self_update::tests::is_newer_than_mtime_false_when_file_unchanged ... ok [INFO] [stdout] test self_update::tests::do_replace_writes_new_content_to_target ... ok [INFO] [stdout] test self_update::tests::is_newer_than_running_false_for_same_file_as_running ... ok [INFO] [stdout] test self_update::tests::mtime_newer_than_returns_false_for_same_file ... ok [INFO] [stdout] test self_update::tests::is_newer_than_running_false_for_nonexistent ... ok [INFO] [stdout] test self_update::tests::replace_and_exec_fails_on_empty_binary ... ok [INFO] [stdout] test self_update::tests::baseline_detects_update_even_when_same_path_as_running ... ok [INFO] [stdout] test self_update::tests::mtime_newer_than_returns_true_for_freshly_written_file ... ok [INFO] [stdout] test self_update::tests::replace_and_exec_fails_on_missing_binary ... ok [INFO] [stdout] test self_update::tests::was_restarted_returns_false_when_unset ... ok [INFO] [stdout] test tui_repl::tests::context_pct_caps ... ok [INFO] [stdout] test self_update::tests::was_restarted_returns_true_and_clears_env_var ... ok [INFO] [stdout] test self_update::tests::is_newer_than_mtime_true_after_write ... ok [INFO] [stdout] test tui_repl::tests::context_pct_half ... ok [INFO] [stdout] test tui_repl::tests::fmt_tokens_small ... ok [INFO] [stdout] test tui_repl::tests::fmt_tokens_thousands ... ok [INFO] [stdout] test tui_repl::tests::fmt_tokens_large ... ok [INFO] [stdout] test tui_repl::tests::context_pct_zero_is_none ... ok [INFO] [stdout] test tui_repl::tests::footer_contains_help_hint ... ok [INFO] [stdout] test tui_repl::tests::footer_all_segments_present_wide ... ok [INFO] [stdout] test tui_repl::tests::footer_amber_at_75_pct ... ok [INFO] [stdout] test tui_repl::tests::footer_contains_context_pct ... ok [INFO] [stdout] test tui_repl::tests::footer_contains_token_counts ... ok [INFO] [stdout] test tui_repl::tests::footer_drops_segments_when_narrow ... ok [INFO] [stdout] test tui_repl::tests::footer_contains_provider_and_model ... ok [INFO] [stdout] test tui_repl::tests::footer_hides_tokens_when_zero ... ok [INFO] [stdout] test tui_repl::tests::footer_shows_agents_when_nonzero ... ok [INFO] [stdout] test tui_repl::tests::footer_red_at_90_pct ... ok [INFO] [stdout] test tui_repl::tests::result_lines_connector_first ... ok [INFO] [stdout] test tui_repl::tests::result_lines_empty ... ok [INFO] [stdout] test tui_repl::tests::result_lines_truncates_long ... ok [INFO] [stdout] test tui_repl::tests::result_lines_plus_one_exception ... ok [INFO] [stdout] test tui_repl::tests::tool_result_empty ... ok [INFO] [stdout] test tui_repl::tests::result_lines_dim_mode ... ok [INFO] [stdout] test tui_repl::tests::session_id_extracts_suffix ... ok [INFO] [stdout] test tui_repl::tests::tool_result_bash_not_dimmed ... ok [INFO] [stdout] test tui_repl::tests::tool_result_read_dimmed ... ok [INFO] [stdout] test tui_repl::tests::tool_result_error_red ... ok [INFO] [stdout] test markdown::tests::code_block_no_language ... ok [INFO] [stdout] test markdown::tests::triple_dash_not_hr_inside_code_block ... ok [INFO] [stdout] test markdown::tests::code_block_flush_mid_block ... ok [INFO] [stdout] test markdown::tests::flush_resets_state ... ok [INFO] [stdout] test markdown::tests::code_block_framed ... ok [INFO] [stdout] test markdown::tests::code_block_respects_eol_mode ... ok [INFO] [stdout] test markdown::tests::backticks_inside_code_block_not_confused ... ok [INFO] [stdout] test markdown::tests::mixed_content_streaming ... ok [INFO] [stdout] test markdown::tests::consecutive_code_blocks ... ok [INFO] [stdout] test self_update::tests::do_replace_with_real_binary_content ... ok [INFO] [stdout] test self_update::tests::detect_self_build_some_when_binary_is_newer ... ok [INFO] [stdout] test markdown::tests::heading_inside_code_block_not_rendered ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 127 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 2.06s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/piku-fef1ff4688d698a8) [INFO] [stderr] Running tests/agentic_user.rs (/opt/rustwide/target/debug/deps/agentic_user-99090362441e77b9) [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] [stdout] [INFO] [stdout] running 25 tests [INFO] [stdout] test action_display ... ok [INFO] [stdout] test screen_snapshot_is_ready_unicode_prompt ... ok [INFO] [stdout] test extract_json_from_markdown_fence ... ok [INFO] [stdout] test deterministic_checks_cursor_hidden ... ok [INFO] [stdout] test deterministic_checks_tab_change ... ok [INFO] [stdout] test extract_json_bare_object ... ok [INFO] [stdout] test extract_json_from_prose ... ok [INFO] [stdout] test screen_snapshot_input_row_follows_cursor ... ok [INFO] [stdout] test screen_snapshot_is_ready_ascii_prompt ... ok [INFO] [stdout] test conversation_memory_format ... ok [INFO] [stdout] test screen_snapshot_is_ready_with_hint ... ok [INFO] [stdout] test screen_snapshot_not_ready_when_hidden ... ok [INFO] [stdout] test special_key_bytes ... ok [INFO] [stdout] test terminal_observer_scrollback_captures_scrolled_content ... ok [INFO] [stdout] test terminal_observer_basic ... ok [INFO] [stdout] test workspace_observer_detects_new_file ... ok [INFO] [stdout] test terminal_observer_cursor_hide ... ok [INFO] [stdout] test terminal_observer_styled_rows ... ok [INFO] [stdout] test agentic_user_confident_dev ... ok [INFO] [stdout] test agentic_user_adversarial ... ok [INFO] [stdout] test workspace_observer_detects_modification ... ok [INFO] [stdout] test agentic_user_cautious_beginner ... ok [INFO] [stdout] test agentic_user_feature_implementer ... ok [INFO] [stdout] test agentic_user_input_explorer ... ok [INFO] [stdout] test agentic_attempt_tree_learning ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 25 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.39s [INFO] [stdout] [INFO] [stderr] Running tests/binary_tests.rs (/opt/rustwide/target/debug/deps/binary_tests-a4598c33b85ccc72) [INFO] [stdout] [INFO] [stdout] running 25 tests [INFO] [stdout] test new_session_id_is_unique_across_rapid_calls ... ok [INFO] [stdout] test help_exits_zero_and_contains_usage ... ok [INFO] [stdout] test model_flag_without_value_exits_nonzero ... ok [INFO] [stdout] test resume_flag_without_value_exits_nonzero ... ok [INFO] [stdout] test provider_flag_without_value_does_not_crash ... ok [INFO] [stdout] test provider_flag_without_value_exits_nonzero ... ok [INFO] [stdout] test model_flag_without_value_does_not_crash ... ok [INFO] [stdout] test version_output_does_not_spawn_date_subprocess ... ok [INFO] [stdout] test help_short_flag_identical_to_long ... ok [INFO] [stdout] test piku_restarted_env_var_prints_restart_message_on_any_invocation ... ok [INFO] [stdout] test version_runs_with_custom_config_dir ... ok [INFO] [stdout] test version_writes_to_stdout_not_stderr ... ok [INFO] [stdout] test version_prints_semver_to_stdout ... ok [INFO] [stdout] test xdg_config_home_controls_session_location ... ok [INFO] [stdout] test version_short_flag_identical_to_long ... ok [INFO] [stdout] test openrouter_without_key_exits_nonzero_mentions_key ... ok [INFO] [stdout] test unknown_provider_exits_nonzero_and_names_it ... ok [INFO] [stdout] test resume_nonexistent_session_exits_nonzero ... ok [INFO] [stdout] test groq_without_key_exits_nonzero_mentions_key ... ok [INFO] [stdout] test anthropic_without_key_exits_nonzero ... ok [INFO] [stdout] test no_args_starts_tui_repl_and_exits_zero ... ok [INFO] [stdout] test flags_only_no_prompt_enters_repl ... ok [INFO] [stdout] test missing_api_key_exits_nonzero_with_actionable_error ... ok [INFO] [stdout] test model_equals_form_is_accepted ... ok [INFO] [stdout] test ollama_provider_resolves_without_key ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 25 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.38s [INFO] [stdout] [INFO] [stderr] Running tests/dogfood.rs (/opt/rustwide/target/debug/deps/dogfood-9161dd06e90bf2ec) [INFO] [stdout] [INFO] [stdout] running 12 tests [INFO] [stdout] test dogfood_add_function_to_existing_file ... ok [INFO] [stdout] test dogfood_edit_with_ambiguous_pattern ... ok [INFO] [stdout] test dogfood_bash_and_use_output ... ok [INFO] [stdout] test dogfood_explore_codebase ... ok [INFO] [stdout] test dogfood_find_off_by_one_bug ... ok [INFO] [stdout] test dogfood_multifile_rename ... ok [INFO] [stdout] test dogfood_read_and_answer ... ok [INFO] [stdout] test dogfood_read_edit_verify_loop ... ok [INFO] [stdout] test dogfood_self_describe_architecture ... ok [INFO] [stdout] test dogfood_trace_file_is_written ... ok [INFO] [stdout] test dogfood_write_new_file_from_scratch ... ok [INFO] [stdout] test dogfood_write_tests_for_function ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 12 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running tests/input_integration.rs (/opt/rustwide/target/debug/deps/input_integration-f4ccf30444e11852) [INFO] [stdout] [INFO] [stdout] running 11 tests [INFO] [stdout] test ctrl_c_behavior ... ok [INFO] [stdout] test ctrl_d_behavior ... ok [INFO] [stdout] test esc_then_history ... ok [INFO] [stdout] test multiline_editing ... ok [INFO] [stdout] test paste_normalization ... ok [INFO] [stdout] test ghost_text_accept ... ok [INFO] [stdout] test readline_sequence ... ok [INFO] [stdout] test stash_workflow ... ok [INFO] [stdout] test tab_completion ... ok [INFO] [stdout] test type_clear_retype_recall ... ok [INFO] [stdout] test kill_yank_undo ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 11 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stderr] Running tests/llm_e2e.rs (/opt/rustwide/target/debug/deps/llm_e2e-ef379ddd38ba72d7) [INFO] [stdout] [INFO] [stdout] running 5 tests [INFO] [stdout] test piku_adds_doc_comment_to_rust_function ... ok [INFO] [stdout] test piku_reads_file_and_references_content ... ok [INFO] [stdout] test piku_runs_bash_and_reports_output ... ok [INFO] [stderr] Running tests/rendering.rs (/opt/rustwide/target/debug/deps/rendering-12295f8510a616c7) [INFO] [stdout] test piku_explores_own_codebase_with_glob_and_read ... ok [INFO] [stdout] test piku_creates_new_file_with_content ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 5 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 17 tests [INFO] [stdout] test eol_modes_consistent ... ok [INFO] [stdout] test bold_italic_combined ... ok [INFO] [stdout] test four_backtick_fence_known_limitation ... ok [INFO] [stdout] test empty_tool_input ... ok [INFO] [stdout] test bash_long_command_truncated ... ok [INFO] [stdout] test bash_single_line_command ... ok [INFO] [stdout] test bash_multiline_command ... ok [INFO] [stdout] test nested_blockquote ... ok [INFO] [stdout] test ordered_list_custom_start ... ok [INFO] [stdout] test grep_with_path ... ok [INFO] [stdout] test read_file_short_path ... ok [INFO] [stdout] test unknown_tool_shows_first_string_arg ... ok [INFO] [stdout] test read_file_with_line_range ... ok [INFO] [stdout] test code_block_trailing_blank ... ok [INFO] [stdout] test full_assistant_response ... ok [INFO] [stdout] test code_block_streamed_byte_by_byte ... ok [INFO] [stdout] test interleaved_code_and_text ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 17 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.05s [INFO] [stdout] [INFO] [stderr] Running tests/self_update_e2e.rs (/opt/rustwide/target/debug/deps/self_update_e2e-3da69f76a2e690fa) [INFO] [stdout] [INFO] [stdout] running 58 tests [INFO] [stdout] test bug_a_detect_self_build::cargo_build_piku_runtime_does_not_trigger ... ok [INFO] [stdout] test bug_a_detect_self_build::cargo_build_piku_tools_does_not_trigger ... ok [INFO] [stdout] test bug_a_detect_self_build::failed_build_never_triggers ... ok [INFO] [stdout] test bug_a_detect_self_build::cargo_check_does_not_trigger ... ok [INFO] [stdout] test bug_a_detect_self_build::cargo_build_piku_api_does_not_trigger ... ok [INFO] [stdout] test bug_a_detect_self_build::only_finished_without_piku_marker_does_not_trigger ... ok [INFO] [stdout] test bug_a_detect_self_build::genuine_piku_build_with_correct_marker ... ok [INFO] [stdout] test cli_parsing::empty_args_returns_repl ... ok [INFO] [stdout] test cli_parsing::help_flag_long ... ok [INFO] [stdout] test cli_parsing::help_flag_short ... ok [INFO] [stdout] test cli_parsing::model_flag_empty_value_returns_arg_error ... ok [INFO] [stdout] test cli_parsing::model_and_provider_together ... ok [INFO] [stdout] test cli_parsing::model_flag_without_value_returns_arg_error ... ok [INFO] [stdout] test cli_parsing::prompt_before_flags_still_works ... ok [INFO] [stdout] test cli_parsing::model_flag_space_form ... ok [INFO] [stdout] test cli_parsing::provider_flag_without_value_returns_arg_error ... ok [INFO] [stdout] test cli_parsing::single_word_prompt ... ok [INFO] [stdout] test cli_parsing::model_flag_equals_form ... ok [INFO] [stdout] test cli_parsing::provider_flag_equals_form ... ok [INFO] [stdout] test cli_parsing::provider_flag_space_form ... ok [INFO] [stdout] test bash_detect_integration::bash_stderr_appended_to_output_for_detection ... ok [INFO] [stdout] test cli_parsing::resume_flag_space_form ... ok [INFO] [stdout] test bash_detect_integration::failed_command_never_triggers_detection ... ok [INFO] [stdout] test cli_parsing::version_flag_short ... ok [INFO] [stdout] test detect_self_build::returns_none_on_failed_exit ... ok [INFO] [stdout] test detect_self_build::returns_none_on_failed_exit_even_with_piku_marker ... ok [INFO] [stdout] test cli_parsing::resume_flag_without_value_returns_arg_error ... ok [INFO] [stdout] test cli_parsing::resume_with_model_and_provider ... ok [INFO] [stdout] test cli_parsing::resume_with_prompt ... ok [INFO] [stdout] test cli_parsing::version_flag_long ... ok [INFO] [stdout] test cli_parsing::multi_word_prompt_is_joined ... ok [INFO] [stdout] test do_replace_real_binary::old_target_unchanged_when_new_binary_missing ... ok [INFO] [stdout] test detect_self_build::returns_none_without_finished_marker ... ok [INFO] [stdout] test detect_self_build::does_not_false_positive_on_other_crate_only ... ok [INFO] [stdout] test detect_self_build::returns_none_when_binary_not_newer ... ok [INFO] [stdout] test cli_parsing::resume_flag_equals_form ... ok [INFO] [stdout] test provider_resolution::custom_without_base_url_errors ... ok [INFO] [stdout] test provider_resolution::openrouter_without_key_errors ... ok [INFO] [stdout] test provider_resolution::groq_without_key_errors ... ok [INFO] [stdout] test provider_resolution::unknown_provider_name_errors_with_message ... ok [INFO] [stdout] test session_isolation::session_save_to_nonexistent_parent_dir_creates_it ... ok [INFO] [stdout] test piku_md::piku_md_content_appears_in_system_prompt ... ok [INFO] [stdout] test session_isolation::overwriting_same_session_file_preserves_latest_state ... ok [INFO] [stdout] test session_isolation::two_sessions_with_different_ids_do_not_overwrite ... ok [INFO] [stdout] test session_resume::orphaned_tool_use_in_session_is_detected ... ok [INFO] [stdout] test session_resume::resume_with_only_user_message_adds_new_user_correctly ... ok [INFO] [stdout] test session_resume::resume_after_mid_turn_interrupt_produces_valid_api_sequence ... ok [INFO] [stdout] test piku_md::deduplicates_identical_content_across_ancestor_dirs ... ok [INFO] [stdout] test detect_self_build::mtime_newer_than_is_directional ... ok [INFO] [stdout] test piku_md::large_piku_md_is_truncated_with_marker ... ok [INFO] [stdout] test piku_md::both_piku_md_and_piku_local_md_loaded_when_different ... ok [INFO] [stdout] test bash_detect_integration::cargo_version_output_does_not_trigger_detection ... ok [INFO] [stdout] test detect_self_build::returns_some_when_binary_is_newer_and_output_has_finished ... ok [INFO] [stdout] test provider_resolution::ollama_always_succeeds_resolve_named ... ok [INFO] [stdout] test do_replace_real_binary::replace_is_atomic_no_tmp_file_left_on_success ... ok [INFO] [stdout] test do_replace_real_binary::replaced_binary_is_executable ... ok [INFO] [stdout] test do_replace_real_binary::replaces_target_with_exact_bytes_of_new_binary ... ok [INFO] [stdout] test do_replace_real_binary::subprocess_runs_replaced_binary ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 58 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.85s [INFO] [stdout] [INFO] [stderr] Running tests/test_helpers.rs (/opt/rustwide/target/debug/deps/test_helpers-6909c33f8b1196bd) [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] Running tests/tui_formatting.rs (/opt/rustwide/target/debug/deps/tui_formatting-f6c7837a373da38c) [INFO] [stdout] [INFO] [stdout] running 25 tests [INFO] [stdout] test duration_minutes ... ok [INFO] [stdout] test duration_hours ... ok [INFO] [stdout] test duration_seconds ... ok [INFO] [stdout] test markdown_blockquote_uses_quarter_block ... ok [INFO] [stdout] test pretty_json_too_large ... ok [INFO] [stdout] test markdown_flush_adds_eol_to_partial ... ok [INFO] [stdout] test visible_width_complex_ansi ... ok [INFO] [stdout] test pretty_json_not_json ... ok [INFO] [stdout] test visible_width_empty ... ok [INFO] [stdout] test tool_input_read_file_short_path_unchanged ... ok [INFO] [stdout] test tool_input_bash_multiline_shows_count ... ok [INFO] [stdout] test tool_input_grep_pattern_only ... ok [INFO] [stdout] test markdown_fast_path_plain_text ... ok [INFO] [stdout] test tool_input_read_file_with_lines ... ok [INFO] [stdout] test tool_input_unknown_tool_first_string ... ok [INFO] [stdout] test tool_input_bash_short ... ok [INFO] [stdout] test tool_input_read_file_long_path_shortened ... ok [INFO] [stdout] test tool_input_grep_with_long_path ... ok [INFO] [stdout] test visible_width_plain ... ok [INFO] [stdout] test pretty_json_object ... ok [INFO] [stdout] test visible_width_ansi ... ok [INFO] [stdout] test visible_width_prompt ... ok [INFO] [stdout] test tool_input_bash_very_long_truncated ... ok [INFO] [stdout] test tool_input_bash_empty ... ok [INFO] [stdout] test markdown_fast_path_still_handles_code_blocks ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 25 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.11s [INFO] [stdout] [INFO] [stderr] Running tests/tui_output.rs (/opt/rustwide/target/debug/deps/tui_output-dd6bf59f575c2ce9) [INFO] [stdout] [INFO] [stdout] running 6 tests [INFO] [stdout] test cursor_restored_in_teardown ... ok [INFO] [stdout] test bash_output_not_dimmed_in_format_tool_result ... ok [INFO] [stdout] test user_message_echo_includes_input_variable ... ok [INFO] [stdout] test cursor_show_sequence_present_after_turn ... ok [INFO] [stdout] test user_message_echoed_before_run_turn ... ok [INFO] [stdout] test cursor_restored_on_ctrl_c ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stderr] Running tests/tui_smoke.rs (/opt/rustwide/target/debug/deps/tui_smoke-dbb2767706eb8b73) [INFO] [stdout] [INFO] [stdout] running 8 tests [INFO] [stdout] test sigterm_restores_terminal_before_exit ... ok [INFO] [stdout] test ctrl_d_on_empty_prompt_exits_cleanly ... ok [INFO] [stdout] test help_slash_command_renders ... ok [INFO] [stdout] test permissions_slash_command_renders ... ok [INFO] [stdout] test hooks_slash_command_renders ... ok [INFO] [stdout] test submit_does_not_panic_on_turn_start ... ok [INFO] [stdout] test ctrl_c_mid_turn_cancels_cleanly ... ok [INFO] [stdout] test two_consecutive_prompts_echo_normally ... FAILED [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- two_consecutive_prompts_echo_normally stdout ---- [INFO] [stdout] [INFO] [stdout] thread 'two_consecutive_prompts_echo_normally' (827) panicked at crates/piku/tests/tui_smoke.rs:235:5: [INFO] [stdout] first turn did not produce expected error: [INFO] [stdout]  openrouter · anthropic/claude-sonnet-4.6 │ /help piku openrouter · anthropic/claude-sonnet-4.6 [INFO] [stdout] /help for commands · Shift+Enter for newline · Ctrl-D to exit [INFO] [stdout] [>1u❯ Send a message or /help[?25h❯ f[?25h❯ fi[?25h❯ fir[?25h❯ firs[?25h❯ first[?25h[<1u[?25h [INFO] [stdout] ❯ first [INFO] [stdout] ❯ · thinking[?25h [INFO] [stdout] [1 iter · +0 tokens · 0↑ 0↓ total] [INFO] [stdout] [error] request error: error sending request for url (https://openrouter.ai/api/v1/chat/completions) [INFO] [stdout]  openrouter · anthropic/claude-sonnet-4.6 │ /help [?25h[>1u❯ Send a message or /help[?25h [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x63911bf1e03a - std[128c3efe2914e152]::backtrace_rs::backtrace::libunwind::trace [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x63911bf1e03a - std[128c3efe2914e152]::backtrace_rs::backtrace::trace_unsynchronized:: [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x63911bf1e03a - std[128c3efe2914e152]::sys::backtrace::_print_fmt [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:74:9 [INFO] [stdout] 3: 0x63911bf1e03a - <::print::DisplayBacktrace as core[6771d259883166e6]::fmt::Display>::fmt [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:44:26 [INFO] [stdout] 4: 0x63911bf32dfa - ::fmt [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/fmt/rt.rs:152:76 [INFO] [stdout] 5: 0x63911bf32dfa - core[6771d259883166e6]::fmt::write [INFO] [stdout] 6: 0x63911bf22e42 - std[128c3efe2914e152]::io::default_write_fmt::> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/io/mod.rs:621:11 [INFO] [stdout] 7: 0x63911bf22e42 - as std[128c3efe2914e152]::io::Write>::write_fmt [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/io/mod.rs:1976:13 [INFO] [stdout] 8: 0x63911befaf0f - ::print [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:47:9 [INFO] [stdout] 9: 0x63911befaf0f - std[128c3efe2914e152]::panicking::default_hook::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:292:27 [INFO] [stdout] 10: 0x63911bf15889 - std[128c3efe2914e152]::panicking::default_hook [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:316:9 [INFO] [stdout] 11: 0x63911bea92ec - core[6771d259883166e6]::ops::function::Fn<(&'a std[128c3efe2914e152]::panic::PanicHookInfo<'b>,), Output = ()> + core[6771d259883166e6]::marker::Sync + core[6771d259883166e6]::marker::Send> as core[6771d259883166e6]::ops::function::Fn<(&std[128c3efe2914e152]::panic::PanicHookInfo,)>>::call [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/alloc/src/boxed.rs:2263:9 [INFO] [stdout] 12: 0x63911bea92ec - test[b137923399915ecf]::test_main_with_exit_callback::::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x63911bf15a42 - core[6771d259883166e6]::ops::function::Fn<(&'a std[128c3efe2914e152]::panic::PanicHookInfo<'b>,), Output = ()> + core[6771d259883166e6]::marker::Sync + core[6771d259883166e6]::marker::Send> as core[6771d259883166e6]::ops::function::Fn<(&std[128c3efe2914e152]::panic::PanicHookInfo,)>>::call [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/alloc/src/boxed.rs:2263:9 [INFO] [stdout] 14: 0x63911bf15a42 - std[128c3efe2914e152]::panicking::panic_with_hook [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:833:13 [INFO] [stdout] 15: 0x63911befafc8 - std[128c3efe2914e152]::panicking::panic_handler::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:698:13 [INFO] [stdout] 16: 0x63911beeffc9 - std[128c3efe2914e152]::sys::backtrace::__rust_end_short_backtrace:: [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:182:18 [INFO] [stdout] 17: 0x63911befbf1d - __rustc[752cc74e29381ccc]::rust_begin_unwind [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:689:5 [INFO] [stdout] 18: 0x63911bf335bc - core[6771d259883166e6]::panicking::panic_fmt [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x63911be84d02 - tui_smoke::two_consecutive_prompts_echo_normally::h1567ed53ebdb4b99 [INFO] [stdout] at /opt/rustwide/workdir/crates/piku/tests/tui_smoke.rs:235:5 [INFO] [stdout] 20: 0x63911be850f7 - tui_smoke::two_consecutive_prompts_echo_normally::{{closure}}::h9520306d63b715eb [INFO] [stdout] at /opt/rustwide/workdir/crates/piku/tests/tui_smoke.rs:226:43 [INFO] [stdout] 21: 0x63911be7b8a6 - core::ops::function::FnOnce::call_once::h38ac9399fae923b8 [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 22: 0x63911be9d3eb - core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String> as core[6771d259883166e6]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 23: 0x63911be9d3eb - test[b137923399915ecf]::__rust_begin_short_backtrace::, fn() -> core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String>> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:663:18 [INFO] [stdout] 24: 0x63911bea9dbb - test[b137923399915ecf]::run_test_in_process::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:686:74 [INFO] [stdout] 25: 0x63911bea9dbb - as core[6771d259883166e6]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/panic/unwind_safe.rs:275:9 [INFO] [stdout] 26: 0x63911bea9dbb - std[128c3efe2914e152]::panicking::catch_unwind::do_call::, core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String>> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:581:40 [INFO] [stdout] 27: 0x63911bea9dbb - std[128c3efe2914e152]::panicking::catch_unwind::, core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:544:19 [INFO] [stdout] 28: 0x63911bea9dbb - std[128c3efe2914e152]::panic::catch_unwind::, core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String>> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panic.rs:359:14 [INFO] [stdout] 29: 0x63911bea9dbb - test[b137923399915ecf]::run_test_in_process [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:686:27 [INFO] [stdout] 30: 0x63911bea9dbb - test[b137923399915ecf]::run_test::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:607:43 [INFO] [stdout] 31: 0x63911bea4214 - test[b137923399915ecf]::run_test::{closure#1} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:637:41 [INFO] [stdout] 32: 0x63911bea4214 - std[128c3efe2914e152]::sys::backtrace::__rust_begin_short_backtrace:: [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:166:18 [INFO] [stdout] 33: 0x63911beac9c2 - std[128c3efe2914e152]::thread::lifecycle::spawn_unchecked::::{closure#1}::{closure#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/thread/lifecycle.rs:91:13 [INFO] [stdout] 34: 0x63911beac9c2 - ::{closure#1}::{closure#0}> as core[6771d259883166e6]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/panic/unwind_safe.rs:275:9 [INFO] [stdout] 35: 0x63911beac9c2 - std[128c3efe2914e152]::panicking::catch_unwind::do_call::::{closure#1}::{closure#0}>, ()> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:581:40 [INFO] [stdout] 36: 0x63911beac9c2 - std[128c3efe2914e152]::panicking::catch_unwind::<(), core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe::{closure#1}::{closure#0}>> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:544:19 [INFO] [stdout] 37: 0x63911beac9c2 - std[128c3efe2914e152]::panic::catch_unwind::::{closure#1}::{closure#0}>, ()> [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panic.rs:359:14 [INFO] [stdout] 38: 0x63911beac9c2 - std[128c3efe2914e152]::thread::lifecycle::spawn_unchecked::::{closure#1} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/thread/lifecycle.rs:89:26 [INFO] [stdout] 39: 0x63911beac9c2 - ::{closure#1} as core[6771d259883166e6]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0} [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 40: 0x63911bf1d45f - + core[6771d259883166e6]::marker::Send> as core[6771d259883166e6]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/alloc/src/boxed.rs:2249:9 [INFO] [stdout] 41: 0x63911bf1d45f - ::new::thread_start [INFO] [stdout] at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/thread/unix.rs:118:17 [INFO] [stdout] 42: 0x7b4fb9e01aa4 - [INFO] [stdout] 43: 0x7b4fb9e8ea64 - clone [INFO] [stdout] 44: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] two_consecutive_prompts_echo_normally [INFO] [stdout] [INFO] [stdout] test result: FAILED. 7 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 5.41s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass `-p piku --test tui_smoke` [INFO] running `Command { std: "docker" "inspect" "b7fe773a59b25c884443cdf9beeb6b7527600a756dafad3592b113b6e53e3ea2", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "b7fe773a59b25c884443cdf9beeb6b7527600a756dafad3592b113b6e53e3ea2", kill_on_drop: false }` [INFO] [stdout] b7fe773a59b25c884443cdf9beeb6b7527600a756dafad3592b113b6e53e3ea2