[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 beta-2026-04-21 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-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/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-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/tuanhung303/weave-patch-mcp 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] 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" "+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-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" "+beta-2026-04-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] b9e3f61a779b9d70692a2b679cf3ff38c18c8d90cae05b8620daa609e9d56fd4
[INFO] running `Command { std: "docker" "start" "-a" "b9e3f61a779b9d70692a2b679cf3ff38c18c8d90cae05b8620daa609e9d56fd4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "b9e3f61a779b9d70692a2b679cf3ff38c18c8d90cae05b8620daa609e9d56fd4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b9e3f61a779b9d70692a2b679cf3ff38c18c8d90cae05b8620daa609e9d56fd4", kill_on_drop: false }`
[INFO] [stdout] b9e3f61a779b9d70692a2b679cf3ff38c18c8d90cae05b8620daa609e9d56fd4
[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=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] c6c4a6da1115daf5922e170d6e70a82753773f8e1fe2fb9b1c02b8a5015e2639
[INFO] running `Command { std: "docker" "start" "-a" "c6c4a6da1115daf5922e170d6e70a82753773f8e1fe2fb9b1c02b8a5015e2639", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.184
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling strsim v0.11.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling futures-channel v0.3.32
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling futures-io v0.3.32
[INFO] [stderr]    Compiling ref-cast v1.0.25
[INFO] [stderr]    Compiling slab v0.4.12
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]    Compiling option-ext v0.2.0
[INFO] [stderr]    Compiling num-conv v0.2.1
[INFO] [stderr]    Compiling time-core v0.1.8
[INFO] [stderr]    Compiling dyn-clone v1.0.20
[INFO] [stderr]    Compiling rmcp v1.3.0
[INFO] [stderr]    Compiling time v0.3.47
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling pastey v0.2.1
[INFO] [stderr]    Compiling rayon v1.11.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling mio v1.2.0
[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 similar v2.7.0
[INFO] [stderr]    Compiling glob v0.3.3
[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 futures-macro v0.3.32
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling tokio-macros v2.7.0
[INFO] [stderr]    Compiling ref-cast-impl v1.0.25
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling schemars_derive v1.2.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling tokio v1.51.0
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling tracing-subscriber v0.3.23
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling thiserror v1.0.69
[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 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 42s
[INFO] running `Command { std: "docker" "inspect" "c6c4a6da1115daf5922e170d6e70a82753773f8e1fe2fb9b1c02b8a5015e2639", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c6c4a6da1115daf5922e170d6e70a82753773f8e1fe2fb9b1c02b8a5015e2639", kill_on_drop: false }`
[INFO] [stdout] c6c4a6da1115daf5922e170d6e70a82753773f8e1fe2fb9b1c02b8a5015e2639
[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=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] 8b27d9086fd4311ff3bb1e71ec2744364a72c9fe3dc84f19aca6f4b55b82b910
[INFO] running `Command { std: "docker" "start" "-a" "8b27d9086fd4311ff3bb1e71ec2744364a72c9fe3dc84f19aca6f4b55b82b910", 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.40s
[INFO] running `Command { std: "docker" "inspect" "8b27d9086fd4311ff3bb1e71ec2744364a72c9fe3dc84f19aca6f4b55b82b910", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8b27d9086fd4311ff3bb1e71ec2744364a72c9fe3dc84f19aca6f4b55b82b910", kill_on_drop: false }`
[INFO] [stdout] 8b27d9086fd4311ff3bb1e71ec2744364a72c9fe3dc84f19aca6f4b55b82b910
[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=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] e1a592e75f6960929043ade1017e3b86d647d98bfc92ceff3964d4226a82c37e
[INFO] running `Command { std: "docker" "start" "-a" "e1a592e75f6960929043ade1017e3b86d647d98bfc92ceff3964d4226a82c37e", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.28s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/weave_patch_mcp-91db1ab197f0adcb)
[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_old_status_migration ... ok
[INFO] [stdout] test applier::opstatus_serde_tests::test_opstatus_default ... ok
[INFO] [stdout] test applier::tests::test_create_file ... ok
[INFO] [stdout] test applier::tests::test_create_file_nested ... ok
[INFO] [stdout] test applier::opstatus_serde_tests::test_opstatus_serialization ... ok
[INFO] [stdout] test applier::tests::test_cross_file_atomicity_success ... ok
[INFO] [stdout] test applier::tests::test_delete_file_has_line_changes ... ok
[INFO] [stdout] test applier::tests::test_error_context_not_found ... ok
[INFO] [stdout] test applier::tests::test_error_file_not_found_for_update ... ok
[INFO] [stdout] test applier::tests::test_error_file_not_found_reports_absolute_path_source ... ok
[INFO] [stdout] test applier::tests::test_error_file_not_found_suggests_similar_files ... 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_find_similar_files_nonexistent_directory ... ok
[INFO] [stdout] test applier::tests::test_find_similar_files_ignores_directories ... ok
[INFO] [stdout] test applier::tests::test_absolute_path_add_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_create_file_has_diff ... ok
[INFO] [stdout] test applier::tests::test_levenshtein_distance_empty_strings ... ok
[INFO] [stdout] test applier::tests::test_find_similar_files_finds_similar ... ok
[INFO] [stdout] test applier::tests::test_delete_file ... ok
[INFO] [stdout] test applier::tests::test_cross_file_atomicity_rollback ... ok
[INFO] [stdout] test applier::tests::test_levenshtein_distance_identical ... 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_file_dest_exists ... ok
[INFO] [stdout] test applier::tests::test_move_atomic_rollback_on_batch_failure ... ok
[INFO] [stdout] test applier::tests::test_move_file_success ... ok
[INFO] [stdout] test applier::tests::test_move_file_source_not_found ... ok
[INFO] [stdout] test applier::tests::test_move_file_symlink_rejected ... ok
[INFO] [stdout] test applier::tests::test_multi_file_patch ... ok
[INFO] [stdout] test applier::tests::test_path_traversal_add_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_path_traversal_delete_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_read_file_not_found ... ok
[INFO] [stdout] test applier::tests::test_read_file_path_traversal_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_resolve_path_absolute ... ok
[INFO] [stdout] test applier::tests::test_read_file_validates_path ... ok
[INFO] [stdout] test applier::tests::test_resolve_path_home_expanded ... ok
[INFO] [stdout] test applier::tests::test_nested_path_traversal_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_resolve_path_relative_existing ... ok
[INFO] [stdout] test applier::tests::test_shadow_file_cleaned_up_on_failure ... 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_symlink_delete_rejected ... ok
[INFO] [stdout] test applier::tests::test_symlink_update_rejected ... ok
[INFO] [stdout] test applier::tests::test_structured_error_closest_matches ... ok
[INFO] [stdout] test applier::tests::test_validator_go_extension ... ok
[INFO] [stdout] test applier::tests::test_backslash_path_now_allowed ... ok
[INFO] [stdout] test applier::tests::test_validator_json_invalid ... ok
[INFO] [stdout] test applier::tests::test_fuzzy_match_normalized_whitespace ... ok
[INFO] [stdout] test applier::tests::test_validator_sh_invalid ... ok
[INFO] [stdout] test applier::tests::test_update_file_has_diff_and_match_info ... 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_validator_sh_valid ... 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 parser::tests::test_parse_apply_patch_delete_file_block ... 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_auto_wrap_missing_begin ... ok
[INFO] [stdout] test parser::tests::test_parse_auto_wrap_missing_end ... 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_indented_context ... 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 applier::tests::test_write_then_update_uses_staged_content ... 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 applier::tests::test_update_file_single_hunk ... ok
[INFO] [stdout] test reader::tests::test_extract_python_def ... ok
[INFO] [stdout] test reader::tests::test_extract_missing_symbol ... ok
[INFO] [stdout] test reader::tests::test_extract_rust_fn ... ok
[INFO] [stdout] test applier::tests::test_validator_json_valid ... ok
[INFO] [stdout] test reader::tests::test_extract_rust_impl ... ok
[INFO] [stdout] test reader::tests::test_glob_no_matches ... ok
[INFO] [stdout] test reader::tests::test_glob_rejects_symlink ... ok
[INFO] [stdout] test applier::tests::test_fuzzy_match_similarity_threshold ... ok
[INFO] [stdout] test reader::tests::test_line_range_basic ... ok
[INFO] [stdout] test reader::tests::test_glob_expansion ... ok
[INFO] [stdout] test reader::tests::test_line_range_limit_zero ... ok
[INFO] [stdout] test reader::tests::test_line_range_offset_beyond_eof ... ok
[INFO] [stdout] test reader::tests::test_line_range_no_params ... ok
[INFO] [stdout] test reader::tests::test_line_range_with_offset_mid ... ok
[INFO] [stdout] test reader::tests::test_glob_rejects_traversal ... ok
[INFO] [stdout] test server::tests::json_response_payload_includes_summary_and_operations ... ok
[INFO] [stdout] test server::tests::write_then_read_sees_staged_content_and_commits ... ok
[INFO] [stdout] test server::tests::dry_run_preserves_filesystem_but_reads_staged_content ... ok
[INFO] [stdout] test reader::tests::test_extract_multiple_symbols ... ok
[INFO] [stdout] test reader::tests::test_extract_typescript_function ... ok
[INFO] [stdout] test applier::tests::test_update_file_multiple_hunks ... ok
[INFO] [stdout] test server::tests::tool_contract_docs_are_synchronized ... FAILED
[INFO] [stdout] test applier::tests::test_large_file_fuzzy_skipped ... ok
[INFO] [stdout] test applier::tests::test_validator_js_valid ... ok
[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' (983) 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:     0x577a7b5f7a3a - 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:     0x577a7b5f7a3a - std[128c3efe2914e152]::backtrace_rs::backtrace::trace_unsynchronized::<std[128c3efe2914e152]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x577a7b5f7a3a - std[128c3efe2914e152]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x577a7b5f7a3a - <<std[128c3efe2914e152]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[6771d259883166e6]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x577a7b60f25a - <core[6771d259883166e6]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x577a7b60f25a - core[6771d259883166e6]::fmt::write
[INFO] [stdout]    6:     0x577a7b5fc912 - std[128c3efe2914e152]::io::default_write_fmt::<alloc[fef50e8eecedd288]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/io/mod.rs:621:11
[INFO] [stdout]    7:     0x577a7b5fc912 - <alloc[fef50e8eecedd288]::vec::Vec<u8> as std[128c3efe2914e152]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/io/mod.rs:1976:13
[INFO] [stdout]    8:     0x577a7b5d2e2f - <std[128c3efe2914e152]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x577a7b5d2e2f - std[128c3efe2914e152]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x577a7b5edb39 - std[128c3efe2914e152]::panicking::default_hook
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x577a7b0fad8c - <alloc[fef50e8eecedd288]::boxed::Box<dyn for<'a, 'b> 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:     0x577a7b0fad8c - test[b137923399915ecf]::test_main_with_exit_callback::<test[b137923399915ecf]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x577a7b5eddb2 - <alloc[fef50e8eecedd288]::boxed::Box<dyn for<'a, 'b> 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:     0x577a7b5eddb2 - std[128c3efe2914e152]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x577a7b5d2f1a - std[128c3efe2914e152]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x577a7b5c7da9 - std[128c3efe2914e152]::sys::backtrace::__rust_end_short_backtrace::<std[128c3efe2914e152]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x577a7b5d3d7d - __rustc[752cc74e29381ccc]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x577a7b60fa9c - core[6771d259883166e6]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x577a7b60fa62 - core[6771d259883166e6]::panicking::panic
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/panicking.rs:150:5
[INFO] [stdout]   20:     0x577a7afe1213 - weave_patch_mcp::server::tests::tool_contract_docs_are_synchronized::h1eb6d67b11f80a63
[INFO] [stdout]                                at /opt/rustwide/workdir/src/server.rs:1234:9
[INFO] [stdout]   21:     0x577a7afe1787 - weave_patch_mcp::server::tests::tool_contract_docs_are_synchronized::{{closure}}::h9975c3579f39ddba
[INFO] [stdout]                                at /opt/rustwide/workdir/src/server.rs:1230:45
[INFO] [stdout]   22:     0x577a7b08f406 - core::ops::function::FnOnce::call_once::h158b79979af3c0cb
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x577a7b0eee8b - <fn() -> 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]   24:     0x577a7b0eee8b - test[b137923399915ecf]::__rust_begin_short_backtrace::<core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String>, fn() -> core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String>>
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x577a7b0fb85b - test[b137923399915ecf]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x577a7b0fb85b - <core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe<test[b137923399915ecf]::run_test_in_process::{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]   27:     0x577a7b0fb85b - std[128c3efe2914e152]::panicking::catch_unwind::do_call::<core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe<test[b137923399915ecf]::run_test_in_process::{closure#0}>, core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String>>
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x577a7b0fb85b - std[128c3efe2914e152]::panicking::catch_unwind::<core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String>, core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe<test[b137923399915ecf]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x577a7b0fb85b - std[128c3efe2914e152]::panic::catch_unwind::<core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe<test[b137923399915ecf]::run_test_in_process::{closure#0}>, core[6771d259883166e6]::result::Result<(), alloc[fef50e8eecedd288]::string::String>>
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x577a7b0fb85b - test[b137923399915ecf]::run_test_in_process
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x577a7b0fb85b - test[b137923399915ecf]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x577a7b0f5cb4 - test[b137923399915ecf]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x577a7b0f5cb4 - std[128c3efe2914e152]::sys::backtrace::__rust_begin_short_backtrace::<test[b137923399915ecf]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x577a7b0fe462 - std[128c3efe2914e152]::thread::lifecycle::spawn_unchecked::<test[b137923399915ecf]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x577a7b0fe462 - <core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe<std[128c3efe2914e152]::thread::lifecycle::spawn_unchecked<test[b137923399915ecf]::run_test::{closure#1}, ()>::{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]   36:     0x577a7b0fe462 - std[128c3efe2914e152]::panicking::catch_unwind::do_call::<core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe<std[128c3efe2914e152]::thread::lifecycle::spawn_unchecked<test[b137923399915ecf]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x577a7b0fe462 - std[128c3efe2914e152]::panicking::catch_unwind::<(), core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe<std[128c3efe2914e152]::thread::lifecycle::spawn_unchecked<test[b137923399915ecf]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x577a7b0fe462 - std[128c3efe2914e152]::panic::catch_unwind::<core[6771d259883166e6]::panic::unwind_safe::AssertUnwindSafe<std[128c3efe2914e152]::thread::lifecycle::spawn_unchecked<test[b137923399915ecf]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x577a7b0fe462 - std[128c3efe2914e152]::thread::lifecycle::spawn_unchecked::<test[b137923399915ecf]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x577a7b0fe462 - <std[128c3efe2914e152]::thread::lifecycle::spawn_unchecked<test[b137923399915ecf]::run_test::{closure#1}, ()>::{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]   41:     0x577a7b5f6a3f - <alloc[fef50e8eecedd288]::boxed::Box<dyn core[6771d259883166e6]::ops::function::FnOnce<(), Output = ()> + 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]   42:     0x577a7b5f6a3f - <std[128c3efe2914e152]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/8489f1adbe1c8f8921cf18b9962cf565237a5489/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   43:     0x72ae81c33aa4 - <unknown>
[INFO] [stdout]   44:     0x72ae81cc0a64 - 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.22s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "e1a592e75f6960929043ade1017e3b86d647d98bfc92ceff3964d4226a82c37e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e1a592e75f6960929043ade1017e3b86d647d98bfc92ceff3964d4226a82c37e", kill_on_drop: false }`
[INFO] [stdout] e1a592e75f6960929043ade1017e3b86d647d98bfc92ceff3964d4226a82c37e
