[INFO] cloning repository https://github.com/cyberwitchery/lepiter-cli
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/cyberwitchery/lepiter-cli" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcyberwitchery%2Flepiter-cli", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcyberwitchery%2Flepiter-cli'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 41e090c40a43626cf927e8824a7e8ccf4b50a035
[INFO] testing cyberwitchery/lepiter-cli against try#33835004928d3bf65db4d4712e1330766263b0bd for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcyberwitchery%2Flepiter-cli" "/workspace/builds/worker-4-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/cyberwitchery/lepiter-cli
[INFO] finished tweaking git repo https://github.com/cyberwitchery/lepiter-cli
[INFO] tweaked toml for git repo https://github.com/cyberwitchery/lepiter-cli written to /workspace/builds/worker-4-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/cyberwitchery/lepiter-cli on toolchain 33835004928d3bf65db4d4712e1330766263b0bd
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/cyberwitchery/lepiter-cli 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" "+33835004928d3bf65db4d4712e1330766263b0bd" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] bb8ce98f6b2ead39f4ce32f186946ab77448201b1c8038fd65b39dc858941678
[INFO] running `Command { std: "docker" "start" "-a" "bb8ce98f6b2ead39f4ce32f186946ab77448201b1c8038fd65b39dc858941678", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "bb8ce98f6b2ead39f4ce32f186946ab77448201b1c8038fd65b39dc858941678", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "bb8ce98f6b2ead39f4ce32f186946ab77448201b1c8038fd65b39dc858941678", kill_on_drop: false }`
[INFO] [stdout] bb8ce98f6b2ead39f4ce32f186946ab77448201b1c8038fd65b39dc858941678
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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" "+33835004928d3bf65db4d4712e1330766263b0bd" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 9ed39529adc68a1ac58b742f6b9b25d77a1571b03ad3e2d68afc9bd94be60c1e
[INFO] running `Command { std: "docker" "start" "-a" "9ed39529adc68a1ac58b742f6b9b25d77a1571b03ad3e2d68afc9bd94be60c1e", kill_on_drop: false }`
[INFO] [stderr]    Compiling instability v0.3.11
[INFO] [stderr]    Compiling rustix v1.1.4
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling is-docker v0.2.0
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling memchr v2.8.0
[INFO] [stderr]    Compiling hashbrown v0.17.0
[INFO] [stderr]    Compiling is-wsl v0.4.0
[INFO] [stderr]    Compiling compact_str v0.8.1
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling open v5.3.3
[INFO] [stderr]    Compiling signal-hook-mio v0.2.5
[INFO] [stderr]    Compiling crossterm v0.28.1
[INFO] [stderr]    Compiling indexmap v2.14.0
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling darling_core v0.23.0
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling derive_more-impl v2.1.1
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling derive_more v2.1.1
[INFO] [stderr]    Compiling crossterm v0.29.0
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]    Compiling ratatui v0.29.0
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling lepiter-core v0.7.0 (/opt/rustwide/workdir/lepiter-core)
[INFO] [stderr]    Compiling lepiter-cli v0.7.0 (/opt/rustwide/workdir/lepiter-tui)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 34.21s
[INFO] running `Command { std: "docker" "inspect" "9ed39529adc68a1ac58b742f6b9b25d77a1571b03ad3e2d68afc9bd94be60c1e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9ed39529adc68a1ac58b742f6b9b25d77a1571b03ad3e2d68afc9bd94be60c1e", kill_on_drop: false }`
[INFO] [stdout] 9ed39529adc68a1ac58b742f6b9b25d77a1571b03ad3e2d68afc9bd94be60c1e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0bd54a1756ea6454414eb60e722f2233ac37f4de9d47a9deda9da57a6e72fccf
[INFO] running `Command { std: "docker" "start" "-a" "0bd54a1756ea6454414eb60e722f2233ac37f4de9d47a9deda9da57a6e72fccf", kill_on_drop: false }`
[INFO] [stderr]    Compiling lepiter-core v0.7.0 (/opt/rustwide/workdir/lepiter-core)
[INFO] [stderr]    Compiling lepiter-cli v0.7.0 (/opt/rustwide/workdir/lepiter-tui)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 8.33s
[INFO] running `Command { std: "docker" "inspect" "0bd54a1756ea6454414eb60e722f2233ac37f4de9d47a9deda9da57a6e72fccf", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0bd54a1756ea6454414eb60e722f2233ac37f4de9d47a9deda9da57a6e72fccf", kill_on_drop: false }`
[INFO] [stdout] 0bd54a1756ea6454414eb60e722f2233ac37f4de9d47a9deda9da57a6e72fccf
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] be161a725698f5f6fcb2e6f8fd2b58cb75f2a72bd6f9e3294a8ce0de5c77b56c
[INFO] running `Command { std: "docker" "start" "-a" "be161a725698f5f6fcb2e6f8fd2b58cb75f2a72bd6f9e3294a8ce0de5c77b56c", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.23s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/lepiter_cli-bfc53cec8af97ae0)
[INFO] [stdout] 
[INFO] [stdout] running 240 tests
[INFO] [stdout] test edit::tests::char_to_byte_idx_ascii ... ok
[INFO] [stdout] test edit::tests::char_to_byte_idx_emoji ... ok
[INFO] [stdout] test edit::tests::collect_snippets_deeply_nested ... ok
[INFO] [stdout] test edit::tests::collect_snippets_empty ... ok
[INFO] [stdout] test edit::tests::collect_snippets_flat ... ok
[INFO] [stdout] test edit::tests::collect_snippets_no_children_key ... ok
[INFO] [stdout] test edit::tests::char_to_byte_idx_multibyte ... ok
[INFO] [stdout] test edit::tests::collect_snippets_normalizes_cr ... ok
[INFO] [stdout] test edit::tests::commit_buffer_updates_raw_json ... ok
[INFO] [stdout] test edit::tests::cursor_line_col_multiline ... ok
[INFO] [stdout] test edit::tests::cursor_line_col_single_line ... ok
[INFO] [stdout] test edit::tests::cursor_line_col_with_tab ... ok
[INFO] [stdout] test edit::tests::collect_snippets_nested ... ok
[INFO] [stdout] test edit::tests::cursor_tracks_multiline_text_snippet ... ok
[INFO] [stdout] test edit::tests::delete_char_at_beginning ... ok
[INFO] [stdout] test edit::tests::delete_char_at_empty_returns_false ... ok
[INFO] [stdout] test edit::tests::delete_char_at_end_returns_false ... ok
[INFO] [stdout] test edit::tests::delete_char_at_middle ... ok
[INFO] [stdout] test edit::tests::delete_char_at_multibyte ... ok
[INFO] [stdout] test edit::tests::commit_buffer_noop_when_unchanged ... ok
[INFO] [stdout] test edit::tests::cursor_line_col_cr_treated_as_newline ... ok
[INFO] [stdout] test edit::tests::delete_char_before_at_start_returns_false ... ok
[INFO] [stdout] test edit::tests::delete_char_before_end ... ok
[INFO] [stdout] test edit::tests::delete_char_before_middle ... ok
[INFO] [stdout] test edit::tests::delete_char_before_multibyte ... ok
[INFO] [stdout] test edit::tests::delete_char_before_single_char ... ok
[INFO] [stdout] test edit::tests::display_col_to_char_idx_basic ... ok
[INFO] [stdout] test edit::tests::display_col_to_char_idx_empty ... ok
[INFO] [stdout] test edit::tests::display_col_to_char_idx_with_tab ... ok
[INFO] [stdout] test edit::tests::editable_field_code_snippet ... ok
[INFO] [stdout] test edit::tests::editable_field_code_snippet_source_field ... ok
[INFO] [stdout] test edit::tests::editable_field_non_editable ... ok
[INFO] [stdout] test edit::tests::editable_field_text_snippet ... ok
[INFO] [stdout] test edit::tests::ensure_scroll_cursor_at_bottom_edge ... ok
[INFO] [stdout] test edit::tests::ensure_scroll_cursor_above_view ... ok
[INFO] [stdout] test edit::tests::ensure_scroll_cursor_at_top_edge ... ok
[INFO] [stdout] test edit::tests::ensure_scroll_cursor_below_view ... ok
[INFO] [stdout] test edit::tests::ensure_scroll_cursor_in_view ... ok
[INFO] [stdout] test edit::tests::ensure_scroll_cursor_just_past_bottom ... ok
[INFO] [stdout] test edit::tests::ensure_scroll_view_height_one ... ok
[INFO] [stdout] test edit::tests::ensure_scroll_zero_height_returns_current ... ok
[INFO] [stdout] test edit::tests::insert_char_at_beginning ... ok
[INFO] [stdout] test edit::tests::insert_char_at_ascii_middle ... ok
[INFO] [stdout] test edit::tests::insert_char_at_cr_becomes_lf ... ok
[INFO] [stdout] test edit::tests::insert_char_at_end ... ok
[INFO] [stdout] test edit::tests::insert_char_at_empty_buffer ... ok
[INFO] [stdout] test edit::tests::insert_char_at_multibyte ... ok
[INFO] [stdout] test edit::tests::editable_field_text_snippet_text_field ... ok
[INFO] [stdout] test edit::tests::insert_char_at_multibyte_middle ... ok
[INFO] [stdout] test edit::tests::is_editable_false_for_picture ... ok
[INFO] [stdout] test edit::tests::is_editable_true_for_text ... ok
[INFO] [stdout] test edit::tests::move_cursor_vertical_at_first_line_stays ... ok
[INFO] [stdout] test edit::tests::move_cursor_vertical_at_last_line_stays ... ok
[INFO] [stdout] test edit::tests::move_cursor_vertical_clamps_to_shorter_line ... ok
[INFO] [stdout] test edit::tests::move_cursor_vertical_down ... ok
[INFO] [stdout] test edit::tests::move_cursor_vertical_single_line_noop ... ok
[INFO] [stdout] test edit::tests::move_cursor_vertical_up ... ok
[INFO] [stdout] test edit::tests::push_undo_caps_at_200 ... ok
[INFO] [stdout] test edit::tests::push_undo_on_non_editable_is_noop ... ok
[INFO] [stdout] test edit::tests::push_undo_snapshot_records_state ... ok
[INFO] [stdout] test edit::tests::set_buffer_normalizes_and_sets_cursor ... ok
[INFO] [stdout] test edit::tests::snippet_at_path_mut_finds_nested ... ok
[INFO] [stdout] test edit::tests::snippet_at_path_mut_invalid_returns_none ... ok
[INFO] [stdout] test edit::tests::undo_clamps_cursor_to_buffer_length ... ok
[INFO] [stdout] test edit::tests::undo_on_empty_stack_returns_false ... ok
[INFO] [stdout] test edit::tests::undo_restores_previous_state ... ok
[INFO] [stdout] test highlight::tests::backslash_escape_in_string ... ok
[INFO] [stdout] test highlight::tests::javascript_comment ... ok
[INFO] [stdout] test highlight::tests::keyword_detection ... ok
[INFO] [stdout] test highlight::tests::number_literal ... ok
[INFO] [stdout] test highlight::tests::python_comment ... ok
[INFO] [stdout] test highlight::tests::simple_escaped_quote ... ok
[INFO] [stdout] test inline::tests::annotation ... ok
[INFO] [stdout] test inline::tests::bold ... ok
[INFO] [stdout] test inline::tests::bold_and_italic ... ok
[INFO] [stdout] test inline::tests::bracket_not_a_link ... ok
[INFO] [stdout] test inline::tests::code ... ok
[INFO] [stdout] test inline::tests::empty_string ... ok
[INFO] [stdout] test inline::tests::italic ... ok
[INFO] [stdout] test inline::tests::multiple_links ... ok
[INFO] [stdout] test inline::tests::plain_text ... ok
[INFO] [stdout] test inline::tests::unclosed_bold ... ok
[INFO] [stdout] test inline::tests::url_link ... ok
[INFO] [stdout] test inline::tests::wiki_link ... ok
[INFO] [stdout] test keybindings::tests::edit_backtab_clamps_at_first_snippet ... ok
[INFO] [stdout] test edit::tests::snippet_at_path_mut_empty_path_returns_root ... ok
[INFO] [stdout] test keybindings::tests::edit_backtab_switches_snippet_backward ... ok
[INFO] [stdout] test keybindings::tests::edit_delete_removes_char_at_cursor ... ok
[INFO] [stdout] test keybindings::tests::edit_ctrl_char_is_ignored ... ok
[INFO] [stdout] test keybindings::tests::edit_char_inserts_into_buffer ... ok
[INFO] [stdout] test keybindings::tests::edit_backspace_deletes_before_cursor ... ok
[INFO] [stdout] test keybindings::tests::edit_end_moves_cursor_to_end ... ok
[INFO] [stdout] test keybindings::tests::edit_esc_exits_to_page_mode ... ok
[INFO] [stdout] test keybindings::tests::edit_home_moves_cursor_to_start ... ok
[INFO] [stdout] test keybindings::tests::edit_left_clamps_at_zero ... ok
[INFO] [stdout] test keybindings::tests::edit_mode_returns_tick ... ok
[INFO] [stdout] test keybindings::tests::edit_ctrl_u_undoes ... ok
[INFO] [stdout] test keybindings::tests::edit_enter_inserts_newline ... ok
[INFO] [stdout] test keybindings::tests::edit_pagedown_increases_scroll ... ok
[INFO] [stdout] test keybindings::tests::edit_left_arrow_moves_cursor ... ok
[INFO] [stdout] test keybindings::tests::edit_pageup_decreases_scroll ... ok
[INFO] [stdout] test keybindings::tests::edit_pageup_clamps_at_zero ... ok
[INFO] [stdout] test keybindings::tests::edit_right_arrow_moves_cursor ... ok
[INFO] [stdout] test keybindings::tests::edit_right_clamps_at_buffer_len ... ok
[INFO] [stdout] test keybindings::tests::edit_tab_clamps_at_last_snippet ... ok
[INFO] [stdout] test keybindings::tests::edit_tab_switches_snippet_forward ... ok
[INFO] [stdout] test keybindings::tests::help_mode_ignores_enter ... ok
[INFO] [stdout] test keybindings::tests::help_mode_question_mark_dismisses ... ok
[INFO] [stdout] test keybindings::tests::help_mode_esc_dismisses ... ok
[INFO] [stdout] test keybindings::tests::help_mode_ignores_other_keys ... ok
[INFO] [stdout] test keybindings::tests::list_enter_opens_page ... ok
[INFO] [stdout] test keybindings::tests::list_down_arrow_moves_selection ... ok
[INFO] [stdout] test keybindings::tests::list_esc_stays_in_list ... ok
[INFO] [stdout] test keybindings::tests::list_g_does_not_change_scroll ... ok
[INFO] [stdout] test keybindings::tests::list_k_moves_selection_up ... ok
[INFO] [stdout] test keybindings::tests::list_j_moves_selection_down ... ok
[INFO] [stdout] test keybindings::tests::list_q_returns_quit ... ok
[INFO] [stdout] test keybindings::tests::list_question_mark_shows_help ... ok
[INFO] [stdout] test keybindings::tests::list_selection_clamps_at_zero ... ok
[INFO] [stdout] test keybindings::tests::list_shift_o_is_noop ... ok
[INFO] [stdout] test keybindings::tests::list_slash_enters_search_mode ... ok
[INFO] [stdout] test keybindings::tests::list_to_page_to_list_via_b ... ok
[INFO] [stdout] test keybindings::tests::list_returns_tick ... ok
[INFO] [stdout] test keybindings::tests::list_to_search_to_list_roundtrip ... ok
[INFO] [stdout] test keybindings::tests::list_unrecognized_key_returns_tick ... ok
[INFO] [stdout] test keybindings::tests::list_up_arrow_moves_selection ... ok
[INFO] [stdout] test keybindings::tests::page_backtab_cycles_link_selection_backward ... ok
[INFO] [stdout] test keybindings::tests::page_g_scrolls_to_top ... ok
[INFO] [stdout] test keybindings::tests::page_big_g_scrolls_to_bottom ... ok
[INFO] [stdout] test keybindings::tests::page_down_arrow_scrolls ... ok
[INFO] [stdout] test keybindings::tests::page_j_k_dont_change_list_selection ... ok
[INFO] [stdout] test keybindings::tests::page_h_with_history_opens_previous ... ok
[INFO] [stdout] test keybindings::tests::page_k_scrolls_up ... ok
[INFO] [stdout] test keybindings::tests::page_h_goes_back_in_history ... ok
[INFO] [stdout] test keybindings::tests::page_j_scrolls_down ... ok
[INFO] [stdout] test keybindings::tests::page_k_clamps_at_zero ... ok
[INFO] [stdout] test keybindings::tests::page_q_quits ... ok
[INFO] [stdout] test keybindings::tests::page_slash_enters_search ... ok
[INFO] [stdout] test keybindings::tests::search_esc_clears_and_returns_to_list ... ok
[INFO] [stdout] test keybindings::tests::search_always_returns_search_tick ... ok
[INFO] [stdout] test keybindings::tests::search_enter_opens_selected_page ... ok
[INFO] [stdout] test keybindings::tests::search_backspace_on_empty_is_noop ... ok
[INFO] [stdout] test keybindings::tests::search_backspace_removes_last_char ... ok
[INFO] [stdout] test keybindings::tests::page_shift_o_triggers_open_externally ... ok
[INFO] [stdout] test keybindings::tests::page_tab_cycles_link_selection_forward ... ok
[INFO] [stdout] test keybindings::tests::page_unrecognized_key_returns_tick ... ok
[INFO] [stdout] test keybindings::tests::search_typing_accumulates_chars ... ok
[INFO] [stdout] test keybindings::tests::search_unrecognized_key_returns_search_tick ... ok
[INFO] [stdout] test keybindings::tests::search_up_down_navigate_results ... ok
[INFO] [stdout] test keybindings::tests::page_to_edit_to_page_roundtrip ... ok
[INFO] [stdout] test keybindings::tests::page_up_arrow_scrolls ... ok
[INFO] [stdout] test render::tests::annotations_empty_string ... ok
[INFO] [stdout] test keybindings::tests::page_esc_returns_to_list ... ok
[INFO] [stdout] test keybindings::tests::search_esc_returns_search_tick ... ok
[INFO] [stdout] test render::tests::annotations_highlight ... ok
[INFO] [stdout] test keybindings::tests::page_pageup_scrolls_half_page ... ok
[INFO] [stdout] test render::tests::annotations_multiple ... ok
[INFO] [stdout] test render::tests::annotations_plain_text ... ok
[INFO] [stdout] test render::tests::annotations_renders_bold ... ok
[INFO] [stdout] test keybindings::tests::page_question_mark_shows_help ... ok
[INFO] [stdout] test keybindings::tests::page_b_returns_to_list ... ok
[INFO] [stdout] test render::tests::highlight_leaves_non_matching_markers ... ok
[INFO] [stdout] test render::tests::both_paths_style_bold_identically ... ok
[INFO] [stdout] test render::tests::both_paths_style_annotations_identically ... ok
[INFO] [stdout] test render::tests::highlight_empty_lines ... ok
[INFO] [stdout] test render::tests::annotations_renders_links_without_markers ... ok
[INFO] [stdout] test render::tests::highlight_marker_at_span_start ... ok
[INFO] [stdout] test render::tests::highlight_replaces_matching_marker ... ok
[INFO] [stdout] test render::tests::highlight_marker_embedded_in_text ... ok
[INFO] [stdout] test render::tests::highlight_marker_at_span_end ... ok
[INFO] [stdout] test render::tests::inline_annotation ... ok
[INFO] [stdout] test render::tests::inline_bracket_not_a_link ... ok
[INFO] [stdout] test render::tests::inline_bold ... ok
[INFO] [stdout] test render::tests::inline_code ... ok
[INFO] [stdout] test render::tests::inline_empty_string ... ok
[INFO] [stdout] test render::tests::inline_multiple_links_indexed ... ok
[INFO] [stdout] test render::tests::inline_url_link ... ok
[INFO] [stdout] test render::tests::inline_wiki_link ... ok
[INFO] [stdout] test render::tests::list_empty_item ... ok
[INFO] [stdout] test render::tests::list_item_with_multiple_nodes ... ok
[INFO] [stdout] test render::tests::inline_italic ... ok
[INFO] [stdout] test render::tests::inline_plain_text ... ok
[INFO] [stdout] test render::tests::list_item_with_code_block ... ok
[INFO] [stdout] test render::tests::list_single_line_items ... ok
[INFO] [stdout] test render::tests::sanitize_control_chars_to_space ... ok
[INFO] [stdout] test plugins::tests::request_detects_mid_request_crash ... ok
[INFO] [stdout] test render::tests::sanitize_strips_esc ... ok
[INFO] [stdout] test render::tests::sanitize_mixed ... ok
[INFO] [stdout] test render::tests::sanitize_preserves_newlines ... ok
[INFO] [stdout] test tests::collect_page_links_inline_link_in_heading ... ok
[INFO] [stdout] test render::tests::sanitize_tabs_to_spaces ... ok
[INFO] [stdout] test plugins::tests::render_with_working_plugin ... ok
[INFO] [stdout] test tests::collect_page_links_code_nodes_ignored ... ok
[INFO] [stdout] test tests::collect_page_links_inline_link_in_paragraph ... ok
[INFO] [stdout] test tests::collect_page_links_inline_link_in_quote ... ok
[INFO] [stdout] test tests::collect_page_links_multiple_inline_links ... ok
[INFO] [stdout] test render::tests::sanitize_plain_text_unchanged ... ok
[INFO] [stdout] test tests::collect_page_links_mixed_standalone_and_inline ... ok
[INFO] [stdout] test tests::collect_page_links_inline_link_in_text ... ok
[INFO] [stdout] test tests::collect_page_links_list_items_with_inline_links ... ok
[INFO] [stdout] test tests::collect_page_links_no_links_in_plain_text ... ok
[INFO] [stdout] test tests::collect_page_links_standalone_link_node ... ok
[INFO] [stdout] test plugins::tests::working_plugin_responds_within_timeout ... ok
[INFO] [stdout] test tests::collect_page_links_wiki_link_in_paragraph ... ok
[INFO] [stdout] test keybindings::tests::page_pagedown_scrolls_half_page ... ok
[INFO] [stdout] test util::tests::cache_limit_allow_zero_parses_valid_value ... ok
[INFO] [stdout] test util::tests::cache_limit_allow_zero_permits_zero ... ok
[INFO] [stdout] test util::tests::cache_limit_allow_zero_uses_default_when_unset ... ok
[INFO] [stdout] test util::tests::cache_limit_allow_zero_default_zero_stays_zero ... ok
[INFO] [stdout] test util::tests::cache_limit_from_env_clamps_default_zero_to_one ... ok
[INFO] [stdout] test util::tests::cache_limit_from_env_falls_back_on_non_numeric ... ok
[INFO] [stdout] test util::tests::cache_limit_from_env_clamps_zero_to_one ... ok
[INFO] [stdout] test render::tests::inline_bold_and_italic_combined ... ok
[INFO] [stdout] test util::tests::cache_limit_from_env_parses_valid_value ... ok
[INFO] [stdout] test util::tests::cache_limit_from_env_uses_default_when_unset ... ok
[INFO] [stdout] test render::tests::inline_unclosed_bold_treated_as_text ... ok
[INFO] [stdout] test util::tests::insert_and_get ... ok
[INFO] [stdout] test util::tests::get_missing_returns_none ... ok
[INFO] [stdout] test util::tests::insert_existing_key_refreshes_order ... ok
[INFO] [stdout] test util::tests::new_cache_is_empty ... ok
[INFO] [stdout] test util::tests::eviction_at_capacity ... ok
[INFO] [stdout] test util::tests::peek_does_not_change_order ... ok
[INFO] [stdout] test util::tests::eviction_chain ... ok
[INFO] [stdout] test util::tests::get_updates_lru_order ... ok
[INFO] [stdout] test util::tests::get_with_str_key ... ok
[INFO] [stdout] test util::tests::insert_existing_key_updates_value ... ok
[INFO] [stdout] test util::tests::integer_keys_work ... ok
[INFO] [stdout] test util::tests::peek_with_str_key ... ok
[INFO] [stdout] test util::tests::touch_present_key_returns_true ... ok
[INFO] [stdout] test util::tests::zero_capacity_cache ... ok
[INFO] [stdout] test util::tests::touch_with_str_key ... ok
[INFO] [stdout] test util::tests::zero_capacity_rejects_inserts ... ok
[INFO] [stdout] test util::tests::touch_absent_key_returns_false ... ok
[INFO] [stdout] test util::tests::touch_refreshes_lru_order ... ok
[INFO] [stdout] test plugins::tests::request_detects_already_exited_plugin ... ok
[INFO] [stdout] test plugins::tests::render_returns_error_when_respawn_fails ... ok
[INFO] [stdout] test plugins::tests::multiple_requests_work_after_respawn ... ok
[INFO] [stdout] test plugins::tests::request_times_out_on_unresponsive_plugin ... ok
[INFO] [stdout] test plugins::tests::transient_error_not_cached ... ok
[INFO] [stdout] test plugins::tests::render_respawns_hung_plugin ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 240 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.18s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/plugin_ipc.rs (/opt/rustwide/target/debug/deps/plugin_ipc-fc99bd2100cb5d27)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling lepiter-core v0.7.0 (/opt/rustwide/workdir/lepiter-core)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 14.82s
[INFO] [stderr] error: test failed, to rerun pass `-p lepiter-cli --test plugin_ipc`
[INFO] [stdout] test wardley_plugin_renders_nodes_over_ipc ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- wardley_plugin_renders_nodes_over_ipc stdout ----
[INFO] [stdout] Error: wardley_plugin not found at /opt/rustwide/workdir/target/debug/examples/wardley_plugin
[INFO] [stdout] 
[INFO] [stdout] Stack backtrace:
[INFO] [stdout]    0: <anyhow::Error>::msg::<alloc::string::String>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/anyhow-1.0.102/src/backtrace.rs:10:14
[INFO] [stdout]    1: plugin_ipc::build_plugin_binary
[INFO] [stdout]              at ./tests/plugin_ipc.rs:57:9
[INFO] [stdout]    2: plugin_ipc::wardley_plugin_renders_nodes_over_ipc
[INFO] [stdout]              at ./tests/plugin_ipc.rs:8:18
[INFO] [stdout]    3: plugin_ipc::wardley_plugin_renders_nodes_over_ipc::{closure#0}
[INFO] [stdout]              at ./tests/plugin_ipc.rs:7:47
[INFO] [stdout]    4: <plugin_ipc::wardley_plugin_renders_nodes_over_ipc::{closure#0} as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]    5: <fn() -> core::result::Result<(), alloc::string::String> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]    6: test::__rust_begin_short_backtrace::<core::result::Result<(), alloc::string::String>, fn() -> core::result::Result<(), alloc::string::String>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:724:18
[INFO] [stdout]    7: test::run_test_in_process::{closure#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:74
[INFO] [stdout]    8: <core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]    9: std::panicking::catch_unwind::do_call::<core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}>, core::result::Result<(), alloc::string::String>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   10: std::panicking::catch_unwind::<core::result::Result<(), alloc::string::String>, core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   11: std::panic::catch_unwind::<core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}>, core::result::Result<(), alloc::string::String>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   12: test::run_test_in_process
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:27
[INFO] [stdout]   13: test::run_test::{closure#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:668:43
[INFO] [stdout]   14: test::run_test::{closure#1}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:698:41
[INFO] [stdout]   15: std::sys::backtrace::__rust_begin_short_backtrace::<test::run_test::{closure#1}, ()>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   16: std::thread::lifecycle::spawn_unchecked::<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:70:13
[INFO] [stdout]   17: <core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   18: std::panicking::catch_unwind::do_call::<core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   19: std::panicking::catch_unwind::<(), core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   20: std::panic::catch_unwind::<core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   21: std::thread::lifecycle::spawn_unchecked::<test::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:68:26
[INFO] [stdout]   22: <std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1} as core::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23: <alloc::boxed::Box<dyn core::ops::function::FnOnce<(), Output = ()> + core::marker::Send> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2271:9
[INFO] [stdout]   24: <std::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   25: <unknown>
[INFO] [stdout]   26: clone
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     wardley_plugin_renders_nodes_over_ipc
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 16.29s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "be161a725698f5f6fcb2e6f8fd2b58cb75f2a72bd6f9e3294a8ce0de5c77b56c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "be161a725698f5f6fcb2e6f8fd2b58cb75f2a72bd6f9e3294a8ce0de5c77b56c", kill_on_drop: false }`
[INFO] [stdout] be161a725698f5f6fcb2e6f8fd2b58cb75f2a72bd6f9e3294a8ce0de5c77b56c
