[INFO] cloning repository https://github.com/tuanhung303/weave-patch-mcp
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/tuanhung303/weave-patch-mcp" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftuanhung303%2Fweave-patch-mcp", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftuanhung303%2Fweave-patch-mcp'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] e60f4948251c55524262a7b872b37e4a4bf726f6
[INFO] testing tuanhung303/weave-patch-mcp against 1.95.0 for beta-1.96-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftuanhung303%2Fweave-patch-mcp" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/tuanhung303/weave-patch-mcp
[INFO] finished tweaking git repo https://github.com/tuanhung303/weave-patch-mcp
[INFO] tweaked toml for git repo https://github.com/tuanhung303/weave-patch-mcp written to /workspace/builds/worker-4-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/tuanhung303/weave-patch-mcp on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/tuanhung303/weave-patch-mcp 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" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded tracing-appender v0.2.4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7bc18ba4ca017162aa6c9d82385f4dcb8aab2e6ef406311d2acca821d1570f99
[INFO] running `Command { std: "docker" "start" "-a" "7bc18ba4ca017162aa6c9d82385f4dcb8aab2e6ef406311d2acca821d1570f99", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7bc18ba4ca017162aa6c9d82385f4dcb8aab2e6ef406311d2acca821d1570f99", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7bc18ba4ca017162aa6c9d82385f4dcb8aab2e6ef406311d2acca821d1570f99", kill_on_drop: false }`
[INFO] [stdout] 7bc18ba4ca017162aa6c9d82385f4dcb8aab2e6ef406311d2acca821d1570f99
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+1.95.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 774b8bde7d5975b96f11bf8ec12c59027e6f6c9751882c193cd128da32313194
[INFO] running `Command { std: "docker" "start" "-a" "774b8bde7d5975b96f11bf8ec12c59027e6f6c9751882c193cd128da32313194", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling libc v0.2.184
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling strsim v0.11.1
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling futures-channel v0.3.32
[INFO] [stderr]    Compiling futures-io v0.3.32
[INFO] [stderr]    Compiling slab v0.4.12
[INFO] [stderr]    Compiling ref-cast v1.0.25
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling option-ext v0.2.0
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]    Compiling num-conv v0.2.1
[INFO] [stderr]    Compiling time-core v0.1.8
[INFO] [stderr]    Compiling rmcp v1.3.0
[INFO] [stderr]    Compiling dyn-clone v1.0.20
[INFO] [stderr]    Compiling time v0.3.47
[INFO] [stderr]    Compiling pastey v0.2.1
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling glob v0.3.3
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling mio v1.2.0
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling socket2 v0.6.3
[INFO] [stderr]    Compiling dirs-sys v0.4.1
[INFO] [stderr]    Compiling dirs v5.0.1
[INFO] [stderr]    Compiling getrandom v0.4.2
[INFO] [stderr]    Compiling shellexpand v3.1.2
[INFO] [stderr]    Compiling uuid v1.23.0
[INFO] [stderr]    Compiling rayon v1.11.0
[INFO] [stderr]    Compiling similar v2.7.0
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling darling_core v0.23.0
[INFO] [stderr]    Compiling serde_derive_internals v0.29.1
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling futures-macro v0.3.32
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling ref-cast-impl v1.0.25
[INFO] [stderr]    Compiling tokio-macros v2.7.0
[INFO] [stderr]    Compiling schemars_derive v1.2.1
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling tokio v1.51.0
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling tracing-subscriber v0.3.23
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]    Compiling rmcp-macros v1.3.0
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling tracing-appender v0.2.4
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling futures-executor v0.3.32
[INFO] [stderr]    Compiling futures v0.3.32
[INFO] [stderr]    Compiling schemars v1.2.1
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling weave-patch-mcp v0.0.18 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 36s
[INFO] running `Command { std: "docker" "inspect" "774b8bde7d5975b96f11bf8ec12c59027e6f6c9751882c193cd128da32313194", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "774b8bde7d5975b96f11bf8ec12c59027e6f6c9751882c193cd128da32313194", kill_on_drop: false }`
[INFO] [stdout] 774b8bde7d5975b96f11bf8ec12c59027e6f6c9751882c193cd128da32313194
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+1.95.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1f14f7a326401f820986ff345e05f4f0db4bf3c0bf2f839097c863c459f6054e
[INFO] running `Command { std: "docker" "start" "-a" "1f14f7a326401f820986ff345e05f4f0db4bf3c0bf2f839097c863c459f6054e", kill_on_drop: false }`
[INFO] [stderr]    Compiling fastrand v2.4.0
[INFO] [stderr]    Compiling tempfile v3.27.0
[INFO] [stderr]    Compiling weave-patch-mcp v0.0.18 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 15.19s
[INFO] running `Command { std: "docker" "inspect" "1f14f7a326401f820986ff345e05f4f0db4bf3c0bf2f839097c863c459f6054e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1f14f7a326401f820986ff345e05f4f0db4bf3c0bf2f839097c863c459f6054e", kill_on_drop: false }`
[INFO] [stdout] 1f14f7a326401f820986ff345e05f4f0db4bf3c0bf2f839097c863c459f6054e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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" "+1.95.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] ae7bca8169ab89e2f96347938f84b5f5ebcdff4a331d9fe0ab2fd33c2c8b368f
[INFO] running `Command { std: "docker" "start" "-a" "ae7bca8169ab89e2f96347938f84b5f5ebcdff4a331d9fe0ab2fd33c2c8b368f", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.22s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/weave_patch_mcp-d44a22581174ebbf)
[INFO] [stdout] 
[INFO] [stdout] running 124 tests
[INFO] [stdout] test applier::opstatus_serde_tests::test_opstatus_deserialization ... ok
[INFO] [stdout] test applier::opstatus_serde_tests::test_opstatus_serialization ... ok
[INFO] [stdout] test applier::opstatus_serde_tests::test_opstatus_old_status_migration ... ok
[INFO] [stdout] test applier::opstatus_serde_tests::test_opstatus_default ... ok
[INFO] [stdout] test applier::tests::test_create_file_has_diff ... ok
[INFO] [stdout] test applier::tests::test_create_file ... ok
[INFO] [stdout] test applier::tests::test_create_file_nested ... ok
[INFO] [stdout] test applier::tests::test_delete_file ... ok
[INFO] [stdout] test applier::tests::test_error_file_not_found_for_update ... ok
[INFO] [stdout] test applier::tests::test_error_file_not_found_suggests_similar_files ... ok
[INFO] [stdout] test applier::tests::test_cross_file_atomicity_success ... ok
[INFO] [stdout] test applier::tests::test_error_serializable ... ok
[INFO] [stdout] test applier::tests::test_expand_home_absolute_path ... ok
[INFO] [stdout] test applier::tests::test_expand_home_just_tilde ... ok
[INFO] [stdout] test applier::tests::test_expand_home_relative_path ... ok
[INFO] [stdout] test applier::tests::test_expand_home_with_tilde_path ... ok
[INFO] [stdout] test applier::tests::test_delete_file_has_line_changes ... ok
[INFO] [stdout] test applier::tests::test_backslash_path_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_find_similar_files_finds_similar ... ok
[INFO] [stdout] test applier::tests::test_error_context_not_found ... ok
[INFO] [stdout] test applier::tests::test_find_similar_files_ignores_directories ... ok
[INFO] [stdout] test applier::tests::test_error_file_not_found_reports_absolute_path_source ... ok
[INFO] [stdout] test applier::tests::test_levenshtein_distance_empty_strings ... ok
[INFO] [stdout] test applier::tests::test_levenshtein_distance_kitten_sitting ... ok
[INFO] [stdout] test applier::tests::test_levenshtein_distance_single_char ... ok
[INFO] [stdout] test applier::tests::test_move_atomic_rollback_on_batch_failure ... ok
[INFO] [stdout] test applier::tests::test_find_similar_files_nonexistent_directory ... ok
[INFO] [stdout] test applier::tests::test_move_file_source_not_found ... ok
[INFO] [stdout] test applier::tests::test_move_file_dest_exists ... ok
[INFO] [stdout] test applier::tests::test_move_file_symlink_rejected ... ok
[INFO] [stdout] test applier::tests::test_move_file_success ... ok
[INFO] [stdout] test applier::tests::test_cross_file_atomicity_rollback ... ok
[INFO] [stdout] test applier::tests::test_multi_file_patch ... ok
[INFO] [stdout] test applier::tests::test_nested_path_traversal_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_path_traversal_add_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_levenshtein_distance_identical ... ok
[INFO] [stdout] test applier::tests::test_read_file_not_found ... ok
[INFO] [stdout] test applier::tests::test_absolute_path_add_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_resolve_path_absolute ... ok
[INFO] [stdout] test applier::tests::test_read_file_path_traversal_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_resolve_path_home_expanded ... ok
[INFO] [stdout] test applier::tests::test_resolve_path_relative_existing ... ok
[INFO] [stdout] test applier::tests::test_read_file_validates_path ... ok
[INFO] [stdout] test applier::tests::test_path_traversal_delete_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_read_file_symlink_rejected ... ok
[INFO] [stdout] test applier::tests::test_short_pattern_no_fuzzy ... ok
[INFO] [stdout] test applier::tests::test_structured_error_closest_matches ... ok
[INFO] [stdout] test applier::tests::test_shadow_file_cleaned_up_on_failure ... ok
[INFO] [stdout] test applier::tests::test_symlink_delete_rejected ... ok
[INFO] [stdout] test applier::tests::test_symlink_update_rejected ... ok
[INFO] [stdout] test applier::tests::test_validator_go_extension ... ok
[INFO] [stdout] test applier::tests::test_validator_json_invalid ... ok
[INFO] [stdout] test applier::tests::test_update_file_multiple_hunks ... ok
[INFO] [stdout] test applier::tests::test_validator_sh_invalid ... ok
[INFO] [stdout] test applier::tests::test_validator_sh_valid ... ok
[INFO] [stdout] test applier::tests::test_validator_unknown_extension ... ok
[INFO] [stdout] test applier::tests::test_write_file_creates_new_file ... ok
[INFO] [stdout] test applier::tests::test_write_file_overwrites_existing_file ... ok
[INFO] [stdout] test applier::tests::test_write_then_update_rolls_back_on_staged_context_mismatch ... ok
[INFO] [stdout] test applier::tests::test_write_then_update_uses_staged_content ... ok
[INFO] [stdout] test parser::tests::test_error_missing_begin_no_ops ... ok
[INFO] [stdout] test parser::tests::test_parse_add_file ... ok
[INFO] [stdout] test parser::tests::test_parse_add_file_indented ... ok
[INFO] [stdout] test parser::tests::test_parse_apply_patch_add_file_block ... ok
[INFO] [stdout] test applier::tests::test_fuzzy_match_similarity_threshold ... ok
[INFO] [stdout] test parser::tests::test_parse_apply_patch_update_with_move_to ... ok
[INFO] [stdout] test parser::tests::test_parse_auto_wrap_both_missing ... ok
[INFO] [stdout] test parser::tests::test_parse_apply_patch_delete_file_block ... ok
[INFO] [stdout] test parser::tests::test_parse_auto_wrap_missing_begin ... ok
[INFO] [stdout] test parser::tests::test_parse_create_apply_patch_style_body ... ok
[INFO] [stdout] test parser::tests::test_parse_delete_file ... ok
[INFO] [stdout] test parser::tests::test_parse_hint_with_class ... ok
[INFO] [stdout] test parser::tests::test_parse_hint_with_punctuation ... ok
[INFO] [stdout] test parser::tests::test_parse_auto_wrap_missing_end ... ok
[INFO] [stdout] test parser::tests::test_parse_map_directory ... ok
[INFO] [stdout] test parser::tests::test_parse_markdown_table_pipe_row_as_context ... ok
[INFO] [stdout] test parser::tests::test_parse_move_file ... ok
[INFO] [stdout] test parser::tests::test_parse_move_missing_destination ... ok
[INFO] [stdout] test parser::tests::test_parse_multi_file_patch ... ok
[INFO] [stdout] test parser::tests::test_parse_read_file_basic ... ok
[INFO] [stdout] test parser::tests::test_parse_read_file_mixed_with_operations ... ok
[INFO] [stdout] test parser::tests::test_parse_read_file_with_offset_limit ... ok
[INFO] [stdout] test parser::tests::test_parse_read_file_with_symbols ... ok
[INFO] [stdout] test parser::tests::test_parse_threshold_invalid_value ... ok
[INFO] [stdout] test parser::tests::test_parse_threshold_missing ... ok
[INFO] [stdout] test parser::tests::test_parse_threshold_out_of_range ... ok
[INFO] [stdout] test parser::tests::test_parse_threshold_valid ... ok
[INFO] [stdout] test parser::tests::test_parse_update_indented_diff ... ok
[INFO] [stdout] test parser::tests::test_parse_update_multiple_hunks ... ok
[INFO] [stdout] test parser::tests::test_parse_update_single_hunk ... ok
[INFO] [stdout] test parser::tests::test_parse_update_with_context_hint ... ok
[INFO] [stdout] test parser::tests::test_parse_update_with_move_to ... ok
[INFO] [stdout] test parser::tests::test_parse_view_alias_with_start_end ... ok
[INFO] [stdout] test parser::tests::test_parse_write_file ... ok
[INFO] [stdout] test patch_utils::tests::test_normalize_path_simple ... ok
[INFO] [stdout] test patch_utils::tests::test_paths_equivalent ... ok
[INFO] [stdout] test patch_utils::tests::test_success_rate_empty ... ok
[INFO] [stdout] test reader::tests::test_extract_go_function ... ok
[INFO] [stdout] test parser::tests::test_parse_indented_context ... ok
[INFO] [stdout] test applier::tests::test_validator_json_valid ... ok
[INFO] [stdout] test reader::tests::test_extract_python_def ... ok
[INFO] [stdout] test reader::tests::test_extract_missing_symbol ... ok
[INFO] [stdout] test applier::tests::test_validator_js_valid ... ok
[INFO] [stdout] test reader::tests::test_extract_rust_impl ... ok
[INFO] [stdout] test reader::tests::test_extract_typescript_function ... ok
[INFO] [stdout] test reader::tests::test_glob_no_matches ... ok
[INFO] [stdout] test reader::tests::test_glob_rejects_symlink ... ok
[INFO] [stdout] test reader::tests::test_glob_expansion ... ok
[INFO] [stdout] test reader::tests::test_line_range_basic ... ok
[INFO] [stdout] test reader::tests::test_glob_rejects_traversal ... ok
[INFO] [stdout] test reader::tests::test_line_range_limit_zero ... ok
[INFO] [stdout] test reader::tests::test_line_range_no_params ... ok
[INFO] [stdout] test reader::tests::test_line_range_offset_beyond_eof ... ok
[INFO] [stdout] test reader::tests::test_line_range_with_offset_mid ... ok
[INFO] [stdout] test server::tests::json_response_payload_includes_summary_and_operations ... ok
[INFO] [stdout] test server::tests::dry_run_preserves_filesystem_but_reads_staged_content ... ok
[INFO] [stdout] test applier::tests::test_fuzzy_match_normalized_whitespace ... ok
[INFO] [stdout] test server::tests::write_then_read_sees_staged_content_and_commits ... ok
[INFO] [stdout] test reader::tests::test_extract_rust_fn ... ok
[INFO] [stdout] test applier::tests::test_update_file_has_diff_and_match_info ... ok
[INFO] [stdout] test reader::tests::test_extract_multiple_symbols ... ok
[INFO] [stdout] test applier::tests::test_update_file_single_hunk ... ok
[INFO] [stdout] test applier::tests::test_large_file_fuzzy_skipped ... ok
[INFO] [stdout] test server::tests::tool_contract_docs_are_synchronized ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- server::tests::tool_contract_docs_are_synchronized stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'server::tests::tool_contract_docs_are_synchronized' (981) panicked at src/server.rs:1234:9:
[INFO] [stdout] assertion failed: tool_contract::PATCH_EXEC_DESCRIPTION.contains(&format!("Version: {}",
[INFO] [stdout]             tool_contract::VERSION))
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x57ecb26f91ba - std[e28293b1aa0f68bd]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x57ecb26f91ba - std[e28293b1aa0f68bd]::backtrace_rs::backtrace::trace_unsynchronized::<std[e28293b1aa0f68bd]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x57ecb26f91ba - std[e28293b1aa0f68bd]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x57ecb26f91ba - <<std[e28293b1aa0f68bd]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[c1f1a4ba060b9bfa]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x57ecb2710a1a - <core[c1f1a4ba060b9bfa]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x57ecb2710a1a - core[c1f1a4ba060b9bfa]::fmt::write
[INFO] [stdout]    6:     0x57ecb26fe0a2 - std[e28293b1aa0f68bd]::io::default_write_fmt::<alloc[fdfd2bd8633a6659]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x57ecb26fe0a2 - <alloc[fdfd2bd8633a6659]::vec::Vec<u8> as std[e28293b1aa0f68bd]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x57ecb26d462f - <std[e28293b1aa0f68bd]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x57ecb26d462f - std[e28293b1aa0f68bd]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x57ecb26ef3c9 - std[e28293b1aa0f68bd]::panicking::default_hook
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x57ecb220576c - <alloc[fdfd2bd8633a6659]::boxed::Box<dyn for<'a, 'b> core[c1f1a4ba060b9bfa]::ops::function::Fn<(&'a std[e28293b1aa0f68bd]::panic::PanicHookInfo<'b>,), Output = ()> + core[c1f1a4ba060b9bfa]::marker::Sync + core[c1f1a4ba060b9bfa]::marker::Send> as core[c1f1a4ba060b9bfa]::ops::function::Fn<(&std[e28293b1aa0f68bd]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/alloc/src/boxed.rs:2254:9
[INFO] [stdout]   12:     0x57ecb220576c - test[273d7611820c9051]::test_main_with_exit_callback::<test[273d7611820c9051]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x57ecb26ef642 - <alloc[fdfd2bd8633a6659]::boxed::Box<dyn for<'a, 'b> core[c1f1a4ba060b9bfa]::ops::function::Fn<(&'a std[e28293b1aa0f68bd]::panic::PanicHookInfo<'b>,), Output = ()> + core[c1f1a4ba060b9bfa]::marker::Sync + core[c1f1a4ba060b9bfa]::marker::Send> as core[c1f1a4ba060b9bfa]::ops::function::Fn<(&std[e28293b1aa0f68bd]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/alloc/src/boxed.rs:2254:9
[INFO] [stdout]   14:     0x57ecb26ef642 - std[e28293b1aa0f68bd]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x57ecb26d471a - std[e28293b1aa0f68bd]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x57ecb26cbd39 - std[e28293b1aa0f68bd]::sys::backtrace::__rust_end_short_backtrace::<std[e28293b1aa0f68bd]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x57ecb26d557d - __rustc[b7974e8690430dd9]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x57ecb271137c - core[c1f1a4ba060b9bfa]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x57ecb2711342 - core[c1f1a4ba060b9bfa]::panicking::panic
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/core/src/panicking.rs:150:5
[INFO] [stdout]   20:     0x57ecb2198683 - weave_patch_mcp::server::tests::tool_contract_docs_are_synchronized::h95be1cfc2ab9238b
[INFO] [stdout]                                at /opt/rustwide/workdir/src/server.rs:1234:9
[INFO] [stdout]   21:     0x57ecb2198bf7 - weave_patch_mcp::server::tests::tool_contract_docs_are_synchronized::{{closure}}::hf7d5afce30697a3e
[INFO] [stdout]                                at /opt/rustwide/workdir/src/server.rs:1230:45
[INFO] [stdout]   22:     0x57ecb21c97c6 - core::ops::function::FnOnce::call_once::h77446758d0fcf864
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x57ecb21f984b - <fn() -> core[c1f1a4ba060b9bfa]::result::Result<(), alloc[fdfd2bd8633a6659]::string::String> as core[c1f1a4ba060b9bfa]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x57ecb21f984b - test[273d7611820c9051]::__rust_begin_short_backtrace::<core[c1f1a4ba060b9bfa]::result::Result<(), alloc[fdfd2bd8633a6659]::string::String>, fn() -> core[c1f1a4ba060b9bfa]::result::Result<(), alloc[fdfd2bd8633a6659]::string::String>>
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x57ecb220623b - test[273d7611820c9051]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x57ecb220623b - <core[c1f1a4ba060b9bfa]::panic::unwind_safe::AssertUnwindSafe<test[273d7611820c9051]::run_test_in_process::{closure#0}> as core[c1f1a4ba060b9bfa]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x57ecb220623b - std[e28293b1aa0f68bd]::panicking::catch_unwind::do_call::<core[c1f1a4ba060b9bfa]::panic::unwind_safe::AssertUnwindSafe<test[273d7611820c9051]::run_test_in_process::{closure#0}>, core[c1f1a4ba060b9bfa]::result::Result<(), alloc[fdfd2bd8633a6659]::string::String>>
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x57ecb220623b - std[e28293b1aa0f68bd]::panicking::catch_unwind::<core[c1f1a4ba060b9bfa]::result::Result<(), alloc[fdfd2bd8633a6659]::string::String>, core[c1f1a4ba060b9bfa]::panic::unwind_safe::AssertUnwindSafe<test[273d7611820c9051]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x57ecb220623b - std[e28293b1aa0f68bd]::panic::catch_unwind::<core[c1f1a4ba060b9bfa]::panic::unwind_safe::AssertUnwindSafe<test[273d7611820c9051]::run_test_in_process::{closure#0}>, core[c1f1a4ba060b9bfa]::result::Result<(), alloc[fdfd2bd8633a6659]::string::String>>
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x57ecb220623b - test[273d7611820c9051]::run_test_in_process
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x57ecb220623b - test[273d7611820c9051]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x57ecb2201954 - test[273d7611820c9051]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x57ecb2201954 - std[e28293b1aa0f68bd]::sys::backtrace::__rust_begin_short_backtrace::<test[273d7611820c9051]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x57ecb2208e42 - std[e28293b1aa0f68bd]::thread::lifecycle::spawn_unchecked::<test[273d7611820c9051]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x57ecb2208e42 - <core[c1f1a4ba060b9bfa]::panic::unwind_safe::AssertUnwindSafe<std[e28293b1aa0f68bd]::thread::lifecycle::spawn_unchecked<test[273d7611820c9051]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[c1f1a4ba060b9bfa]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x57ecb2208e42 - std[e28293b1aa0f68bd]::panicking::catch_unwind::do_call::<core[c1f1a4ba060b9bfa]::panic::unwind_safe::AssertUnwindSafe<std[e28293b1aa0f68bd]::thread::lifecycle::spawn_unchecked<test[273d7611820c9051]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x57ecb2208e42 - std[e28293b1aa0f68bd]::panicking::catch_unwind::<(), core[c1f1a4ba060b9bfa]::panic::unwind_safe::AssertUnwindSafe<std[e28293b1aa0f68bd]::thread::lifecycle::spawn_unchecked<test[273d7611820c9051]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x57ecb2208e42 - std[e28293b1aa0f68bd]::panic::catch_unwind::<core[c1f1a4ba060b9bfa]::panic::unwind_safe::AssertUnwindSafe<std[e28293b1aa0f68bd]::thread::lifecycle::spawn_unchecked<test[273d7611820c9051]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x57ecb2208e42 - std[e28293b1aa0f68bd]::thread::lifecycle::spawn_unchecked::<test[273d7611820c9051]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x57ecb2208e42 - <std[e28293b1aa0f68bd]::thread::lifecycle::spawn_unchecked<test[273d7611820c9051]::run_test::{closure#1}, ()>::{closure#1} as core[c1f1a4ba060b9bfa]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x57ecb26f81bf - <alloc[fdfd2bd8633a6659]::boxed::Box<dyn core[c1f1a4ba060b9bfa]::ops::function::FnOnce<(), Output = ()> + core[c1f1a4ba060b9bfa]::marker::Send> as core[c1f1a4ba060b9bfa]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/alloc/src/boxed.rs:2240:9
[INFO] [stdout]   42:     0x57ecb26f81bf - <std[e28293b1aa0f68bd]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/59807616e1fa2540724bfbac14d7976d7e4a3860/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   43:     0x76869dabeaa4 - <unknown>
[INFO] [stdout]   44:     0x76869db4ba64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     server::tests::tool_contract_docs_are_synchronized
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 123 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.42s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "ae7bca8169ab89e2f96347938f84b5f5ebcdff4a331d9fe0ab2fd33c2c8b368f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ae7bca8169ab89e2f96347938f84b5f5ebcdff4a331d9fe0ab2fd33c2c8b368f", kill_on_drop: false }`
[INFO] [stdout] ae7bca8169ab89e2f96347938f84b5f5ebcdff4a331d9fe0ab2fd33c2c8b368f
