[INFO] cloning repository https://github.com/raiderrobert/graft [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/raiderrobert/graft" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fraiderrobert%2Fgraft", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fraiderrobert%2Fgraft'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] c74448488df314cdac80adb9997a2cdd61fe53c0 [INFO] testing raiderrobert/graft against try#dec9417b8611e34e787a3e4c37686b5131f9e5c5 for pr-154210 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fraiderrobert%2Fgraft" "/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/raiderrobert/graft [INFO] removed 0 missing tests [INFO] finished tweaking git repo https://github.com/raiderrobert/graft [INFO] tweaked toml for git repo https://github.com/raiderrobert/graft written to /workspace/builds/worker-4-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/raiderrobert/graft on toolchain dec9417b8611e34e787a3e4c37686b5131f9e5c5 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/raiderrobert/graft 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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 4da66b3ecd9ac4c285ce8a00e1f3f5b6414eb577f5278c690566cb3ac00cb57b [INFO] running `Command { std: "docker" "start" "-a" "4da66b3ecd9ac4c285ce8a00e1f3f5b6414eb577f5278c690566cb3ac00cb57b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "4da66b3ecd9ac4c285ce8a00e1f3f5b6414eb577f5278c690566cb3ac00cb57b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4da66b3ecd9ac4c285ce8a00e1f3f5b6414eb577f5278c690566cb3ac00cb57b", kill_on_drop: false }` [INFO] [stdout] 4da66b3ecd9ac4c285ce8a00e1f3f5b6414eb577f5278c690566cb3ac00cb57b [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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] aa9ed7b0fa79ed48749a3e939c7889e7bd8011f7cbf9c9d570eb6ee5186e9fe9 [INFO] running `Command { std: "docker" "start" "-a" "aa9ed7b0fa79ed48749a3e939c7889e7bd8011f7cbf9c9d570eb6ee5186e9fe9", kill_on_drop: false }` [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Compiling once_cell v1.21.4 [INFO] [stderr] Compiling futures-sink v0.3.32 [INFO] [stderr] Compiling cc v1.2.57 [INFO] [stderr] Compiling bitflags v2.11.0 [INFO] [stderr] Compiling rustix v1.1.4 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling tokio v1.50.0 [INFO] [stderr] Compiling slab v0.4.12 [INFO] [stderr] Compiling linux-raw-sys v0.12.1 [INFO] [stderr] Compiling futures-io v0.3.32 [INFO] [stderr] Compiling object v0.37.3 [INFO] [stderr] Compiling rustls v0.23.37 [INFO] [stderr] Compiling gimli v0.32.3 [INFO] [stderr] Compiling anstyle-parse v1.0.0 [INFO] [stderr] Compiling unicode-width v0.2.2 [INFO] [stderr] Compiling futures-channel v0.3.32 [INFO] [stderr] Compiling owo-colors v4.3.0 [INFO] [stderr] Compiling colorchoice v1.0.5 [INFO] [stderr] Compiling getrandom v0.4.2 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling anstyle v1.0.14 [INFO] [stderr] Compiling rustc-demangle v0.1.27 [INFO] [stderr] Compiling indexmap v2.13.0 [INFO] [stderr] Compiling clap_lex v1.1.0 [INFO] [stderr] Compiling anstream v1.0.0 [INFO] [stderr] Compiling is_ci v1.2.0 [INFO] [stderr] Compiling winnow v0.7.15 [INFO] [stderr] Compiling toml_write v0.1.2 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling textwrap v0.16.2 [INFO] [stderr] Compiling supports-color v3.0.2 [INFO] [stderr] Compiling clap_builder v4.6.0 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling filetime v0.2.27 [INFO] [stderr] Compiling supports-hyperlinks v3.2.0 [INFO] [stderr] Compiling supports-unicode v3.0.0 [INFO] [stderr] Compiling sha2 v0.10.9 [INFO] [stderr] Compiling dirs v6.0.0 [INFO] [stderr] Compiling console v0.15.11 [INFO] [stderr] Compiling semver v1.0.27 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling addr2line v0.25.1 [INFO] [stderr] Compiling xattr v1.6.1 [INFO] [stderr] Compiling terminal_size v0.4.3 [INFO] [stderr] Compiling tempfile v3.27.0 [INFO] [stderr] Compiling tar v0.4.44 [INFO] [stderr] Compiling backtrace v0.3.76 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling backtrace-ext v0.2.1 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling tower-http v0.6.8 [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 serde_derive v1.0.228 [INFO] [stderr] Compiling clap_derive v4.6.0 [INFO] [stderr] Compiling miette-derive v7.6.0 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling rustls-webpki v0.103.9 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling miette v7.6.0 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling clap v4.6.0 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling toml_edit v0.22.27 [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 toml v0.8.23 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling graft v0.1.3 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 57.44s [INFO] running `Command { std: "docker" "inspect" "aa9ed7b0fa79ed48749a3e939c7889e7bd8011f7cbf9c9d570eb6ee5186e9fe9", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "aa9ed7b0fa79ed48749a3e939c7889e7bd8011f7cbf9c9d570eb6ee5186e9fe9", kill_on_drop: false }` [INFO] [stdout] aa9ed7b0fa79ed48749a3e939c7889e7bd8011f7cbf9c9d570eb6ee5186e9fe9 [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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] eb5c500085ecff13da54c28ac9a7b1d5c6dbddcf6ce399018eeeb96611261301 [INFO] running `Command { std: "docker" "start" "-a" "eb5c500085ecff13da54c28ac9a7b1d5c6dbddcf6ce399018eeeb96611261301", kill_on_drop: false }` [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Compiling memchr v2.8.0 [INFO] [stderr] Compiling futures-sink v0.3.32 [INFO] [stderr] Compiling smawk v0.3.2 [INFO] [stderr] Compiling bytecount v0.6.9 [INFO] [stderr] Compiling either v1.15.0 [INFO] [stderr] Compiling rustc_version v0.4.1 [INFO] [stderr] Compiling clap_builder v4.6.0 [INFO] [stderr] Compiling toml_parser v1.0.9+spec-1.1.0 [INFO] [stderr] Compiling indexmap v2.13.0 [INFO] [stderr] Compiling regex-syntax v0.7.5 [INFO] [stderr] Compiling toml_datetime v1.0.0+spec-1.1.0 [INFO] [stderr] Compiling peg-runtime v0.6.3 [INFO] [stderr] Compiling glob v0.3.3 [INFO] [stderr] Compiling drain_filter_polyfill v0.1.3 [INFO] [stderr] Compiling inventory v0.3.22 [INFO] [stderr] Compiling futures-channel v0.3.32 [INFO] [stderr] Compiling textwrap v0.16.2 [INFO] [stderr] Compiling humantime v2.3.0 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling peg-macros v0.6.3 [INFO] [stderr] Compiling itertools v0.13.0 [INFO] [stderr] Compiling rstest_macros v0.23.0 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling object v0.37.3 [INFO] [stderr] Compiling bstr v1.12.1 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling nom v7.1.3 [INFO] [stderr] Compiling toml_edit v0.25.4+spec-1.1.0 [INFO] [stderr] Compiling peg v0.6.3 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling proc-macro-crate v3.5.0 [INFO] [stderr] Compiling nom_locate v4.2.0 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling globset v0.4.18 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling ignore v0.4.25 [INFO] [stderr] Compiling backtrace v0.3.76 [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 serde_derive v1.0.228 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling futures-macro v0.3.32 [INFO] [stderr] Compiling sealed v0.5.0 [INFO] [stderr] Compiling clap_derive v4.6.0 [INFO] [stderr] Compiling derive_more v0.99.20 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling miette-derive v7.6.0 [INFO] [stderr] Compiling typed-builder-macro v0.15.2 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling pin-project-internal v1.1.11 [INFO] [stderr] Compiling synthez-core v0.3.1 [INFO] [stderr] Compiling backtrace-ext v0.2.1 [INFO] [stderr] Compiling lazy-regex-proc_macros v3.6.0 [INFO] [stderr] Compiling globwalk v0.9.1 [INFO] [stderr] Compiling smart-default v0.7.1 [INFO] [stderr] Compiling miette v7.6.0 [INFO] [stderr] Compiling typed-builder v0.15.2 [INFO] [stderr] Compiling synthez-codegen v0.3.1 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling synthez v0.3.1 [INFO] [stderr] Compiling lazy-regex v3.6.0 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling clap v4.6.0 [INFO] [stderr] Compiling pin-project v1.1.11 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling cucumber-expressions v0.3.0 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling gherkin v0.14.0 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling toml_edit v0.22.27 [INFO] [stderr] Compiling cucumber-codegen v0.21.1 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling toml v0.8.23 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling futures-executor v0.3.32 [INFO] [stderr] Compiling futures v0.3.32 [INFO] [stderr] Compiling cucumber v0.21.1 [INFO] [stderr] Compiling rstest v0.23.0 [INFO] [stderr] Compiling tower-http v0.6.8 [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 hyper-rustls v0.27.7 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling graft v0.1.3 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 1m 03s [INFO] running `Command { std: "docker" "inspect" "eb5c500085ecff13da54c28ac9a7b1d5c6dbddcf6ce399018eeeb96611261301", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "eb5c500085ecff13da54c28ac9a7b1d5c6dbddcf6ce399018eeeb96611261301", kill_on_drop: false }` [INFO] [stdout] eb5c500085ecff13da54c28ac9a7b1d5c6dbddcf6ce399018eeeb96611261301 [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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 2be349ca8fbaac8dead2b67b3e567ab1e610a7fb304d56b830225468a8ba10fa [INFO] running `Command { std: "docker" "start" "-a" "2be349ca8fbaac8dead2b67b3e567ab1e610a7fb304d56b830225468a8ba10fa", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.45s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/graft-d8eb23c395876d61) [INFO] [stdout] [INFO] [stdout] running 62 tests [INFO] [stdout] test cache::tests::cache_miss_returns_none ... ok [INFO] [stdout] test cache::tests::different_commits_return_different_content ... ok [INFO] [stdout] test checksum::tests::checksum_bytes_returns_prefixed_hex ... ok [INFO] [stdout] test checksum::tests::directory_checksum_is_order_independent ... ok [INFO] [stdout] test cache::tests::put_then_get_returns_content ... ok [INFO] [stdout] test config::lockfile::tests::parse_empty_lockfile ... ok [INFO] [stdout] test cache::tests::nested_path_works ... ok [INFO] [stdout] test checksum::tests::checksum_file_on_disk_matches_checksum_bytes ... ok [INFO] [stdout] test checksum::tests::same_content_same_checksum ... ok [INFO] [stdout] test config::lockfile::tests::parse_valid_lockfile ... ok [INFO] [stdout] test config::manifest::tests::reject_dest_escaping_root::case_1 ... ok [INFO] [stdout] test config::manifest::tests::parse_bundle_dep_with_files ... ok [INFO] [stdout] test config::manifest::tests::parse_empty_manifest ... ok [INFO] [stdout] test config::manifest::tests::reject_dest_escaping_root::case_2 ... ok [INFO] [stdout] test config::manifest::tests::parse_single_dep ... ok [INFO] [stdout] test config::lockfile::tests::roundtrip_serialize_deserialize ... ok [INFO] [stdout] test config::manifest::tests::reject_dest_targeting_git::case_1 ... ok [INFO] [stdout] test config::manifest::tests::reject_dest_targeting_git::case_2 ... ok [INFO] [stdout] test config::manifest::tests::roundtrip_serialize_deserialize ... ok [INFO] [stdout] test config::manifest::tests::reject_dest_targeting_git::case_3 ... ok [INFO] [stdout] test config::manifest::tests::reject_duplicate_dest ... ok [INFO] [stdout] test github::client::tests::test_client_creation ... ok [INFO] [stdout] test checksum::tests::different_content_different_checksum ... ok [INFO] [stdout] test github::client::tests::test_client_creation_with_token ... ok [INFO] [stdout] test source::parse::tests::parse_rejects_invalid::case_1 ... ok [INFO] [stdout] test source::parse::tests::parse_rejects_invalid::case_2 ... ok [INFO] [stdout] test github::auth::tests::test_resolve_token_does_not_panic ... ok [INFO] [stdout] test source::parse::tests::parse_root_file ... ok [INFO] [stdout] test source::parse::tests::parse_single_file ... ok [INFO] [stdout] test source::parse::tests::parse_with_version_sha ... ok [INFO] [stdout] test source::parse::tests::parse_with_version_tag ... ok [INFO] [stdout] test source::parse::tests::roundtrip_to_source_string ... ok [INFO] [stdout] test source::tags::tests::find_newer_semver_tags ... ok [INFO] [stdout] test source::tags::tests::find_newer_tags_none_available ... ok [INFO] [stdout] test source::tags::tests::find_newer_tags_with_v_prefix_current ... ok [INFO] [stdout] test source::tags::tests::parse_annotated_tags_prefers_deref ... ok [INFO] [stdout] test source::tags::tests::parse_simple_tags ... ok [INFO] [stdout] test source::tags::tests::sort_mixed_semver_and_nonsemver ... ok [INFO] [stdout] test source::tags::tests::sort_semver_tags ... ok [INFO] [stdout] test source::version::tests::detects_sha::case_1 ... ok [INFO] [stdout] test source::version::tests::detects_sha::case_2 ... ok [INFO] [stdout] test source::version::tests::detects_tag::case_1 ... ok [INFO] [stdout] test source::parse::tests::parse_directory ... ok [INFO] [stdout] test source::version::tests::detects_tag::case_2 ... ok [INFO] [stdout] test source::version::tests::detects_tag::case_3 ... ok [INFO] [stdout] test source::version::tests::detects_tag::case_4 ... ok [INFO] [stdout] test state::tests::conflicted_file ... ok [INFO] [stdout] test state::tests::display_state::case_1 ... ok [INFO] [stdout] test state::tests::display_state::case_2 ... ok [INFO] [stdout] test state::tests::display_state::case_4 ... ok [INFO] [stdout] test state::tests::display_state::case_5 ... ok [INFO] [stdout] test state::tests::display_state::case_3 ... ok [INFO] [stdout] test state::tests::missing_file ... ok [INFO] [stdout] test state::tests::missing_no_lockfile_entry ... ok [INFO] [stdout] test state::tests::modified_file ... ok [INFO] [stdout] test state::tests::synced_file ... ok [INFO] [stdout] test state::tests::file_exists_but_no_lock_entry ... ok [INFO] [stdout] test merge::tests::ours_only_change ... ok [INFO] [stdout] test merge::tests::theirs_only_change ... ok [INFO] [stdout] test merge::tests::conflict_overlapping_changes ... ok [INFO] [stdout] test merge::tests::clean_merge_non_overlapping_changes ... ok [INFO] [stdout] test merge::tests::clean_merge_identical ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 62 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/graft-1d21270db281d7e7) [INFO] [stdout] [INFO] [stdout] running 7 tests [INFO] [stdout] test commands::add::tests::default_dest_from_source::case_1 ... ok [INFO] [stdout] test commands::add::tests::derive_name_from_path::case_2 ... ok [INFO] [stdout] test commands::add::tests::derive_name_from_path::case_4 ... ok [INFO] [stdout] test commands::add::tests::derive_name_from_path::case_3 ... ok [INFO] [stdout] test commands::add::tests::derive_name_from_path::case_1 ... ok [INFO] [stdout] test commands::add::tests::default_dest_from_source::case_3 ... ok [INFO] [stdout] test commands::add::tests::default_dest_from_source::case_2 ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 7 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stderr] Running tests/adopt.rs (/opt/rustwide/target/debug/deps/adopt-7127178f1f4980ef) [INFO] [stdout] [INFO] [stdout] running 5 tests [INFO] [stdout] test adopt_shows_modified_when_local_differs ... ok [INFO] [stdout] test list_shows_missing_when_file_absent ... ok [INFO] [stdout] test adopt_shows_synced_when_checksum_matches ... ok [INFO] [stdout] test check_passes_when_adopted_file_matches ... ok [INFO] [stdout] test check_fails_when_adopted_file_modified ... ok [INFO] [stderr] Running tests/bdd.rs (/opt/rustwide/target/debug/deps/bdd-7a1643396f5ffa56) [INFO] [stdout] [INFO] [stdout] test result: ok. 5 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s [INFO] [stdout] [INFO] [stdout] Feature: Add a file dependency from a GitHub repo [INFO] [stdout] Scenario: Add refuses when destination already exists [INFO] [stdout] ✔ Given an empty project directory with "graft.toml" [INFO] [stdout] ✔ And a file "Makefile" with content "existing content" [INFO] [stderr] Running tests/init.rs (/opt/rustwide/target/debug/deps/init-3f386e6a5e53b0e8) [INFO] [stdout] ✔ When I run "graft add gh:owner/repo/Makefile@v1.0.0 Makefile" [INFO] [stdout] ✔ Then the command should fail [INFO] [stdout] ✔ And stderr should contain "already exists" [INFO] [stdout] Scenario: Add rejects path traversal [INFO] [stdout] ✔ Given an empty project directory with "graft.toml" [INFO] [stdout] ✔ When I run "graft add gh:owner/repo/evil@v1.0.0 ../etc/passwd" [INFO] [stdout] ✔ Then the command should fail [INFO] [stdout] Scenario: Add rejects .git directory targets [INFO] [stdout] ✔ Given an empty project directory with "graft.toml" [INFO] [stdout] ✔ When I run "graft add gh:owner/repo/hook@v1.0.0 .git/hooks/pre-commit" [INFO] [stdout] ✔ Then the command should fail [INFO] [stdout] Scenario: Add rejects path traversal without graft.toml [INFO] [stdout] ✔ Given an empty project directory [INFO] [stdout] ✔ When I run "graft add gh:owner/repo/evil@v1.0.0 ../etc/passwd" [INFO] [stdout] ✔ Then the command should fail [INFO] [stdout] Feature: Check graft status for CI [INFO] [stdout] Scenario: Check succeeds with no grafts [INFO] [stdout] ✔ Given an empty project directory with "graft.toml" [INFO] [stdout] ✔ When I run "graft check" [INFO] [stdout] ✔ Then the exit code should be 0 [INFO] [stdout] Feature: Initialize a project with graft [INFO] [stdout] Scenario: Create a new graft.toml in an empty directory [INFO] [stdout] ✔ Given an empty project directory [INFO] [stdout] ✔ When I run "graft init" [INFO] [stdout] ✔ Then the command should succeed [INFO] [stdout] ✔ And a file "graft.toml" should exist [INFO] [stdout] ✔ And "graft.toml" should contain "# Graft" [INFO] [stdout] Scenario: Init is idempotent when graft.toml already exists [INFO] [stdout] ✔ Given an empty project directory [INFO] [stdout] ✔ And a file "graft.toml" with content "# my existing config" [INFO] [stdout] ✔ When I run "graft init" [INFO] [stdout] ✔ Then the command should succeed [INFO] [stdout] ✔ And "graft.toml" should contain "# my existing config" [INFO] [stdout] Feature: List grafts and their status [INFO] [stdout] Scenario: List with no grafts [INFO] [stdout] ✔ Given an empty project directory with "graft.toml" [INFO] [stdout] ✔ When I run "graft list" [INFO] [stdout] ✔ Then the command should succeed [INFO] [stdout] Feature: Check for outdated grafts [INFO] [stdout] Scenario: Outdated with no grafts [INFO] [stdout] ✔ Given an empty project directory with "graft.toml" [INFO] [stdout] ✔ When I run "graft outdated" [INFO] [stdout] ✔ Then the command should succeed [INFO] [stdout] Feature: Remove a graft [INFO] [stdout] Scenario: Remove nonexistent graft fails [INFO] [stdout] ✔ Given an empty project directory with "graft.toml" [INFO] [stdout] ✔ When I run "graft remove nonexistent" [INFO] [stdout] ✔ Then the command should fail [INFO] [stdout] Feature: Resolve conflicts after upgrade [INFO] [stdout] Scenario: Resolve nonexistent graft fails [INFO] [stdout] ✔ Given an empty project directory with "graft.toml" [INFO] [stdout] ✔ When I run "graft resolve nonexistent" [INFO] [stdout] ✔ Then the command should fail [INFO] [stdout] Feature: Upgrade grafts to newer versions [INFO] [stdout] Scenario: Upgrade with no grafts [INFO] [stdout] ✔ Given an empty project directory with "graft.toml" [INFO] [stdout] ✔ When I run "graft upgrade" [INFO] [stdout] ✔ Then the command should succeed [INFO] [stdout] [Summary] [INFO] [stdout] 8 features [INFO] [stdout] 12 scenarios (12 passed) [INFO] [stdout] 42 steps (42 passed) [INFO] [stdout] [INFO] [stdout] running 2 tests [INFO] [stdout] test test_init_idempotent ... ok [INFO] [stdout] test test_init_creates_manifest ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running tests/remove.rs (/opt/rustwide/target/debug/deps/remove-18e9fa44530de495) [INFO] [stdout] [INFO] [stdout] running 2 tests [INFO] [stdout] test test_remove_nonexistent ... ok [INFO] [stdout] test test_remove_keeps_local_file ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stderr] Doc-tests graft [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "2be349ca8fbaac8dead2b67b3e567ab1e610a7fb304d56b830225468a8ba10fa", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "2be349ca8fbaac8dead2b67b3e567ab1e610a7fb304d56b830225468a8ba10fa", kill_on_drop: false }` [INFO] [stdout] 2be349ca8fbaac8dead2b67b3e567ab1e610a7fb304d56b830225468a8ba10fa