[INFO] fetching crate watcher-knight 0.1.1... [INFO] testing watcher-knight-0.1.1 against master#562dee4820c458d823175268e41601d4c060588a for pr-154210-2 [INFO] extracting crate watcher-knight 0.1.1 into /workspace/builds/worker-4-tc1/source [INFO] started tweaking crates.io crate watcher-knight 0.1.1 [INFO] removed 0 missing tests [INFO] finished tweaking crates.io crate watcher-knight 0.1.1 [INFO] tweaked toml for crates.io crate watcher-knight 0.1.1 written to /workspace/builds/worker-4-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate watcher-knight 0.1.1 on toolchain 562dee4820c458d823175268e41601d4c060588a [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate watcher-knight 0.1.1 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" "+562dee4820c458d823175268e41601d4c060588a" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [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" "+562dee4820c458d823175268e41601d4c060588a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 21828c3077e105270e136b9c67816b48531e70c573a33638ac3a05a801784fd4 [INFO] running `Command { std: "docker" "start" "-a" "21828c3077e105270e136b9c67816b48531e70c573a33638ac3a05a801784fd4", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "21828c3077e105270e136b9c67816b48531e70c573a33638ac3a05a801784fd4", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "21828c3077e105270e136b9c67816b48531e70c573a33638ac3a05a801784fd4", kill_on_drop: false }` [INFO] [stdout] 21828c3077e105270e136b9c67816b48531e70c573a33638ac3a05a801784fd4 [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=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" "+562dee4820c458d823175268e41601d4c060588a" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] eed2fd290bbf83f549850a7f936378582d6b4e2bf697999f508aa05d78eafc8c [INFO] running `Command { std: "docker" "start" "-a" "eed2fd290bbf83f549850a7f936378582d6b4e2bf697999f508aa05d78eafc8c", kill_on_drop: false }` [INFO] [stderr] Compiling percent-encoding v2.3.2 [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Compiling clap_builder v4.5.60 [INFO] [stderr] Compiling glob v0.3.3 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling form_urlencoded v1.2.2 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Compiling libz-sys v1.1.24 [INFO] [stderr] Compiling openssl-sys v0.9.111 [INFO] [stderr] Compiling libssh2-sys v0.3.1 [INFO] [stderr] Compiling libgit2-sys v0.18.3+1.9.2 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling clap_derive v4.5.55 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling clap v4.5.60 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling git2 v0.20.4 [INFO] [stderr] Compiling watcher-knight v0.1.1 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 35.50s [INFO] running `Command { std: "docker" "inspect" "eed2fd290bbf83f549850a7f936378582d6b4e2bf697999f508aa05d78eafc8c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "eed2fd290bbf83f549850a7f936378582d6b4e2bf697999f508aa05d78eafc8c", kill_on_drop: false }` [INFO] [stdout] eed2fd290bbf83f549850a7f936378582d6b4e2bf697999f508aa05d78eafc8c [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=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" "+562dee4820c458d823175268e41601d4c060588a" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 0eada5de5f1b2ad0d79ac0125e05160069b2b23f0676e29ea7246f79fb0b7fcf [INFO] running `Command { std: "docker" "start" "-a" "0eada5de5f1b2ad0d79ac0125e05160069b2b23f0676e29ea7246f79fb0b7fcf", kill_on_drop: false }` [INFO] [stderr] Compiling rustix v1.1.4 [INFO] [stderr] Compiling once_cell v1.21.4 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling git2 v0.20.4 [INFO] [stderr] Compiling tempfile v3.27.0 [INFO] [stderr] Compiling watcher-knight v0.1.1 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 7.11s [INFO] running `Command { std: "docker" "inspect" "0eada5de5f1b2ad0d79ac0125e05160069b2b23f0676e29ea7246f79fb0b7fcf", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "0eada5de5f1b2ad0d79ac0125e05160069b2b23f0676e29ea7246f79fb0b7fcf", kill_on_drop: false }` [INFO] [stdout] 0eada5de5f1b2ad0d79ac0125e05160069b2b23f0676e29ea7246f79fb0b7fcf [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=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" "+562dee4820c458d823175268e41601d4c060588a" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] f207086fdb3c43a6f31271cc2bea9b8beda9b15ffd04fa2bb8b273f8ed3df326 [INFO] running `Command { std: "docker" "start" "-a" "f207086fdb3c43a6f31271cc2bea9b8beda9b15ffd04fa2bb8b273f8ed3df326", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.12s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/watcher_knight-2b7546aeaa095962) [INFO] [stdout] [INFO] [stdout] running 117 tests [INFO] [stdout] test cache::tests::cache_key_unique_per_name ... ok [INFO] [stdout] test cache::tests::cache_entry_with_reason ... ok [INFO] [stdout] test cache::tests::build_entry_valid_result ... ok [INFO] [stdout] test cache::tests::cache_deserialization_corrupt_json ... ok [INFO] [stdout] test cache::tests::build_entry_failed_result ... ok [INFO] [stdout] test cache::tests::cache_deserialization_empty_json ... ok [INFO] [stdout] test cache::tests::cache_key_format ... ok [INFO] [stdout] test cache::tests::cache_key_unique_per_path ... ok [INFO] [stdout] test cache::tests::cache_serialization_roundtrip ... ok [INFO] [stdout] test cache::tests::check_cache_miss_unscoped_marker ... ok [INFO] [stdout] test cache::tests::check_cache_miss_empty_cache ... ok [INFO] [stdout] test cache::tests::hash_string_deterministic ... ok [INFO] [stdout] test cache::tests::hash_string_empty ... ok [INFO] [stdout] test cache::tests::hash_string_different_inputs ... ok [INFO] [stdout] test cache::tests::marker_content_hash_changes_on_options_change ... ok [INFO] [stdout] test cache::tests::marker_content_hash_deterministic ... ok [INFO] [stdout] test cache::tests::marker_content_hash_ignores_name_and_path ... ok [INFO] [stdout] test claude::tests::extract_json_multiple_objects_returns_first ... ok [INFO] [stdout] test claude::tests::extract_json_nested_braces ... ok [INFO] [stdout] test claude::tests::extract_json_empty_object ... ok [INFO] [stdout] test claude::tests::extract_json_unclosed_brace ... ok [INFO] [stdout] test cache::tests::build_entry_file_hashes_populated ... ok [INFO] [stdout] test cache::tests::check_cache_miss_instruction_changed ... ok [INFO] [stdout] test cache::tests::hash_watched_files_deterministic ... ok [INFO] [stdout] test claude::tests::extract_json_simple_object ... ok [INFO] [stdout] test claude::tests::extract_json_no_braces ... ok [INFO] [stdout] test cache::tests::hash_watched_files_empty_files ... ok [INFO] [stdout] test cache::tests::hash_watched_files_existing ... ok [INFO] [stdout] test cache::tests::hash_watched_files_missing_file_skipped ... ok [INFO] [stdout] test cache::tests::marker_content_hash_changes_on_instruction_change ... ok [INFO] [stdout] test cache::tests::marker_content_hash_options_order_independent ... ok [INFO] [stdout] test cache::tests::check_cache_hit_valid ... ok [INFO] [stdout] test claude::tests::extract_json_with_surrounding_text ... ok [INFO] [stdout] test claude::tests::parse_response_empty_string ... ok [INFO] [stdout] test claude::tests::parse_response_missing_is_valid_field ... ok [INFO] [stdout] test claude::tests::parse_response_is_valid_not_bool ... ok [INFO] [stdout] test claude::tests::parse_response_json_embedded_in_prose ... ok [INFO] [stdout] test cache::tests::check_cache_miss_file_added_to_scope ... ok [INFO] [stdout] test cache::tests::check_cache_miss_file_content_changed ... ok [INFO] [stdout] test claude::tests::parse_response_name_and_location_propagated ... ok [INFO] [stdout] test claude::tests::parse_response_non_json_text ... ok [INFO] [stdout] test claude::tests::parse_response_valid_true ... ok [INFO] [stdout] test claude::tests::parse_response_valid_false_with_reason ... ok [INFO] [stdout] test marker::tests::detect_comment_prefix_only_whitespace ... ok [INFO] [stdout] test marker::tests::error_display_format ... ok [INFO] [stdout] test marker::tests::error_malformed_options_line_number ... ok [INFO] [stdout] test marker::tests::error_missing_colon ... ok [INFO] [stdout] test marker::tests::example_backend_parses_without_errors ... ok [INFO] [stdout] test claude::tests::parse_response_valid_false_no_reason ... ok [INFO] [stdout] test marker::tests::detect_comment_prefix_empty_string ... ok [INFO] [stdout] test marker::tests::detect_comment_prefix_works ... ok [INFO] [stdout] test marker::tests::double_dash_comment_style ... ok [INFO] [stdout] test marker::tests::error_empty_instruction ... ok [INFO] [stdout] test marker::tests::error_malformed_options ... ok [INFO] [stdout] test marker::tests::error_missing_name ... ok [INFO] [stdout] test marker::tests::error_unclosed_file_list ... ok [INFO] [stdout] test marker::tests::error_unclosed_tag_multiline ... ok [INFO] [stdout] test marker::tests::extract_raw_tags_bare_tag_no_comment ... ok [INFO] [stdout] test claude::tests::parse_response_valid_true_ignores_reason ... ok [INFO] [stdout] test marker::tests::error_unclosed_tag ... ok [INFO] [stdout] test marker::tests::example_frontend_parses_markers ... ok [INFO] [stdout] test marker::tests::extract_raw_tags_close_on_own_line ... ok [INFO] [stdout] test marker::tests::extract_raw_tags_empty_file ... ok [INFO] [stdout] test marker::tests::find_tag_at_start_of_line ... ok [INFO] [stdout] test marker::tests::find_tag_multiple_occurrences_returns_first ... ok [INFO] [stdout] test marker::tests::find_tag_rejects_partial_match ... ok [INFO] [stdout] test marker::tests::mixed_valid_and_invalid ... ok [INFO] [stdout] test marker::tests::indented_marker ... ok [INFO] [stdout] test marker::tests::find_tag_accepts_valid ... ok [INFO] [stdout] test marker::tests::no_markers_in_file ... ok [INFO] [stdout] test marker::tests::multi_line_basic ... ok [INFO] [stdout] test marker::tests::no_space_after_colon ... ok [INFO] [stdout] test marker::tests::name_with_underscores ... ok [INFO] [stdout] test marker::tests::nom_name_numeric_start ... ok [INFO] [stdout] test marker::tests::nom_options_empty_pairs ... ok [INFO] [stdout] test marker::tests::nom_file_list_with_extra_spaces ... ok [INFO] [stdout] test claude::tests::extract_json_empty_input ... ok [INFO] [stdout] test marker::tests::find_tag_at_end_of_line ... ok [INFO] [stdout] test marker::tests::find_tag_followed_by_whitespace ... ok [INFO] [stdout] test marker::tests::multiple_markers_in_one_file ... ok [INFO] [stdout] test marker::tests::hash_comment_style ... ok [INFO] [stdout] test marker::tests::find_tag_rejects_watcher_knight ... ok [INFO] [stdout] test marker::tests::multi_line_with_options ... ok [INFO] [stdout] test marker::tests::multi_line_with_files_and_instruction ... ok [INFO] [stdout] test marker::tests::nom_parse_name_valid ... ok [INFO] [stdout] test marker::tests::nom_parse_options_multiple ... ok [INFO] [stdout] test marker::tests::nom_options_with_spaces ... ok [INFO] [stdout] test marker::tests::normalize_path_multiple_parent_dirs ... ok [INFO] [stdout] test marker::tests::nom_parse_options_valid ... ok [INFO] [stdout] test marker::tests::nom_parse_file_list_single ... ok [INFO] [stdout] test marker::tests::normalize_path_empty ... ok [INFO] [stdout] test marker::tests::normalize_path_no_special_components ... ok [INFO] [stdout] test marker::tests::normalize_path_resolves_dots ... ok [INFO] [stdout] test marker::tests::parse_instruction_only_whitespace ... ok [INFO] [stdout] test marker::tests::parse_line_number_multiline_later_in_file ... ok [INFO] [stdout] test marker::tests::parse_options_on_first_body_line ... ok [INFO] [stdout] test marker::tests::parse_multiple_body_lines_as_instruction ... ok [INFO] [stdout] test marker::tests::parse_rel_path_propagated ... ok [INFO] [stdout] test prompt::tests::prompt_diff_with_trailing_newline_no_double ... ok [INFO] [stdout] test prompt::tests::prompt_diff_without_trailing_newline_adds_one ... ok [INFO] [stdout] test marker::tests::percent_comment_style ... ok [INFO] [stdout] test marker::tests::semicolon_comment_style ... ok [INFO] [stdout] test marker::tests::single_line_basic ... ok [INFO] [stdout] test prompt::tests::prompt_no_diff_has_no_diff_section ... ok [INFO] [stdout] test prompt::tests::prompt_no_diff_instruction_text ... ok [INFO] [stdout] test marker::tests::single_line_with_files ... ok [INFO] [stdout] test marker::tests::strip_continuation_empty_line ... ok [INFO] [stdout] test marker::tests::strip_continuation_no_comment_prefix ... ok [INFO] [stdout] test prompt::tests::prompt_with_diff_has_diff_section ... ok [INFO] [stdout] test marker::tests::strip_continuation_prefix_only_line ... ok [INFO] [stdout] test marker::tests::strip_continuation_missing_expected_prefix ... ok [INFO] [stdout] test prompt::tests::prompt_contains_json_format ... ok [INFO] [stdout] test prompt::tests::prompt_contains_marker_fields ... ok [INFO] [stdout] test prompt::tests::prompt_diff_empty_string ... ok [INFO] [stdout] test marker::tests::nom_parse_file_list_valid ... ok [INFO] [stderr] Running tests/integration.rs (/opt/rustwide/target/debug/deps/integration-01213f20da877ee8) [INFO] [stdout] test marker::tests::wk_in_non_tag_context_ignored ... ok [INFO] [stdout] test prompt::tests::prompt_with_diff_instruction_text ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 117 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 5 tests [INFO] [stdout] test cli_run_no_markers_empty_dir ... ok [INFO] [stdout] test cli_run_file_not_dir ... ok [INFO] [stdout] test cli_run_nonexistent_dir ... ok [INFO] [stdout] test cli_help_flag ... ok [INFO] [stdout] test cli_run_help ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 5 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "f207086fdb3c43a6f31271cc2bea9b8beda9b15ffd04fa2bb8b273f8ed3df326", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f207086fdb3c43a6f31271cc2bea9b8beda9b15ffd04fa2bb8b273f8ed3df326", kill_on_drop: false }` [INFO] [stdout] f207086fdb3c43a6f31271cc2bea9b8beda9b15ffd04fa2bb8b273f8ed3df326