[INFO] cloning repository https://github.com/AptS-1547/gcop-rs [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/AptS-1547/gcop-rs" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAptS-1547%2Fgcop-rs", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAptS-1547%2Fgcop-rs'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 41b3380e9d353b7ea338f1a396c47ae0241f455b [INFO] testing AptS-1547/gcop-rs against try#8da20828b6ea601dfd8e2448cb50ace88876bd78 for pr-150933 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAptS-1547%2Fgcop-rs" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'... [INFO] [stderr] done. [INFO] removed /workspace/builds/worker-5-tc2/source/rust-toolchain.toml [INFO] started tweaking git repo https://github.com/AptS-1547/gcop-rs [INFO] finished tweaking git repo https://github.com/AptS-1547/gcop-rs [INFO] tweaked toml for git repo https://github.com/AptS-1547/gcop-rs written to /workspace/builds/worker-5-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/AptS-1547/gcop-rs on toolchain 8da20828b6ea601dfd8e2448cb50ace88876bd78 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/AptS-1547/gcop-rs 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" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 1f41da659dc1ab45f1e67305dabda1e47902423338086253acc8372075360ddc [INFO] running `Command { std: "docker" "start" "-a" "1f41da659dc1ab45f1e67305dabda1e47902423338086253acc8372075360ddc", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "1f41da659dc1ab45f1e67305dabda1e47902423338086253acc8372075360ddc", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "1f41da659dc1ab45f1e67305dabda1e47902423338086253acc8372075360ddc", kill_on_drop: false }` [INFO] [stdout] 1f41da659dc1ab45f1e67305dabda1e47902423338086253acc8372075360ddc [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 7ac2a4d5eb170150b147ad7ebe660809b7c71dae809eddb2e2bf8cfc0005b1c4 [INFO] running `Command { std: "docker" "start" "-a" "7ac2a4d5eb170150b147ad7ebe660809b7c71dae809eddb2e2bf8cfc0005b1c4", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.106 [INFO] [stderr] Compiling unicode-ident v1.0.24 [INFO] [stderr] Compiling quote v1.0.44 [INFO] [stderr] Compiling libc v0.2.182 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling log v0.4.29 [INFO] [stderr] Compiling cfg-if v1.0.4 [INFO] [stderr] Compiling stable_deref_trait v1.2.1 [INFO] [stderr] Compiling find-msvc-tools v0.1.9 [INFO] [stderr] Compiling crossbeam-utils v0.8.21 [INFO] [stderr] Compiling memchr v2.8.0 [INFO] [stderr] Compiling once_cell v1.21.3 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling pin-project-lite v0.2.16 [INFO] [stderr] Compiling itoa v1.0.17 [INFO] [stderr] Compiling bytes v1.11.1 [INFO] [stderr] Compiling futures-core v0.3.32 [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Compiling zmij v1.0.21 [INFO] [stderr] Compiling mio v1.1.1 [INFO] [stderr] Compiling bitflags v2.11.0 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling regex-syntax v0.8.10 [INFO] [stderr] Compiling socket2 v0.6.2 [INFO] [stderr] Compiling litemap v0.8.1 [INFO] [stderr] Compiling winnow v0.7.14 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling writeable v0.6.2 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling crossbeam-epoch v0.9.18 [INFO] [stderr] Compiling bstr v1.12.1 [INFO] [stderr] Compiling icu_normalizer_data v2.1.1 [INFO] [stderr] Compiling zeroize v1.8.2 [INFO] [stderr] Compiling same-file v1.0.6 [INFO] [stderr] Compiling icu_properties_data v2.1.2 [INFO] [stderr] Compiling walkdir v2.5.0 [INFO] [stderr] Compiling rustls-pki-types v1.14.0 [INFO] [stderr] Compiling crossbeam-deque v0.8.6 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling globset v0.4.18 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling http v1.4.0 [INFO] [stderr] Compiling pkg-config v0.3.32 [INFO] [stderr] Compiling hashbrown v0.16.1 [INFO] [stderr] Compiling serde_derive v1.0.228 [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 zerofrom v0.1.6 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling tokio v1.49.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 icu_provider v2.1.1 [INFO] [stderr] Compiling equivalent v1.0.2 [INFO] [stderr] Compiling rustix v1.1.4 [INFO] [stderr] Compiling untrusted v0.9.0 [INFO] [stderr] Compiling indexmap v2.13.0 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling ignore v0.4.25 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling linux-raw-sys v0.12.1 [INFO] [stderr] Compiling rustls v0.23.37 [INFO] [stderr] Compiling percent-encoding v2.3.2 [INFO] [stderr] Compiling slab v0.4.12 [INFO] [stderr] Compiling getrandom v0.4.1 [INFO] [stderr] Compiling futures-task v0.3.32 [INFO] [stderr] Compiling bitflags v1.3.2 [INFO] [stderr] Compiling libz-sys v1.1.24 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling globwalk v0.8.1 [INFO] [stderr] Compiling httparse v1.10.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling rustls-webpki v0.103.9 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling errno v0.3.14 [INFO] [stderr] Compiling either v1.15.0 [INFO] [stderr] Compiling try-lock v0.2.5 [INFO] [stderr] Compiling utf8parse v0.2.2 [INFO] [stderr] Compiling subtle v2.6.1 [INFO] [stderr] Compiling toml_write v0.1.2 [INFO] [stderr] Compiling tower-service v0.3.3 [INFO] [stderr] Compiling anstyle-parse v0.2.7 [INFO] [stderr] Compiling signal-hook v0.3.18 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling convert_case v0.10.0 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling want v0.3.1 [INFO] [stderr] Compiling signal-hook-registry v1.4.8 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling toml_edit v0.22.27 [INFO] [stderr] Compiling toml_parser v1.0.9+spec-1.1.0 [INFO] [stderr] Compiling arc-swap v1.8.2 [INFO] [stderr] Compiling serde_spanned v1.0.4 [INFO] [stderr] Compiling futures-channel v0.3.32 [INFO] [stderr] Compiling anstyle v1.0.13 [INFO] [stderr] Compiling ryu v1.0.23 [INFO] [stderr] Compiling atomic-waker v1.1.2 [INFO] [stderr] Compiling object v0.37.3 [INFO] [stderr] Compiling unsafe-libyaml v0.2.11 [INFO] [stderr] Compiling utf8_iter v1.0.4 [INFO] [stderr] Compiling lazy_static v1.5.0 [INFO] [stderr] Compiling anstyle-query v1.1.5 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling pin-utils v0.1.0 [INFO] [stderr] Compiling is_terminal_polyfill v1.70.2 [INFO] [stderr] Compiling scopeguard v1.2.0 [INFO] [stderr] Compiling colorchoice v1.0.4 [INFO] [stderr] Compiling toml_writer v1.0.6+spec-1.1.0 [INFO] [stderr] Compiling serde_yaml v0.9.34+deprecated [INFO] [stderr] Compiling toml v0.8.23 [INFO] [stderr] Compiling anstream v0.6.21 [INFO] [stderr] Compiling lock_api v0.4.14 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling triomphe v0.1.15 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling itertools v0.11.0 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling derive_more-impl v2.1.1 [INFO] [stderr] Compiling form_urlencoded v1.2.2 [INFO] [stderr] Compiling libgit2-sys v0.18.3+1.9.2 [INFO] [stderr] Compiling toml_datetime v0.7.5+spec-1.1.0 [INFO] [stderr] Compiling sync_wrapper v1.0.2 [INFO] [stderr] Compiling thread_local v1.1.9 [INFO] [stderr] Compiling siphasher v1.0.2 [INFO] [stderr] Compiling base62 v2.2.3 [INFO] [stderr] Compiling unicode-width v0.2.2 [INFO] [stderr] Compiling tower-layer v0.3.3 [INFO] [stderr] Compiling gimli v0.32.3 [INFO] [stderr] Compiling openssl-probe v0.2.1 [INFO] [stderr] Compiling base64 v0.22.1 [INFO] [stderr] Compiling ipnet v2.11.0 [INFO] [stderr] Compiling normpath v1.5.0 [INFO] [stderr] Compiling portable-atomic v1.13.1 [INFO] [stderr] Compiling adler2 v2.0.1 [INFO] [stderr] Compiling linux-raw-sys v0.4.15 [INFO] [stderr] Compiling litrs v1.0.0 [INFO] [stderr] Compiling document-features v0.2.12 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling addr2line v0.25.1 [INFO] [stderr] Compiling rust-i18n-support v3.1.5 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling rustls-native-certs v0.8.3 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling toml v0.9.12+spec-1.1.0 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling derive_more v2.1.1 [INFO] [stderr] Compiling signal-hook-mio v0.2.5 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling rust-i18n v3.1.5 [INFO] [stderr] Compiling rustc-demangle v0.1.27 [INFO] [stderr] Compiling strsim v0.11.1 [INFO] [stderr] Compiling anyhow v1.0.102 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling iri-string v0.7.10 [INFO] [stderr] Compiling fastrand v2.3.0 [INFO] [stderr] Compiling clap_lex v1.0.0 [INFO] [stderr] Compiling home v0.5.12 [INFO] [stderr] Compiling option-ext v0.2.0 [INFO] [stderr] Compiling glob v0.3.3 [INFO] [stderr] Compiling futures-sink v0.3.32 [INFO] [stderr] Compiling rust-i18n-macro v3.1.5 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling which v4.4.2 [INFO] [stderr] Compiling tempfile v3.26.0 [INFO] [stderr] Compiling clap_builder v4.5.60 [INFO] [stderr] Compiling clap_derive v4.5.55 [INFO] [stderr] Compiling backtrace v0.3.76 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling crossterm v0.29.0 [INFO] [stderr] Compiling rustls-platform-verifier v0.6.2 [INFO] [stderr] Compiling console v0.16.2 [INFO] [stderr] Compiling fuzzy-matcher v0.3.7 [INFO] [stderr] Compiling sharded-slab v0.1.7 [INFO] [stderr] Compiling uuid v1.21.0 [INFO] [stderr] Compiling tracing-log v0.2.0 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling toml_datetime v1.0.0+spec-1.1.0 [INFO] [stderr] Compiling sysinfo v0.37.2 [INFO] [stderr] Compiling unit-prefix v0.5.2 [INFO] [stderr] Compiling pathdiff v0.2.3 [INFO] [stderr] Compiling nu-ansi-term v0.50.3 [INFO] [stderr] Compiling unicode-segmentation v1.12.0 [INFO] [stderr] Compiling iana-time-zone v0.1.65 [INFO] [stderr] Compiling dyn-clone v1.0.20 [INFO] [stderr] Compiling env_home v0.1.0 [INFO] [stderr] Compiling shell-words v1.1.1 [INFO] [stderr] Compiling which v8.0.0 [INFO] [stderr] Compiling inquire v0.9.4 [INFO] [stderr] Compiling edit v0.1.5 [INFO] [stderr] Compiling chrono v0.4.44 [INFO] [stderr] Compiling human-panic v2.0.6 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling config v0.15.19 [INFO] [stderr] Compiling indicatif v0.18.4 [INFO] [stderr] Compiling toml v1.0.3+spec-1.1.0 [INFO] [stderr] Compiling reqwest v0.13.2 [INFO] [stderr] Compiling clap v4.5.60 [INFO] [stderr] Compiling directories v6.0.0 [INFO] [stderr] Compiling serde_yaml_ng v0.10.0 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling sys-locale v0.3.2 [INFO] [stderr] Compiling httpdate v1.0.3 [INFO] [stderr] Compiling colored v3.1.1 [INFO] [stderr] Compiling git2 v0.20.4 [INFO] [stderr] Compiling gcop-rs v0.13.7 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [optimized + debuginfo] target(s) in 11m 19s [INFO] running `Command { std: "docker" "inspect" "7ac2a4d5eb170150b147ad7ebe660809b7c71dae809eddb2e2bf8cfc0005b1c4", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7ac2a4d5eb170150b147ad7ebe660809b7c71dae809eddb2e2bf8cfc0005b1c4", kill_on_drop: false }` [INFO] [stdout] 7ac2a4d5eb170150b147ad7ebe660809b7c71dae809eddb2e2bf8cfc0005b1c4 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] bb617f91b17fc9aab21ca25f260c6e9128c13a34ad73316d955de8e1dded2455 [INFO] running `Command { std: "docker" "start" "-a" "bb617f91b17fc9aab21ca25f260c6e9128c13a34ad73316d955de8e1dded2455", kill_on_drop: false }` [INFO] [stderr] Compiling slab v0.4.12 [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling fnv v1.0.7 [INFO] [stderr] Compiling form_urlencoded v1.2.2 [INFO] [stderr] Compiling zerocopy v0.8.39 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling predicates-core v1.0.10 [INFO] [stderr] Compiling mockall_derive v0.14.0 [INFO] [stderr] Compiling termtree v0.5.1 [INFO] [stderr] Compiling cfg-if v1.0.4 [INFO] [stderr] Compiling mockall v0.14.0 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling predicates-tree v1.0.13 [INFO] [stderr] Compiling predicates v3.1.4 [INFO] [stderr] Compiling rand_core v0.9.5 [INFO] [stderr] Compiling fragile v2.0.1 [INFO] [stderr] Compiling downcast v0.11.0 [INFO] [stderr] Compiling git2 v0.20.4 [INFO] [stderr] Compiling sdd v3.0.10 [INFO] [stderr] Compiling scc v2.4.0 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling assert-json-diff v2.0.2 [INFO] [stderr] Compiling futures-executor v0.3.32 [INFO] [stderr] Compiling serial_test_derive v3.4.0 [INFO] [stderr] Compiling yansi v1.0.1 [INFO] [stderr] Compiling diff v0.1.13 [INFO] [stderr] Compiling similar v2.7.0 [INFO] [stderr] Compiling pretty_assertions v1.4.1 [INFO] [stderr] Compiling serial_test v3.4.0 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling rand_chacha v0.9.0 [INFO] [stderr] Compiling rand v0.9.2 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling mockito v1.7.2 [INFO] [stderr] Compiling reqwest v0.13.2 [INFO] [stderr] Compiling gcop-rs v0.13.7 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [optimized + debuginfo] target(s) in 6m 00s [INFO] running `Command { std: "docker" "inspect" "bb617f91b17fc9aab21ca25f260c6e9128c13a34ad73316d955de8e1dded2455", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "bb617f91b17fc9aab21ca25f260c6e9128c13a34ad73316d955de8e1dded2455", kill_on_drop: false }` [INFO] [stdout] bb617f91b17fc9aab21ca25f260c6e9128c13a34ad73316d955de8e1dded2455 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] c72d982b4d4d5190946f6f8522d081f239656df42b6c1e67b716e9d92ead9122 [INFO] running `Command { std: "docker" "start" "-a" "c72d982b4d4d5190946f6f8522d081f239656df42b6c1e67b716e9d92ead9122", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [optimized + debuginfo] target(s) in 0.62s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/gcop_rs-120268ef554815e4) [INFO] [stdout] [INFO] [stdout] running 346 tests [INFO] [stdout] test commands::commit::tests::test_format_message_header_first_attempt ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_generating_max_retries_exceeded ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_generating_preserves_feedbacks ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_generating_success_no_auto_accept ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_initial_state ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_max_retries_boundary ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_waiting_edit_success ... ok [INFO] [stdout] test commands::commit::tests::test_format_message_header_third_attempt ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_generating_success_with_auto_accept ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_waiting_accept ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_waiting_edit_cancelled_preserves_message ... ok [INFO] [stdout] test commands::commit::tests::test_format_edited_header ... ok [INFO] [stdout] test commands::commit::tests::test_format_message_header_second_attempt ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_waiting_quit ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_waiting_retry_increments_attempt ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_waiting_retry_with_feedback_accumulates ... ok [INFO] [stdout] test commands::commit_state_machine::tests::test_waiting_retry_with_no_feedback ... ok [INFO] [stdout] test commands::format::tests::test_effective_colored ... ok [INFO] [stdout] test commands::format::tests::test_from_cli_format_string ... ok [INFO] [stdout] test commands::hook::tests::test_source_commit_with_sha_is_amend ... ok [INFO] [stdout] test commands::hook::tests::test_source_merge_skips ... ok [INFO] [stdout] test commands::hook::tests::test_source_message_skips ... ok [INFO] [stdout] test commands::hook::tests::test_source_commit_empty_sha_skips ... ok [INFO] [stdout] test commands::format::tests::test_from_cli_json_flag ... ok [INFO] [stdout] test commands::format::tests::test_is_machine_readable ... ok [INFO] [stdout] test commands::options::tests::test_commit_options_from_cli ... ok [INFO] [stdout] test commands::hook::tests::test_empty_source_is_normal ... ok [INFO] [stdout] test commands::hook::tests::test_unknown_source_is_normal ... ok [INFO] [stdout] test commands::options::tests::test_stats_options ... ok [INFO] [stdout] test commands::options::tests::test_commit_options_split_from_config ... ok [INFO] [stdout] test commands::split::tests::test_format_and_parse_editor_roundtrip ... ok [INFO] [stdout] test commands::split::tests::test_format_and_parse_editor_multiline_message ... ok [INFO] [stdout] test commands::options::tests::test_commit_options_split_cli_overrides ... ok [INFO] [stdout] test commands::options::tests::test_commit_options_json_flag ... ok [INFO] [stdout] test commands::split::tests::test_parse_split_response_duplicate_file ... ok [INFO] [stdout] test commands::split::tests::test_parse_split_response_extra_files_across_groups_rejected ... ok [INFO] [stdout] test commands::split::tests::test_parse_split_response_empty_groups ... ok [INFO] [stdout] test commands::split::tests::test_parse_split_response_empty_message ... ok [INFO] [stdout] test commands::split::tests::test_parse_split_response_extra_files_rejected ... ok [INFO] [stdout] test commands::split::tests::test_parse_split_response_no_extra_files_ok ... ok [INFO] [stdout] test commands::split::tests::test_parse_split_response_valid ... ok [INFO] [stdout] test commands::split::tests::test_strip_code_fences_json ... ok [INFO] [stdout] test commands::split::tests::test_strip_code_fences_none ... ok [INFO] [stdout] test commands::split::tests::test_strip_code_fences_plain ... ok [INFO] [stdout] test commands::tests::test_is_auto_generated_lock_files ... ok [INFO] [stdout] test commands::tests::test_is_auto_generated_normal_files ... ok [INFO] [stdout] test commands::tests::test_smart_truncate_all_files_too_large ... ok [INFO] [stdout] test commands::tests::test_smart_truncate_auto_generated_demoted ... ok [INFO] [stdout] test commands::tests::test_is_auto_generated_generated_files ... ok [INFO] [stdout] test commands::tests::test_smart_truncate_no_truncation ... ok [INFO] [stdout] test commands::tests::test_smart_truncate_empty_diff ... ok [INFO] [stdout] test commands::tests::test_smart_truncate_budget_overflow ... ok [INFO] [stdout] test config::tests::test_app_config_default_commit ... ok [INFO] [stdout] test commands::tests::test_smart_truncate_preserves_file_boundary ... ok [INFO] [stdout] test config::tests::test_app_config_default_file ... ok [INFO] [stdout] test config::tests::test_app_config_default_llm ... ok [INFO] [stdout] test config::tests::test_app_config_default_review ... ok [INFO] [stdout] test config::tests::test_app_config_default_network ... ok [INFO] [stdout] test config::tests::test_app_config_default_ui ... ok [INFO] [stdout] test config::global::tests::test_get_config_after_init ... ok [INFO] [stdout] test config::global::tests::test_init_config_succeeds ... ok [INFO] [stdout] test config::global::tests::test_init_config_idempotent ... ok [INFO] [stdout] test config::tests::test_ci_mode_missing_provider_type ... ok [INFO] [stdout] test config::tests::test_ci_mode_with_custom_endpoint ... ok [INFO] [stdout] test config::tests::test_ci_mode_invalid_provider_type ... ok [INFO] [stdout] test config::tests::test_ci_mode_missing_api_key ... ok [INFO] [stdout] test config::tests::test_commit_config_default_convention_is_none ... ok [INFO] [stdout] test config::tests::test_commit_convention_default ... ok [INFO] [stdout] test config::tests::test_convention_from_toml ... ok [INFO] [stdout] test config::tests::test_convention_partial_from_toml ... ok [INFO] [stdout] test config::tests::test_convention_style_serde_roundtrip ... ok [INFO] [stdout] test config::tests::test_env_guard_sets_and_restores ... ok [INFO] [stdout] test commands::split::tests::test_parse_split_response_with_fences ... ok [INFO] [stdout] test config::tests::test_get_config_dir_returns_valid_path ... ok [INFO] [stdout] test config::tests::test_get_config_path_has_toml_suffix ... ok [INFO] [stdout] test config::tests::test_env_overrides_project_config ... ok [INFO] [stdout] test config::tests::test_load_config_succeeds ... ok [INFO] [stdout] test config::tests::test_ci_mode_enabled_with_ci_env ... ok [INFO] [stdout] test config::tests::test_load_config_with_no_project_config ... ok [INFO] [stdout] test config::tests::test_serde_empty_config_matches_default ... ok [INFO] [stdout] test config::tests::test_validate_default_provider_exists ... ok [INFO] [stdout] test config::tests::test_validate_default_provider_not_in_providers ... ok [INFO] [stdout] test config::tests::test_validate_default_provider_ok_when_providers_empty ... ok [INFO] [stdout] test config::tests::test_validate_fallback_provider_not_in_providers ... ok [INFO] [stdout] test config::tests::test_validate_fallback_providers_all_exist ... ok [INFO] [stdout] test config::tests::test_validate_fallback_providers_empty_is_ok ... ok [INFO] [stdout] test error::tests::test_suggestion_config_claude_api_key ... ok [INFO] [stdout] test error::tests::test_suggestion_config_generic_api_key ... ok [INFO] [stdout] test error::tests::test_suggestion_config_openai_api_key ... ok [INFO] [stdout] test error::tests::test_suggestion_config_provider_not_found ... ok [INFO] [stdout] test error::tests::test_suggestion_llm_api_401_unauthorized ... ok [INFO] [stdout] test error::tests::test_suggestion_llm_api_429_rate_limit ... ok [INFO] [stdout] test error::tests::test_suggestion_llm_api_5xx_service_unavailable ... ok [INFO] [stdout] test error::tests::test_suggestion_llm_connection_failed ... ok [INFO] [stdout] test error::tests::test_suggestion_llm_content_blocked ... ok [INFO] [stdout] test error::tests::test_suggestion_llm_parse_failed ... ok [INFO] [stdout] test error::tests::test_suggestion_llm_stream_truncated ... ok [INFO] [stdout] test error::tests::test_suggestion_llm_timeout ... ok [INFO] [stdout] test error::tests::test_suggestion_max_retries_exceeded ... ok [INFO] [stdout] test error::tests::test_suggestion_network_error ... ok [INFO] [stdout] test error::tests::test_suggestion_no_staged_changes ... ok [INFO] [stdout] test error::tests::test_suggestion_returns_none_for_other_errors ... ok [INFO] [stdout] test git::diff::tests::test_parse_diff_stats ... ok [INFO] [stdout] test git::diff::tests::test_parse_diff_stats_binary_file ... ok [INFO] [stdout] test git::diff::tests::test_parse_diff_stats_chinese_filename ... ok [INFO] [stdout] test git::diff::tests::test_parse_diff_stats_empty_diff ... ok [INFO] [stdout] test git::diff::tests::test_parse_diff_stats_file_with_spaces ... ok [INFO] [stdout] test git::diff::tests::test_parse_diff_stats_multiple_files ... ok [INFO] [stdout] test git::diff::tests::test_parse_diff_stats_only_deletions ... ok [INFO] [stdout] test git::diff::tests::test_parse_diff_stats_only_insertions ... ok [INFO] [stdout] test git::diff::tests::test_split_diff_by_file_binary ... ok [INFO] [stdout] test git::diff::tests::test_split_diff_by_file_empty ... ok [INFO] [stdout] test git::diff::tests::test_split_diff_by_file_multiple ... ok [INFO] [stdout] test git::diff::tests::test_split_diff_by_file_single ... ok [INFO] [stdout] test commands::hook::tests::test_source_squash_skips ... ok [INFO] [stdout] test git::repository::tests::test_get_commit_diff_initial_commit ... ok [INFO] [stdout] test git::repository::tests::test_get_commit_diff_invalid_hash ... ok [INFO] [stdout] test git::repository::tests::test_get_commit_diff_normal ... ok [INFO] [stdout] test git::repository::tests::test_get_commit_history ... ok [INFO] [stdout] test git::repository::tests::test_get_commit_history_empty_repo ... ok [INFO] [stdout] test git::repository::tests::test_get_current_branch_detached_head ... ok [INFO] [stdout] test git::repository::tests::test_get_current_branch_empty_repo ... ok [INFO] [stdout] test git::repository::tests::test_get_diff_stats ... ok [INFO] [stdout] test git::repository::tests::test_get_current_branch_normal ... ok [INFO] [stdout] test git::repository::tests::test_get_file_content ... ok [INFO] [stdout] test git::repository::tests::test_get_range_diff ... ok [INFO] [stdout] test git::repository::tests::test_get_range_diff_invalid_format ... ok [INFO] [stdout] test git::repository::tests::test_get_file_content_too_large ... ok [INFO] [stdout] test git::repository::tests::test_get_staged_diff_empty_repo ... ok [INFO] [stdout] test git::repository::tests::test_get_staged_diff_normal ... ok [INFO] [stdout] test git::repository::tests::test_has_staged_changes_false_after_commit ... ok [INFO] [stdout] test git::repository::tests::test_has_staged_changes_false_empty_repo ... ok [INFO] [stdout] test git::repository::tests::test_get_uncommitted_diff ... ok [INFO] [stdout] test git::repository::tests::test_has_staged_changes_true ... ok [INFO] [stdout] test git::repository::tests::test_is_empty_true_for_new_repo ... ok [INFO] [stdout] test git::repository::tests::test_is_empty_false_after_commit ... ok [INFO] [stdout] test git::repository::tests::test_stage_files_glob_path_missing_literal_errors_not_sibling ... ok [INFO] [stdout] test git::repository::tests::test_unstage_all_then_stage_subset_does_not_touch_unstaged_file ... ok [INFO] [stdout] test llm::prompt::tests::test_commit_prompt_scope_with_root_changes ... ok [INFO] [stdout] test llm::prompt::tests::test_commit_prompt_split_custom_template ... ok [INFO] [stdout] test llm::prompt::tests::test_commit_prompt_split_default ... ok [INFO] [stdout] test llm::prompt::tests::test_commit_prompt_split_no_convention ... ok [INFO] [stdout] test llm::prompt::tests::test_commit_prompt_split_with_branch ... ok [INFO] [stdout] test llm::prompt::tests::test_commit_prompt_split_with_conventional_convention ... ok [INFO] [stdout] test llm::prompt::tests::test_commit_prompt_split_with_custom_convention ... ok [INFO] [stdout] test llm::prompt::tests::test_commit_prompt_split_with_feedback ... ok [INFO] [stdout] test llm::prompt::tests::test_commit_prompt_split_with_gitmoji_convention ... ok [INFO] [stdout] test git::repository::tests::test_stage_files_literal_glob_path ... ok [INFO] [stdout] test llm::prompt::tests::test_commit_prompt_with_scope_info ... ok [INFO] [stdout] test llm::prompt::tests::test_commit_prompt_without_scope_info ... ok [INFO] [stdout] test llm::prompt::tests::test_review_prompt_split_custom_template ... ok [INFO] [stdout] test llm::prompt::tests::test_review_prompt_split_default ... ok [INFO] [stdout] test llm::prompt::tests::test_split_commit_prompt_custom_template_appended ... ok [INFO] [stdout] test llm::provider::backends::claude::tests::test_claude_api_error_401 ... ok [INFO] [stdout] test llm::provider::backends::claude::tests::test_claude_api_error_429 ... ok [INFO] [stdout] test llm::provider::backends::claude::tests::test_claude_response_with_extended_thinking ... ok [INFO] [stdout] test llm::provider::backends::claude::tests::test_claude_response_with_thinking_deserializes ... ok [INFO] [stdout] test llm::provider::backends::claude::tests::test_claude_response_with_thinking_and_multiple_text_blocks ... ok [INFO] [stdout] test llm::provider::backends::claude::tests::test_claude_response_without_thinking ... ok [INFO] [stdout] test llm::provider::backends::claude::tests::test_content_block_text_only ... ok [INFO] [stdout] test llm::provider::backends::claude::tests::test_claude_success_response_parsing ... ok [INFO] [stdout] test llm::provider::backends::claude::tests::test_content_block_thinking_becomes_other ... ok [INFO] [stdout] test llm::provider::backends::gemini::tests::test_gemini_api_error_401 ... ok [INFO] [stdout] test llm::provider::backends::gemini::tests::test_gemini_api_error_429 ... ok [INFO] [stdout] test llm::provider::backends::gemini::tests::test_gemini_no_content_response ... ok [INFO] [stdout] test llm::provider::backends::claude::tests::test_content_block_unknown_type_becomes_other ... ok [INFO] [stdout] test llm::provider::backends::gemini::tests::test_gemini_safety_blocked_response ... ok [INFO] [stdout] test llm::provider::backends::ollama::tests::test_ollama_api_error_401 ... ok [INFO] [stdout] test llm::provider::backends::ollama::tests::test_ollama_api_error_429 ... ok [INFO] [stdout] test llm::provider::backends::gemini::tests::test_gemini_success_response_parsing ... ok [INFO] [stdout] test llm::provider::backends::openai::tests::test_openai_api_error_401 ... ok [INFO] [stdout] test llm::provider::backends::ollama::tests::test_ollama_success_response_parsing ... ok [INFO] [stdout] test llm::provider::backends::openai::tests::test_openai_success_response_parsing ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_commit_already_clean ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_commit_bare_fences ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_commit_markdown_lang_tag ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_commit_multiline_body ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_commit_multiline_with_list_bare_fences ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_commit_no_closing_fence ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_commit_plain_message ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_commit_text_lang_tag ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_commit_with_whitespace ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_complex_nested ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_empty_string ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_markdown_lowercase ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_markdown_no_lang ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_markdown_uppercase ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_nested_braces ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_no_braces ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_plain ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_with_both_prefix_suffix ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_with_prefix_text ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_with_suffix_text ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_clean_json_with_whitespace ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_parse_review_empty_issues ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_parse_review_invalid_json ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_parse_review_valid_json ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_parse_review_with_file_and_line ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_parse_review_with_markdown ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_process_commit_response_strips_fences ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_process_commit_response_strips_thinking_and_fence ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_strip_think_basic ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_strip_thinking_basic ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_strip_thinking_empty_block ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_strip_thinking_multiline_content ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_strip_thinking_multiple_blocks ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_strip_thinking_no_tags ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_strip_thinking_unclosed_tag_preserved ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_strip_thinking_with_code_fence_after ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_truncate_emoji ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_truncate_long_string ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_truncate_multibyte_chars ... ok [INFO] [stdout] test llm::provider::base::response::tests::test_truncate_short_string ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_backoff_capped_at_max_delay ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_backoff_doubles_each_attempt ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_backoff_first_attempt_uses_base_delay ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_backoff_minimum_floor_100ms ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_backoff_overflow_protection ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_is_retryable_config_not_retryable ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_is_retryable_connection_failed ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_is_retryable_llm_api_not_retryable ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_is_retryable_llm_not_retryable ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_is_retryable_stream_truncated ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_is_retryable_timeout ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_non_retryable_status_2xx ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_non_retryable_status_429 ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_non_retryable_status_4xx ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_non_retryable_status_501 ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_parse_retry_after_http_date_future ... ok [INFO] [stdout] test llm::provider::backends::openai::tests::test_openai_api_error_429 ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_parse_retry_after_http_date_past ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_parse_retry_after_integer_seconds ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_parse_retry_after_invalid_returns_none ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_retryable_status_408 ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_retryable_status_5xx ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_streaming_200_returns_ok_response ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_streaming_401_returns_llm_api_error ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_streaming_429_retry_after_exceeds_max_delay ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_streaming_429_no_retries_returns_error ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_streaming_429_retry_after_zero_then_success ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_streaming_500_no_retries_returns_error ... ok [INFO] [stdout] test llm::provider::base::validation::tests::test_validate_api_key_empty ... ok [INFO] [stdout] test llm::provider::base::validation::tests::test_validate_api_key_success ... ok [INFO] [stdout] test llm::provider::base::validation::tests::test_validate_http_endpoint_auth_error ... ok [INFO] [stdout] test llm::provider::base::validation::tests::test_validate_http_endpoint_success ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_generate_commit_message_all_fail ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_generate_commit_message_fallback_on_failure ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_generate_commit_message_primary_success ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_review_code_fallback_on_failure ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_review_code_primary_success ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_streaming_fallback_to_non_streaming ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_streaming_primary_success ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_supports_streaming_empty ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_supports_streaming_false ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_supports_streaming_true ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_validate_all_fail ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_validate_empty_providers ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_validate_partial_success ... ok [INFO] [stdout] test llm::provider::fallback::tests::test_validate_success ... ok [INFO] [stdout] test llm::provider::streaming::claude::tests::test_claude_empty_stream_truncated ... ok [INFO] [stdout] test llm::provider::streaming::claude::tests::test_claude_multiple_deltas_then_stop ... ok [INFO] [stdout] test llm::provider::streaming::claude::tests::test_claude_normal_completion ... ok [INFO] [stdout] test llm::provider::streaming::claude::tests::test_claude_sse_event_parse ... ok [INFO] [stdout] test llm::provider::streaming::claude::tests::test_claude_truncated_all_parse_errors ... ok [INFO] [stdout] test llm::provider::streaming::claude::tests::test_claude_truncated_without_stop ... ok [INFO] [stdout] test llm::provider::streaming::gemini::tests::test_gemini_content_blocked_recitation ... ok [INFO] [stdout] test llm::provider::base::retry::tests::test_streaming_500_retry_then_success ... ok [INFO] [stdout] test llm::provider::streaming::gemini::tests::test_gemini_content_blocked_safety ... ok [INFO] [stdout] test llm::provider::streaming::gemini::tests::test_gemini_no_finish_reason_sends_done ... ok [INFO] [stdout] test llm::provider::streaming::gemini::tests::test_gemini_normal_stop ... ok [INFO] [stdout] test llm::provider::streaming::gemini::tests::test_gemini_stream_chunk_parse ... ok [INFO] [stdout] test llm::provider::streaming::gemini::tests::test_gemini_stream_chunk_with_finish_reason ... ok [INFO] [stdout] test llm::provider::streaming::gemini::tests::test_gemini_stream_chunk_with_max_tokens_finish_reason ... ok [INFO] [stdout] test llm::provider::streaming::gemini::tests::test_gemini_stream_chunk_with_safety_finish_reason ... ok [INFO] [stdout] test llm::provider::streaming::openai::tests::test_openai_clean_truncation_sends_done ... ok [INFO] [stdout] test llm::provider::streaming::openai::tests::test_openai_delta_parse ... ok [INFO] [stdout] test llm::provider::streaming::openai::tests::test_openai_normal_completion_via_finish_reason ... ok [INFO] [stdout] test llm::provider::streaming::openai::tests::test_openai_normal_completion_with_done ... ok [INFO] [stdout] test llm::provider::streaming::openai::tests::test_openai_truncated_all_parse_errors ... ok [INFO] [stdout] test llm::provider::streaming::openai::tests::test_parse_sse_line ... ok [INFO] [stdout] test llm::provider::test_utils::tests::test_network_config_no_retry_has_zero_retries ... ok [INFO] [stdout] test llm::provider::test_utils::tests::test_provider_config_with_api_key ... ok [INFO] [stdout] test llm::provider::test_utils::tests::test_provider_config_without_api_key ... ok [INFO] [stdout] test llm::provider::utils::tests::test_claude_endpoint ... ok [INFO] [stdout] test llm::provider::utils::tests::test_complete_endpoint_already_complete ... ok [INFO] [stdout] test llm::provider::utils::tests::test_complete_endpoint_basic ... ok [INFO] [stdout] test llm::provider::utils::tests::test_complete_endpoint_custom_path ... ok [INFO] [stdout] test llm::provider::utils::tests::test_complete_endpoint_with_trailing_slash ... ok [INFO] [stdout] test llm::provider::utils::tests::test_complete_endpoint_with_version_only ... ok [INFO] [stdout] test llm::provider::utils::tests::test_is_complete_api_path ... ok [INFO] [stdout] test llm::provider::utils::tests::test_mask_api_key ... ok [INFO] [stdout] test llm::provider::utils::tests::test_ollama_localhost ... ok [INFO] [stdout] test llm::provider::utils::tests::test_suffix_variations ... ok [INFO] [stdout] test ui::colors::tests::test_format_diff_stats_colored ... ok [INFO] [stdout] test ui::colors::tests::test_format_diff_stats_empty_files ... ok [INFO] [stdout] test ui::colors::tests::test_format_diff_stats_multiple_files ... ok [INFO] [stdout] test ui::colors::tests::test_format_diff_stats_single_deletion ... ok [INFO] [stdout] test ui::colors::tests::test_format_diff_stats_single_file ... ok [INFO] [stdout] test ui::colors::tests::test_format_diff_stats_single_insertion ... ok [INFO] [stdout] test ui::colors::tests::test_format_diff_stats_zero_deletions ... ok [INFO] [stdout] test ui::colors::tests::test_format_diff_stats_zero_insertions ... ok [INFO] [stdout] test ui::streaming::tests::test_lines_to_erase_code_fenced ... ok [INFO] [stdout] test ui::streaming::tests::test_lines_to_erase_empty ... ok [INFO] [stdout] test ui::streaming::tests::test_lines_to_erase_multiline ... ok [INFO] [stdout] test ui::streaming::tests::test_lines_to_erase_single_line ... ok [INFO] [stdout] test ui::streaming::tests::test_lines_to_erase_trailing_newline ... ok [INFO] [stdout] test ui::streaming::tests::test_redisplay_noop_when_unchanged ... ok [INFO] [stdout] test workspace::detector::tests::test_detect_cargo_no_workspace ... ok [INFO] [stdout] test workspace::detector::tests::test_detect_cargo_workspace ... ok [INFO] [stdout] test workspace::detector::tests::test_detect_deduplicates_members ... ok [INFO] [stdout] test workspace::detector::tests::test_detect_lerna_workspace ... ok [INFO] [stdout] test workspace::detector::tests::test_detect_no_workspace ... ok [INFO] [stdout] test workspace::detector::tests::test_detect_npm_with_nx ... ok [INFO] [stdout] test workspace::detector::tests::test_detect_npm_with_turbo ... ok [INFO] [stdout] test workspace::detector::tests::test_detect_npm_workspaces_array ... ok [INFO] [stdout] test workspace::detector::tests::test_detect_npm_workspaces_yarn_style ... ok [INFO] [stdout] test workspace::detector::tests::test_detect_pnpm_workspace ... ok [INFO] [stdout] test workspace::matcher::tests::test_map_all_root_files ... ok [INFO] [stdout] test workspace::matcher::tests::test_map_files_to_packages ... ok [INFO] [stdout] test workspace::matcher::tests::test_map_single_package ... ok [INFO] [stdout] test workspace::matcher::tests::test_match_apps_file ... ok [INFO] [stdout] test workspace::matcher::tests::test_match_exact_path_member ... ok [INFO] [stdout] test workspace::matcher::tests::test_match_file_directly_in_prefix ... ok [INFO] [stdout] test workspace::matcher::tests::test_match_nested_file ... ok [INFO] [stdout] test workspace::matcher::tests::test_match_package_file ... ok [INFO] [stdout] test workspace::matcher::tests::test_match_root_file ... ok [INFO] [stdout] test workspace::scope::tests::test_manual_scope_override ... ok [INFO] [stdout] test workspace::scope::tests::test_many_packages_no_scope ... ok [INFO] [stdout] test workspace::scope::tests::test_mixed_package_and_root ... ok [INFO] [stdout] test workspace::scope::tests::test_root_only_no_scope ... ok [INFO] [stdout] test workspace::scope::tests::test_single_package_scope ... ok [INFO] [stdout] test workspace::scope::tests::test_two_packages_scope ... ok [INFO] [stdout] test workspace::tests::test_glob_pattern_to_prefix_bare_star ... ok [INFO] [stdout] test workspace::tests::test_glob_pattern_to_prefix_double_star ... ok [INFO] [stdout] test workspace::tests::test_glob_pattern_to_prefix_exact ... ok [INFO] [stdout] test workspace::tests::test_glob_pattern_to_prefix_negation ... ok [INFO] [stdout] test workspace::tests::test_glob_pattern_to_prefix_quoted ... ok [INFO] [stdout] test workspace::tests::test_glob_pattern_to_prefix_star ... ok [INFO] [stdout] test workspace::tests::test_glob_pattern_to_prefix_trailing_slash ... ok [INFO] [stdout] test llm::provider::streaming::gemini::tests::test_gemini_max_tokens_sends_done ... ok [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/gcop_rs-f05ecbd916cd5599) [INFO] [stdout] test config::tests::test_env_var_llm_default_provider ... ok [INFO] [stdout] test config::tests::test_load_config_returns_valid_config ... ok [INFO] [stdout] test config::tests::test_ci_mode_disabled_by_default ... ok [INFO] [stdout] test config::tests::test_ci_mode_with_custom_model ... ok [INFO] [stdout] test config::tests::test_project_config_overrides_user_config ... ok [INFO] [stdout] test config::tests::test_env_var_can_be_read ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 346 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.01s [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Running tests/alias_test.rs (/opt/rustwide/target/debug/deps/alias_test-7367080c76bed99d) [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] [stdout] [INFO] [stdout] running 10 tests [INFO] [stdout] test test_get_alias_not_found ... ok [INFO] [stdout] test test_set_alias ... ok [INFO] [stdout] test test_read_config_file_with_existing_content ... ok [INFO] [stdout] test test_remove_nonexistent_alias ... ok [INFO] [stdout] test test_get_alias_existing ... ok [INFO] [stdout] test test_remove_alias ... ok [INFO] [stdout] test test_set_alias_overwrite ... ok [INFO] [stdout] test test_alias_conflict_detection ... ok [INFO] [stdout] test test_alias_various_formats ... ok [INFO] [stdout] test test_install_multiple_aliases ... ok [INFO] [stdout] [INFO] [stderr] Running tests/commit_integration_test.rs (/opt/rustwide/target/debug/deps/commit_integration_test-9c71f140ecbdfbcf) [INFO] [stdout] test result: ok. 10 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.17s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 3 tests [INFO] [stderr] Running tests/commit_main_loop_test.rs (/opt/rustwide/target/debug/deps/commit_main_loop_test-63c37991052b82b3) [INFO] [stdout] test test_git_mock_basic ... ok [INFO] [stdout] test test_llm_mock_basic ... ok [INFO] [stdout] test test_git_mock_multiple_calls ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 10 tests [INFO] [stdout] test test_commit_git_failure ... ok [INFO] [stdout] test test_commit_llm_failure ... ok [INFO] [stdout] test test_commit_dry_run_mode ... ok [INFO] [stdout] test test_commit_no_staged_changes ... ok [INFO] [stdout] test test_commit_json_output_mode ... ok [INFO] [stdout] test test_display_message_no_panic ... ok [INFO] [stdout] test test_commit_verbose_mode ... ok [INFO] [stdout] test test_commit_with_feedback ... ok [INFO] [stdout] test test_handle_json_mode_no_panic ... ok [INFO] [stdout] test test_format_message_header ... ok [INFO] [stderr] Running tests/git_commit_test.rs (/opt/rustwide/target/debug/deps/git_commit_test-66d212532c10e117) [INFO] [stdout] [INFO] [stdout] test result: ok. 10 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 6 tests [INFO] [stdout] test test_commit_no_staged_changes ... ok [INFO] [stdout] test test_commit_hook_failure ... ok [INFO] [stdout] test test_commit_empty_message ... ok [INFO] [stdout] test test_commit_respects_git_config ... ok [INFO] [stdout] test test_commit_with_multiline_message ... ok [INFO] [stderr] Running tests/git_repository_test.rs (/opt/rustwide/target/debug/deps/git_repository_test-6b9a7094a7de4070) [INFO] [stdout] test test_commit_success ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.26s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 14 tests [INFO] [stdout] test test_get_range_diff_invalid_format ... ok [INFO] [stdout] test test_get_commit_diff_for_first_commit ... ok [INFO] [stdout] test test_has_staged_changes_true ... ok [INFO] [stdout] test test_is_empty_on_fresh_repo ... ok [INFO] [stdout] test test_is_empty_with_commit ... ok [INFO] [stdout] test test_paths_with_spaces ... ok [INFO] [stdout] test test_paths_with_unicode ... ok [INFO] [stdout] test test_get_commit_diff_invalid_hash ... ok [INFO] [stdout] test test_get_file_content_respects_custom_max_size ... ok [INFO] [stdout] test test_get_file_content_exceeds_max_size ... ok [INFO] [stdout] test test_get_current_branch_detached_head ... ok [INFO] [stdout] test test_has_staged_changes_false ... ok [INFO] [stdout] test test_get_commit_history_normal ... ok [INFO] [stdout] test test_get_staged_diff_on_empty_repo ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 14 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.12s [INFO] [stdout] [INFO] [stderr] Running tests/integration_test.rs (/opt/rustwide/target/debug/deps/integration_test-77128d90ac146ee9) [INFO] [stdout] [INFO] [stdout] running 6 tests [INFO] [stdout] test test_review_prompt_generation ... ok [INFO] [stdout] test test_config_default_values ... ok [INFO] [stdout] test test_user_feedback_accumulation ... ok [INFO] [stdout] test test_git_diff_parsing ... ok [INFO] [stdout] test test_prompt_generation_flow ... ok [INFO] [stdout] test test_review_response_parsing_flow ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stderr] Running tests/project_config_test.rs (/opt/rustwide/target/debug/deps/project_config_test-ef2295c2e86fab04) [INFO] [stdout] [INFO] [stdout] running 8 tests [INFO] [stdout] test test_convention_custom_with_template_e2e ... ok [INFO] [stdout] test test_commit_convention_defaults ... ok [INFO] [stdout] test test_convention_gitmoji_e2e ... ok [INFO] [stdout] test test_convention_with_custom_prompt_e2e ... ok [INFO] [stdout] test test_app_config_default_no_convention ... ok [INFO] [stdout] test test_convention_with_feedback_e2e ... ok [INFO] [stdout] test test_no_convention_no_section_e2e ... ok [INFO] [stdout] test test_convention_conventional_e2e ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 8 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running tests/provider_validation_test.rs (/opt/rustwide/target/debug/deps/provider_validation_test-bd272b00b3e09096) [INFO] [stdout] [INFO] [stdout] running 9 tests [INFO] [stdout] test test_claude_validate_empty_api_key ... ok [INFO] [stdout] test test_ollama_validate_model_not_found ... ok [INFO] [stdout] test test_ollama_validate_success ... ok [INFO] [stdout] test test_claude_validate_success ... ok [INFO] [stdout] test test_openai_validate_success ... ok [INFO] [stdout] test test_claude_validate_401_unauthorized ... ok [INFO] [stdout] test test_openai_validate_401_unauthorized ... ok [INFO] [stdout] test test_claude_validate_429_rate_limit ... ok [INFO] [stdout] test test_ollama_validate_connection_error ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 9 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.18s [INFO] [stdout] [INFO] [stderr] Running tests/review_command_test.rs (/opt/rustwide/target/debug/deps/review_command_test-5558e0634a5ca479) [INFO] [stdout] [INFO] [stdout] running 6 tests [INFO] [stdout] test test_review_empty_uncommitted_changes_error ... ok [INFO] [stdout] test test_review_target_uncommitted_changes ... ok [INFO] [stdout] test test_review_target_range ... ok [INFO] [stdout] test test_review_target_file ... ok [INFO] [stdout] test test_review_llm_failure ... ok [INFO] [stdout] test test_review_target_single_commit ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] [stderr]      Running tests/stats_test.rs (/opt/rustwide/target/debug/deps/stats_test-5203c68dc65b5b50) [INFO] [stdout] [INFO] [stdout] running 10 tests [INFO] [stderr] Running tests/test_git_ops.rs (/opt/rustwide/target/debug/deps/test_git_ops-0d9307c37ddbbc4a) [INFO] [stdout] test test_repo_stats_author_filter_no_match ... ok [INFO] [stdout] test test_repo_stats_author_filter_by_name ... ok [INFO] [stdout] test test_repo_stats_author_filter_case_insensitive ... ok [INFO] [stdout] test test_repo_stats_days_span ... ok [INFO] [stdout] test test_repo_stats_empty_commits ... ok [INFO] [stdout] test test_repo_stats_days_span_single_day ... ok [INFO] [stdout] test test_repo_stats_multiple_commits ... ok [INFO] [stdout] test test_repo_stats_single_commit ... ok [INFO] [stdout] test test_repo_stats_author_filter_by_email ... ok [INFO] [stdout] test test_repo_stats_commits_by_week ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 10 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [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] [stderr] Running tests/workspace_e2e_test.rs (/opt/rustwide/target/debug/deps/workspace_e2e_test-9778ab1ee8b308b4) [INFO] [stdout] [INFO] [stdout] running 14 tests [INFO] [stdout] test test_e2e_no_workspace ... ok [INFO] [stdout] test test_e2e_four_plus_packages_no_scope ... ok [INFO] [stdout] test test_e2e_dedup_across_workspace_types ... ok [INFO] [stdout] test test_e2e_manual_scope_override ... ok [INFO] [stdout] test test_e2e_mixed_cargo_and_pnpm ... ok [INFO] [stdout] test test_e2e_lerna_workspace ... ok [INFO] [stdout] test test_e2e_cargo_workspace ... ok [INFO] [stdout] test test_e2e_npm_with_nx ... ok [INFO] [stdout] test test_e2e_npm_workspace_array ... ok [INFO] [stdout] test test_e2e_npm_workspace_yarn_style ... ok [INFO] [stderr] Doc-tests gcop_rs [INFO] [stdout] test test_e2e_pnpm_workspace ... ok [INFO] [stdout] test test_e2e_npm_with_turbo ... ok [INFO] [stdout] test test_e2e_root_files_no_scope ... ok [INFO] [stdout] test test_e2e_cargo_no_workspace ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 14 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 33 tests [INFO] [stdout] test src/commands/options.rs - commands::options::CommitOptions (line 48) - compile ... ok [INFO] [stdout] test src/commands/mod.rs - commands::options (line 55) - compile ... ok [INFO] [stdout] test src/commands/options.rs - commands::options::ReviewOptions (line 152) - compile ... ok [INFO] [stdout] test src/commands/commit_state_machine.rs - commands::commit_state_machine::CommitState::handle_generation (line 221) ... ok [INFO] [stdout] test src/commands/options.rs - commands::options::StatsOptions (line 224) - compile ... ok [INFO] [stdout] test src/commands/commit_state_machine.rs - commands::commit_state_machine::CommitState::handle_action (line 280) ... ok [INFO] [stdout] test src/commands/json.rs - commands::json::output_json_error (line 47) - compile ... ok [INFO] [stdout] test src/git/mod.rs - git::GitOperations (line 56) - compile ... ok [INFO] [stdout] test src/git/mod.rs - git::GitOperations::get_current_branch (line 174) - compile ... ok [INFO] [stdout] test src/git/mod.rs - git::MockGitOperations (line 56) - compile ... ok [INFO] [stdout] test src/git/mod.rs - git::MockGitOperations (line 56) - compile ... ok [INFO] [stdout] test src/git/mod.rs - git::MockGitOperations::get_current_branch (line 174) - compile ... ok [INFO] [stdout] test src/git/mod.rs - git::MockGitOperations::get_diff_stats (line 200) - compile ... ok [INFO] [stdout] test src/lib.rs - (line 34) ... ignored [INFO] [stdout] test src/lib.rs - ui (line 120) ... ignored [INFO] [stdout] test src/error.rs - error::GcopError::localized_suggestion (line 401) ... ok [INFO] [stdout] test src/error.rs - error::GcopError (line 46) ... ok [INFO] [stdout] test src/llm/mod.rs - llm::LLMProvider (line 105) - compile ... ok [INFO] [stdout] test src/git/mod.rs - git::GitOperations::get_diff_stats (line 200) - compile ... ok [INFO] [stdout] test src/commands/commit_state_machine.rs - commands::commit_state_machine::CommitState::is_at_max_retries (line 190) ... ok [INFO] [stdout] test src/llm/provider/backends/claude.rs - llm::provider::backends::claude::ClaudeProvider (line 94) ... ignored [INFO] [stdout] test src/llm/provider/backends/ollama.rs - llm::provider::backends::ollama::OllamaProvider (line 51) ... ignored [INFO] [stdout] test src/llm/provider/backends/openai.rs - llm::provider::backends::openai::OpenAIProvider (line 60) ... ignored [INFO] [stdout] test src/llm/provider/base/validation.rs - llm::provider::base::validation::validate_http_endpoint (line 58) ... ignored [INFO] [stdout] test src/git/mod.rs - git::DiffStats (line 271) ... ok [INFO] [stdout] test src/llm/mod.rs - llm::StreamHandle (line 57) - compile ... ok [INFO] [stdout] test src/llm/mod.rs - llm::CommitContext (line 296) ... ok [INFO] [stdout] test src/llm/provider/base/validation.rs - llm::provider::base::validation::validate_api_key (line 20) ... ok [INFO] [stdout] test src/llm/mod.rs - llm::ReviewResult (line 370) ... ok [INFO] [stdout] test src/llm/provider/utils.rs - llm::provider::utils::complete_endpoint (line 34) ... ok [INFO] [stdout] test src/commands/mod.rs - commands::commit_state_machine (line 52) - compile ... ok [INFO] [stdout] test src/error.rs - error::GcopError::localized_message (line 303) ... ok [INFO] [stdout] test src/llm/provider/utils.rs - llm::provider::utils::mask_api_key (line 121) ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 27 passed; 0 failed; 6 ignored; 0 measured; 0 filtered out; finished in 0.03s [INFO] [stdout] [INFO] [stdout] all doctests ran in 2.65s; merged doctests compilation took 2.43s [INFO] running `Command { std: "docker" "inspect" "c72d982b4d4d5190946f6f8522d081f239656df42b6c1e67b716e9d92ead9122", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c72d982b4d4d5190946f6f8522d081f239656df42b6c1e67b716e9d92ead9122", kill_on_drop: false }` [INFO] [stdout] c72d982b4d4d5190946f6f8522d081f239656df42b6c1e67b716e9d92ead9122