[INFO] fetching crate ambient-fs-server 0.1.1... [INFO] testing ambient-fs-server-0.1.1 against try#8da20828b6ea601dfd8e2448cb50ace88876bd78 for pr-150933 [INFO] extracting crate ambient-fs-server 0.1.1 into /workspace/builds/worker-5-tc2/source [INFO] started tweaking crates.io crate ambient-fs-server 0.1.1 [INFO] finished tweaking crates.io crate ambient-fs-server 0.1.1 [INFO] tweaked toml for crates.io crate ambient-fs-server 0.1.1 written to /workspace/builds/worker-5-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate ambient-fs-server 0.1.1 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 crates.io crate ambient-fs-server 0.1.1 already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+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] d0486d24f55629ee7ae8cc20474df528e35cf94ee595611a31e5bbcfc6159574 [INFO] running `Command { std: "docker" "start" "-a" "d0486d24f55629ee7ae8cc20474df528e35cf94ee595611a31e5bbcfc6159574", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "d0486d24f55629ee7ae8cc20474df528e35cf94ee595611a31e5bbcfc6159574", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "d0486d24f55629ee7ae8cc20474df528e35cf94ee595611a31e5bbcfc6159574", kill_on_drop: false }` [INFO] [stdout] d0486d24f55629ee7ae8cc20474df528e35cf94ee595611a31e5bbcfc6159574 [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] 783434c3da4b551c260d2bd7babf346b80704d2b3c7f768853c29ca37b7ba6b2 [INFO] running `Command { std: "docker" "start" "-a" "783434c3da4b551c260d2bd7babf346b80704d2b3c7f768853c29ca37b7ba6b2", kill_on_drop: false }` [INFO] [stderr] Compiling quote v1.0.44 [INFO] [stderr] Compiling libc v0.2.182 [INFO] [stderr] Compiling futures-core v0.3.32 [INFO] [stderr] Compiling memchr v2.8.0 [INFO] [stderr] Compiling futures-sink v0.3.32 [INFO] [stderr] Compiling slab v0.4.12 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling futures-task v0.3.32 [INFO] [stderr] Compiling futures-io v0.3.32 [INFO] [stderr] Compiling hashbrown v0.16.1 [INFO] [stderr] Compiling bitflags v2.11.0 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling anyhow v1.0.101 [INFO] [stderr] Compiling itertools v0.14.0 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling getrandom v0.4.1 [INFO] [stderr] Compiling zerocopy v0.8.39 [INFO] [stderr] Compiling futures-channel v0.3.32 [INFO] [stderr] Compiling syn v2.0.116 [INFO] [stderr] Compiling sync_wrapper v1.0.2 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling rustix v1.1.3 [INFO] [stderr] Compiling regex-syntax v0.8.9 [INFO] [stderr] Compiling bytes v1.11.1 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling linux-raw-sys v0.11.0 [INFO] [stderr] Compiling fastrand v2.3.0 [INFO] [stderr] Compiling iana-time-zone v0.1.65 [INFO] [stderr] Compiling native-tls v0.2.16 [INFO] [stderr] Compiling indexmap v2.13.0 [INFO] [stderr] Compiling unicode-segmentation v1.12.0 [INFO] [stderr] Compiling indexmap v1.9.3 [INFO] [stderr] Compiling unicase v2.9.0 [INFO] [stderr] Compiling unicode-xid v0.2.6 [INFO] [stderr] Compiling nom v7.1.3 [INFO] [stderr] Compiling convert_case v0.10.0 [INFO] [stderr] Compiling mime_guess v2.0.5 [INFO] [stderr] Compiling hashlink v0.11.0 [INFO] [stderr] Compiling notify-types v2.1.0 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Compiling errno v0.3.14 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling mio v1.1.1 [INFO] [stderr] Compiling signal-hook-registry v1.4.8 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling socket2 v0.6.2 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling petgraph v0.7.1 [INFO] [stderr] Compiling inotify-sys v0.1.5 [INFO] [stderr] Compiling inotify v0.11.0 [INFO] [stderr] Compiling tempfile v3.25.0 [INFO] [stderr] Compiling fallible-streaming-iterator v0.1.9 [INFO] [stderr] Compiling ryu v1.0.23 [INFO] [stderr] Compiling fallible-iterator v0.3.0 [INFO] [stderr] Compiling matchit v0.7.3 [INFO] [stderr] Compiling constant_time_eq v0.4.2 [INFO] [stderr] Compiling notify v8.2.0 [INFO] [stderr] Compiling socket2 v0.5.10 [INFO] [stderr] Compiling hostname v0.4.2 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling cmake v0.1.57 [INFO] [stderr] Compiling openssl-sys v0.9.111 [INFO] [stderr] Compiling libsqlite3-sys v0.36.0 [INFO] [stderr] Compiling blake3 v1.8.3 [INFO] [stderr] Compiling aws-lc-sys v0.37.1 [INFO] [stderr] Compiling eventsource-stream v0.2.3 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling darling_core v0.21.3 [INFO] [stderr] Compiling prettyplease v0.2.37 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling futures-macro v0.3.32 [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 prost-derive v0.13.5 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling pin-project-internal v1.1.10 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling derive_more-impl v2.1.1 [INFO] [stderr] Compiling async-stream-impl v0.3.6 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling async-stream v0.3.6 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling prost v0.13.5 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling pin-project v1.1.10 [INFO] [stderr] Compiling darling_macro v0.21.3 [INFO] [stderr] Compiling prost-types v0.13.5 [INFO] [stderr] Compiling darling v0.21.3 [INFO] [stderr] Compiling serde_with_macros v3.16.1 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling derive_more v2.1.1 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling prost-build v0.13.5 [INFO] [stderr] Compiling serde_with v3.16.1 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling chrono v0.4.43 [INFO] [stderr] Compiling futures-executor v0.3.32 [INFO] [stderr] Compiling axum-core v0.4.5 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling value-ext v0.1.3 [INFO] [stderr] Compiling tonic-build v0.12.3 [INFO] [stderr] Compiling futures v0.3.32 [INFO] [stderr] Compiling ambient-fs-server v0.1.1 (/opt/rustwide/workdir) [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling ambient-fs-core v0.1.1 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tokio-stream v0.1.18 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling ambient-fs-analyzer v0.1.1 [INFO] [stderr] Compiling ambient-fs-watcher v0.1.1 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling tower v0.4.13 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling axum v0.7.9 [INFO] [stderr] Compiling rusqlite v0.38.0 [INFO] [stderr] Compiling ambient-fs-store v0.1.1 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling hyper-timeout v0.5.2 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling tonic v0.12.3 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling aws-lc-rs v1.15.4 [INFO] [stderr] Compiling rustls v0.23.36 [INFO] [stderr] Compiling rustls-webpki v0.103.9 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling rustls-platform-verifier v0.6.2 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling reqwest v0.13.2 [INFO] [stderr] Compiling genai v0.5.3 [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 14s [INFO] running `Command { std: "docker" "inspect" "783434c3da4b551c260d2bd7babf346b80704d2b3c7f768853c29ca37b7ba6b2", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "783434c3da4b551c260d2bd7babf346b80704d2b3c7f768853c29ca37b7ba6b2", kill_on_drop: false }` [INFO] [stdout] 783434c3da4b551c260d2bd7babf346b80704d2b3c7f768853c29ca37b7ba6b2 [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] 3ba3b791eb8cf1fb51fd4601727e639bf08d2a6fedb3631017aba98f37b5c71d [INFO] running `Command { std: "docker" "start" "-a" "3ba3b791eb8cf1fb51fd4601727e639bf08d2a6fedb3631017aba98f37b5c71d", kill_on_drop: false }` [INFO] [stderr] Compiling bitflags v2.11.0 [INFO] [stderr] Compiling getrandom v0.4.1 [INFO] [stderr] Compiling diff v0.1.13 [INFO] [stderr] Compiling yansi v1.0.1 [INFO] [stderr] Compiling rustix v1.1.3 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling inotify v0.11.0 [INFO] [stderr] Compiling notify-types v2.1.0 [INFO] [stderr] Compiling rusqlite v0.38.0 [INFO] [stderr] Compiling pretty_assertions v1.4.1 [INFO] [stderr] Compiling reqwest v0.13.2 [INFO] [stderr] Compiling notify v8.2.0 [INFO] [stderr] Compiling ambient-fs-store v0.1.1 [INFO] [stderr] Compiling ambient-fs-watcher v0.1.1 [INFO] [stderr] Compiling tempfile v3.25.0 [INFO] [stderr] Compiling prost-build v0.13.5 [INFO] [stderr] Compiling tonic-build v0.12.3 [INFO] [stderr] Compiling genai v0.5.3 [INFO] [stderr] Compiling ambient-fs-server v0.1.1 (/opt/rustwide/workdir) [INFO] [stderr] Compiling native-tls v0.2.16 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stdout] warning: unused import: `tempfile::tempdir` [INFO] [stdout] --> src/grpc.rs:494:9 [INFO] [stdout] | [INFO] [stdout] 494 | use tempfile::tempdir; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `NamedTempFile` [INFO] [stdout] --> src/pipeline.rs:259:29 [INFO] [stdout] | [INFO] [stdout] 259 | use tempfile::{TempDir, NamedTempFile}; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tempfile::tempdir` [INFO] [stdout] --> src/state.rs:163:9 [INFO] [stdout] | [INFO] [stdout] 163 | use tempfile::tempdir; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Source` [INFO] [stdout] --> src/state.rs:314:60 [INFO] [stdout] | [INFO] [stdout] 314 | use ambient_fs_core::event::{FileEvent, EventType, Source}; [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Source` [INFO] [stdout] --> src/tree_state.rs:215:56 [INFO] [stdout] | [INFO] [stdout] 215 | use ambient_fs_core::event::{FileEvent, EventType, Source}; [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::Utc` [INFO] [stdout] --> src/tree_state.rs:216:9 [INFO] [stdout] | [INFO] [stdout] 216 | use chrono::Utc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/gateway.rs:329:13 [INFO] [stdout] | [INFO] [stdout] 329 | let mut conn = DaemonConnection::new("machine-1".to_string(), tx); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `service` [INFO] [stdout] --> src/gateway.rs:638:13 [INFO] [stdout] | [INFO] [stdout] 638 | let service = GatewayServiceImpl::new(gateway); [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_service` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `file` [INFO] [stdout] --> src/pipeline.rs:339:13 [INFO] [stdout] | [INFO] [stdout] 339 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `file` [INFO] [stdout] --> src/pipeline.rs:366:13 [INFO] [stdout] | [INFO] [stdout] 366 | let file = create_test_file(temp.path(), "test.rs", "fn main() {\n // TODO: fix\n}\n"); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `file` [INFO] [stdout] --> src/pipeline.rs:383:13 [INFO] [stdout] | [INFO] [stdout] 383 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `file` [INFO] [stdout] --> src/pipeline.rs:404:13 [INFO] [stdout] | [INFO] [stdout] 404 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `file` [INFO] [stdout] --> src/pipeline.rs:421:13 [INFO] [stdout] | [INFO] [stdout] 421 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `file` [INFO] [stdout] --> src/pipeline.rs:456:13 [INFO] [stdout] | [INFO] [stdout] 456 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `file` [INFO] [stdout] --> src/pipeline.rs:476:13 [INFO] [stdout] | [INFO] [stdout] 476 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `tx` [INFO] [stdout] --> src/socket.rs:2060:14 [INFO] [stdout] | [INFO] [stdout] 2060 | let (tx, rx) = broadcast::channel(1); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_tx` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `tx` [INFO] [stdout] --> src/socket.rs:2069:14 [INFO] [stdout] | [INFO] [stdout] 2069 | let (tx, rx) = broadcast::channel(1); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_tx` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `tx` [INFO] [stdout] --> src/socket.rs:2089:14 [INFO] [stdout] | [INFO] [stdout] 2089 | let (tx, rx) = broadcast::channel(1); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_tx` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/state.rs:310:13 [INFO] [stdout] | [INFO] [stdout] 310 | let mut rx = state.subscriptions.subscribe("test-project").await; [INFO] [stdout] | ----^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rx` [INFO] [stdout] --> src/state.rs:310:13 [INFO] [stdout] | [INFO] [stdout] 310 | let mut rx = state.subscriptions.subscribe("test-project").await; [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_rx` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/sync.rs:341:13 [INFO] [stdout] | [INFO] [stdout] 341 | let mut mgr = SyncManager::new(state, peers); [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 28.30s [INFO] running `Command { std: "docker" "inspect" "3ba3b791eb8cf1fb51fd4601727e639bf08d2a6fedb3631017aba98f37b5c71d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "3ba3b791eb8cf1fb51fd4601727e639bf08d2a6fedb3631017aba98f37b5c71d", kill_on_drop: false }` [INFO] [stdout] 3ba3b791eb8cf1fb51fd4601727e639bf08d2a6fedb3631017aba98f37b5c71d [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] 4fec32fb7bd2f8ba1675d8455253cef1c4a87b56e9e3d3320db2c88ab3e0520c [INFO] running `Command { std: "docker" "start" "-a" "4fec32fb7bd2f8ba1675d8455253cef1c4a87b56e9e3d3320db2c88ab3e0520c", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `tempfile::tempdir` [INFO] [stderr] --> src/grpc.rs:494:9 [INFO] [stderr] | [INFO] [stderr] 494 | use tempfile::tempdir; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `NamedTempFile` [INFO] [stderr] --> src/pipeline.rs:259:29 [INFO] [stderr] | [INFO] [stderr] 259 | use tempfile::{TempDir, NamedTempFile}; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tempfile::tempdir` [INFO] [stderr] --> src/state.rs:163:9 [INFO] [stderr] | [INFO] [stderr] 163 | use tempfile::tempdir; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Source` [INFO] [stderr] --> src/state.rs:314:60 [INFO] [stderr] | [INFO] [stderr] 314 | use ambient_fs_core::event::{FileEvent, EventType, Source}; [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Source` [INFO] [stderr] --> src/tree_state.rs:215:56 [INFO] [stderr] | [INFO] [stderr] 215 | use ambient_fs_core::event::{FileEvent, EventType, Source}; [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `chrono::Utc` [INFO] [stderr] --> src/tree_state.rs:216:9 [INFO] [stderr] | [INFO] [stderr] 216 | use chrono::Utc; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/gateway.rs:329:13 [INFO] [stderr] | [INFO] [stderr] 329 | let mut conn = DaemonConnection::new("machine-1".to_string(), tx); [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `service` [INFO] [stderr] --> src/gateway.rs:638:13 [INFO] [stderr] | [INFO] [stderr] 638 | let service = GatewayServiceImpl::new(gateway); [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_service` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `file` [INFO] [stderr] --> src/pipeline.rs:339:13 [INFO] [stderr] | [INFO] [stderr] 339 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `file` [INFO] [stderr] --> src/pipeline.rs:366:13 [INFO] [stderr] | [INFO] [stderr] 366 | let file = create_test_file(temp.path(), "test.rs", "fn main() {\n // TODO: fix\n}\n"); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `file` [INFO] [stderr] --> src/pipeline.rs:383:13 [INFO] [stderr] | [INFO] [stderr] 383 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `file` [INFO] [stderr] --> src/pipeline.rs:404:13 [INFO] [stderr] | [INFO] [stderr] 404 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `file` [INFO] [stderr] --> src/pipeline.rs:421:13 [INFO] [stderr] | [INFO] [stderr] 421 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `file` [INFO] [stderr] --> src/pipeline.rs:456:13 [INFO] [stderr] | [INFO] [stderr] 456 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `file` [INFO] [stderr] --> src/pipeline.rs:476:13 [INFO] [stderr] | [INFO] [stderr] 476 | let file = create_test_file(temp.path(), "test.rs", "fn main() {}\n"); [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `tx` [INFO] [stderr] --> src/socket.rs:2060:14 [INFO] [stderr] | [INFO] [stderr] 2060 | let (tx, rx) = broadcast::channel(1); [INFO] [stderr] | ^^ help: if this is intentional, prefix it with an underscore: `_tx` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `tx` [INFO] [stderr] --> src/socket.rs:2069:14 [INFO] [stderr] | [INFO] [stderr] 2069 | let (tx, rx) = broadcast::channel(1); [INFO] [stderr] | ^^ help: if this is intentional, prefix it with an underscore: `_tx` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `tx` [INFO] [stderr] --> src/socket.rs:2089:14 [INFO] [stderr] | [INFO] [stderr] 2089 | let (tx, rx) = broadcast::channel(1); [INFO] [stderr] | ^^ help: if this is intentional, prefix it with an underscore: `_tx` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/state.rs:310:13 [INFO] [stderr] | [INFO] [stderr] 310 | let mut rx = state.subscriptions.subscribe("test-project").await; [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `rx` [INFO] [stderr] --> src/state.rs:310:13 [INFO] [stderr] | [INFO] [stderr] 310 | let mut rx = state.subscriptions.subscribe("test-project").await; [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_rx` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/sync.rs:341:13 [INFO] [stderr] | [INFO] [stderr] 341 | let mut mgr = SyncManager::new(state, peers); [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: `ambient-fs-server` (lib test) generated 21 warnings (run `cargo fix --lib -p ambient-fs-server --tests` to apply 21 suggestions) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.50s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/ambient_fs_server-37e59b26db715742) [INFO] [stdout] [INFO] [stdout] running 265 tests [INFO] [stdout] test agents::tests::activity_new_creates_minimal ... ok [INFO] [stdout] test agents::tests::activity_is_done_checks_flag ... ok [INFO] [stdout] test agents::tests::calculate_pass_rate_empty_returns_one ... ok [INFO] [stdout] test agents::tests::active_agent_count_excludes_stale ... ok [INFO] [stdout] test agents::tests::calculate_pass_rate_all_valid ... ok [INFO] [stdout] test agents::tests::activity_serialize_minimal ... ok [INFO] [stdout] test agents::tests::activity_timestamp_parses_unix_ts ... ok [INFO] [stdout] test agents::tests::agent_count_includes_stale ... ok [INFO] [stdout] test agents::tests::agent_completes_file_work ... ok [INFO] [stdout] test agents::tests::agent_count_returns_zero_initially ... ok [INFO] [stdout] test agents::tests::calculate_pass_rate_none_valid ... ok [INFO] [stdout] test agents::tests::calculate_pass_rate_mixed ... ok [INFO] [stdout] test agents::tests::get_active_agent_returns_agent_with_file ... ok [INFO] [stdout] test agents::tests::get_all_agents_returns_empty_initially ... ok [INFO] [stdout] test agents::tests::new_creates_tracker ... ok [INFO] [stdout] test agents::tests::get_all_agents_excludes_stale ... ok [INFO] [stdout] test agents::tests::get_reference_count_accumulates_multiple_activities ... ok [INFO] [stdout] test agents::tests::get_reference_count_survives_done_activity ... ok [INFO] [stdout] test agents::tests::get_reference_count_returns_zero_for_unknown_file ... ok [INFO] [stdout] test agents::tests::process_line_invalid_json_returns_none ... ok [INFO] [stdout] test agents::tests::calculate_pass_rate_with_empty_lines ... ok [INFO] [stdout] test agents::tests::process_line_empty_string_fields_returns_none ... ok [INFO] [stdout] test agents::tests::get_active_agent_multiple_files_per_agent ... ok [INFO] [stdout] test agents::tests::get_active_agent_returns_most_recent ... ok [INFO] [stdout] test agents::tests::get_active_agent_returns_none_for_unknown_file ... ok [INFO] [stdout] test agents::tests::get_reference_count_increments_on_activity ... ok [INFO] [stdout] test agents::tests::multiple_agents_different_files ... ok [INFO] [stdout] test agents::tests::process_line_missing_required_field_returns_none ... ok [INFO] [stdout] test agents::tests::process_line_valid_json_returns_activity ... ok [INFO] [stdout] test agents::tests::process_line_with_whitespace ... ok [INFO] [stdout] test agents::tests::process_line_with_optional_fields ... ok [INFO] [stdout] test agents::tests::prune_stale_preserves_counts_for_shared_files ... ok [INFO] [stdout] test agents::tests::prune_stale_removes_old_agents ... ok [INFO] [stdout] test agents::tests::update_creates_new_agent ... ok [INFO] [stdout] test agents::tests::update_done_removes_file_from_active ... ok [INFO] [stdout] test agents::tests::prune_stale_resets_counts_for_stale_agent_files ... ok [INFO] [stdout] test agents::tests::update_updates_last_seen ... ok [INFO] [stdout] test agents::tests::prune_stale_returns_zero_when_no_stale ... ok [INFO] [stdout] test agents::tests::state_is_stale_timeout ... ok [INFO] [stdout] test agents::tests::state_new_creates_empty ... ok [INFO] [stdout] test agents::tests::update_copies_intent_and_tool ... ok [INFO] [stdout] test agents::tests::update_adds_file_to_agent ... ok [INFO] [stdout] test agents::tests::update_does_not_duplicate_files ... ok [INFO] [stdout] test agents::tests::with_default_timeout_uses_5_minutes ... ok [INFO] [stdout] test agents::tests::activity_serialize_full ... ok [INFO] [stdout] test agents::tests::agent_transitions_between_files ... ok [INFO] [stdout] test agents::tests::get_active_agent_skips_stale_agents ... ok [INFO] [stdout] test agents::tests::get_reference_count_tracks_multiple_files_independently ... ok [INFO] [stdout] test gateway::tests::forward_event_to_multiple_daemons ... ok [INFO] [stdout] test gateway::tests::forward_event_does_not_go_back_to_sender ... ok [INFO] [stdout] test gateway::tests::buffer_event_adds_to_buffer ... ok [INFO] [stdout] test gateway::tests::get_buffered_events_returns_empty_for_unknown_project ... ok [INFO] [stdout] test gateway::tests::forward_event_to_other_daemons ... ok [INFO] [stdout] test gateway::tests::get_buffered_events_returns_all_for_project ... ok [INFO] [stdout] test gateway::tests::new_creates_connection_with_timestamps ... ok [INFO] [stdout] test gateway::tests::is_stale_returns_true_when_timeout_exceeded ... ok [INFO] [stdout] test gateway::tests::register_daemon_adds_to_routing_table ... ok [INFO] [stdout] test gateway::tests::buffer_evicts_oldest_when_full ... ok [INFO] [stdout] test gateway::tests::register_daemons_different_projects ... ok [INFO] [stdout] test gateway::tests::register_multiple_daemons_same_project ... ok [INFO] [stdout] test gateway::tests::register_with_empty_project_id_returns_error ... ok [INFO] [stdout] test gateway::tests::register_with_empty_machine_id_returns_error ... ok [INFO] [stdout] test gateway::tests::register_with_valid_params_succeeds ... ok [INFO] [stdout] test gateway::tests::unregister_daemon_removes_from_routing_table ... ok [INFO] [stdout] test gateway::tests::unregister_nonexistent_daemon_is_noop ... ok [INFO] [stdout] test gateway::tests::unregister_one_daemon_leaves_others ... ok [INFO] [stdout] test grpc::tests::addr_returns_configured_address ... ok [INFO] [stdout] test grpc::tests::file_event_to_message_preserves_data ... ok [INFO] [stdout] test grpc::tests::file_event_to_message_with_all_event_types ... ok [INFO] [stdout] test grpc::tests::file_event_to_message_with_all_sources ... ok [INFO] [stdout] test grpc::tests::file_event_to_message_with_old_path ... ok [INFO] [stdout] test grpc::tests::message_to_file_event_invalid_event_type_returns_none ... ok [INFO] [stdout] test grpc::tests::message_to_file_event_invalid_source_returns_none ... ok [INFO] [stdout] test grpc::tests::message_to_file_event_roundtrip ... ok [INFO] [stdout] test grpc::tests::message_to_file_event_with_renamed_event ... ok [INFO] [stdout] test grpc::tests::new_creates_server_with_state ... ok [INFO] [stdout] test grpc::tests::protocol_error_creates_status_with_code ... ok [INFO] [stdout] test grpc::tests::protocol_error_with_invalid_argument ... ok [INFO] [stdout] test grpc::tests::service_impl_constructor ... ok [INFO] [stdout] test gateway::tests::update_last_seen_refreshes_timestamp ... ok [INFO] [stdout] test agents::tests::process_line_empty_returns_none ... ok [INFO] [stdout] test gateway::tests::new_creates_server_with_addr ... ok [INFO] [stdout] test gateway::tests::new_service_impl_creates_instance ... ok [INFO] [stdout] test awareness::tests::build_awareness_with_no_event_returns_none ... ok [INFO] [stdout] test awareness::tests::build_awareness_change_frequency_calculated_from_event_age ... ok [INFO] [stdout] test awareness::tests::build_awareness_with_activity_has_nonzero_chat_references ... ok [INFO] [stdout] test awareness::tests::build_awareness_missing_cache_returns_zeros ... ok [INFO] [stdout] test awareness::tests::build_awareness_filters_by_project_and_file ... ok [INFO] [stdout] test awareness::tests::build_awareness_with_active_agent_populates_agent_field ... ok [INFO] [stdout] test awareness::tests::build_awareness_with_event_only_returns_partial_awareness ... ok [INFO] [stdout] test awareness::tests::build_awareness_with_source_id_sets_modified_by_label ... ok [INFO] [stdout] test awareness::tests::build_awareness_chat_references_independent_per_file ... ok [INFO] [stdout] test awareness::tests::build_awareness_with_event_and_analysis_returns_full_awareness ... ok [INFO] [stdout] test pipeline::tests::analyze_file_returns_none_for_deleted_event ... ok [INFO] [stdout] test pipeline::tests::analyze_file_returns_none_for_event_without_hash ... ok [INFO] [stdout] test awareness::tests::build_awareness_with_no_activity_has_zero_chat_references ... ok [INFO] [stdout] test pipeline::tests::analyze_file_returns_none_for_renamed_event ... ok [INFO] [stdout] test pipeline::tests::analyze_file_caches_result ... ok [INFO] [stdout] test pipeline::tests::new_creates_pipeline_with_config ... ok [INFO] [stdout] test pipeline::tests::schedule_analysis_does_not_block ... ok [INFO] [stdout] test pipeline::tests::analyze_file_counts_lines_correctly ... ok [INFO] [stdout] test pipeline::tests::analyze_file_analyzes_and_returns_result ... ok [INFO] [stdout] test pipeline::tests::analyze_file_handles_missing_file_gracefully ... ok [INFO] [stdout] test pipeline::tests::with_defaults_uses_default_config ... ok [INFO] [stdout] test protocol::tests::error_response ... ok [INFO] [stdout] test protocol::tests::error_server_specific_codes ... ok [INFO] [stdout] test protocol::tests::error_standard_codes ... ok [INFO] [stdout] test protocol::tests::error_with_data ... ok [INFO] [stdout] test protocol::tests::full_roundtrip_error_response ... ok [INFO] [stdout] test protocol::tests::full_roundtrip_subscribe_request ... ok [INFO] [stdout] test protocol::tests::id_default_is_null ... ok [INFO] [stdout] test protocol::tests::id_null_roundtrip ... ok [INFO] [stdout] test protocol::tests::id_number_roundtrip ... ok [INFO] [stdout] test protocol::tests::id_string_roundtrip ... ok [INFO] [stdout] test protocol::tests::method_from_str_invalid ... ok [INFO] [stdout] test protocol::tests::method_from_str_valid ... ok [INFO] [stdout] test protocol::tests::method_to_string ... ok [INFO] [stdout] test protocol::tests::notification_has_no_id ... ok [INFO] [stdout] test protocol::tests::notification_parse ... ok [INFO] [stdout] test protocol::tests::params_array_roundtrip ... ok [INFO] [stdout] test protocol::tests::params_object_roundtrip ... ok [INFO] [stdout] test protocol::tests::params_optional_serialize_none ... ok [INFO] [stdout] test protocol::tests::request_with_array_params ... ok [INFO] [stdout] test pipeline::tests::analyze_file_handles_empty_file ... ok [INFO] [stdout] test protocol::tests::request_with_id_is_not_notification ... ok [INFO] [stdout] test protocol::tests::request_with_object_params ... ok [INFO] [stdout] test protocol::tests::request_without_params ... ok [INFO] [stdout] test protocol::tests::response_error_serialize_error_only ... ok [INFO] [stdout] test protocol::tests::response_success_serialize_result_only ... ok [INFO] [stdout] test protocol::tests::success_response ... ok [INFO] [stdout] test socket::tests::bind_creates_socket_file ... ok [INFO] [stdout] test pipeline::tests::analyze_file_counts_todos_correctly ... ok [INFO] [stdout] test socket::tests::bind_twice_returns_error ... ok [INFO] [stdout] test socket::tests::bind_removes_existing_file ... ok [INFO] [stdout] test socket::tests::connection_state_add_subscription ... ok [INFO] [stdout] test socket::tests::connection_state_get_receiver ... ok [INFO] [stdout] test socket::tests::connection_state_new_starts_empty ... ok [INFO] [stdout] test socket::tests::connection_state_remove_nonexistent_returns_false ... ok [INFO] [stdout] test socket::tests::connection_state_remove_subscription ... ok [INFO] [stdout] test pipeline::tests::analyze_file_reanalyzes_when_hash_changes ... ok [INFO] [stdout] test pipeline::tests::schedule_analysis_handles_invalid_path ... ok [INFO] [stdout] test pipeline::tests::semaphore_limits_concurrent_analysis_to_max_concurrent ... ok [INFO] [stdout] test pipeline::tests::schedule_analysis_spawn_completes_analysis ... ok [INFO] [stdout] test protocol::tests::response_with_null_id ... ok [INFO] [stdout] test pipeline::tests::analyze_file_returns_none_on_second_call_with_same_hash ... ok [INFO] [stdout] test socket::tests::new_creates_server_with_path ... ok [INFO] [stdout] test pipeline::tests::analyze_file_returns_none_when_cache_is_fresh ... ok [INFO] [stdout] test llm::tests::custom_provider_reads_openai_api_key ... ok [INFO] [stdout] test socket::tests::multiple_concurrent_connections ... ok [INFO] [stdout] test socket::tests::handle_empty_lines_ignored ... ok [INFO] [stdout] test socket::tests::multiple_subscriptions_per_connection ... ok [INFO] [stdout] test socket::tests::multiple_requests_on_same_connection ... ok [INFO] [stdout] test socket::tests::handle_invalid_json_returns_error ... ok [INFO] [stdout] test socket::tests::shutdown_after_bind_succeeds ... ok [INFO] [stdout] test socket::tests::shutdown_before_bind_returns_ok ... ok [INFO] [stdout] test socket::tests::client_disconnect_handled_gracefully ... ok [INFO] [stdout] test socket::tests::query_events_with_invalid_params_type_returns_error ... ok [INFO] [stdout] test socket::tests::query_events_returns_empty_array ... ok [INFO] [stdout] test socket::tests::query_events_with_real_db_returns_events ... ok [INFO] [stdout] test socket::tests::query_events_with_limit ... ok [INFO] [stdout] test socket::tests::subscribe_without_params_returns_error ... ok [INFO] [stdout] test socket::tests::run_accepts_connections ... ok [INFO] [stdout] test socket::tests::query_events_with_source_filter ... ok [INFO] [stdout] test socket::tests::subscribe_returns_project_id ... ok [INFO] [stdout] test state::tests::add_project_inserts_mapping ... ok [INFO] [stdout] test socket::tests::subscribe_without_project_id_returns_error ... ok [INFO] [stdout] test socket::tests::query_events_with_project_id_filter ... ok [INFO] [stdout] test socket::tests::unsubscribe_returns_true ... ok [INFO] [stdout] test socket::tests::subscribe_request_returns_success ... ok [INFO] [stdout] test state::tests::add_multiple_projects ... ok [INFO] [stdout] test socket::tests::unknown_method_returns_error ... ok [INFO] [stdout] test state::tests::add_tree_stores_tree ... ok [INFO] [stdout] test state::tests::add_project_overwrites_existing ... ok [INFO] [stdout] test state::tests::add_watcher_stores_watcher ... ok [INFO] [stdout] test socket::tests::run_ends_on_shutdown_signal ... ok [INFO] [stdout] test state::tests::list_projects_returns_all_ids ... ok [INFO] [stdout] test state::tests::list_projects_returns_empty_initially ... ok [INFO] [stdout] test state::tests::get_project_returns_none_for_unknown ... ok [INFO] [stdout] test state::tests::clone_shares_same_state ... ok [INFO] [stdout] test state::tests::get_project_returns_path_for_known ... ok [INFO] [stdout] test state::tests::has_project_returns_true_after_add ... ok [INFO] [stdout] test state::tests::new_has_empty_projects ... ok [INFO] [stdout] test state::tests::remove_nonexistent_project_returns_none ... ok [INFO] [stdout] test state::tests::new_creates_state_with_store_path ... ok [INFO] [stdout] test state::tests::remove_nonexistent_tree_returns_none ... ok [INFO] [stdout] test llm::tests::different_models_all_enable_feature ... ok [INFO] [stdout] test llm::tests::from_env_returns_none_when_model_not_set ... ok [INFO] [stdout] test subscriptions::tests::active_projects_lists_subscribed ... ok [INFO] [stdout] test subscriptions::tests::broadcast_reaches_multiple_subscribers_same_project ... ok [INFO] [stdout] test subscriptions::tests::broadcast_reaches_subscribers ... ok [INFO] [stdout] test subscriptions::tests::broadcast_with_no_subscribers_returns_zero ... ok [INFO] [stdout] test subscriptions::tests::different_projects_independent ... ok [INFO] [stdout] test state::tests::new_has_empty_trees ... ok [INFO] [stdout] test subscriptions::tests::dropping_receiver_decreases_count ... ok [INFO] [stdout] test state::tests::has_project_returns_false_for_empty ... ok [INFO] [stdout] test subscriptions::tests::mixed_notifications_all_delivered ... ok [INFO] [stdout] test subscriptions::tests::explicit_unsubscribe_decreases_count ... ok [INFO] [stdout] test subscriptions::tests::multiple_events_broadcast_correctly ... ok [INFO] [stdout] test subscriptions::tests::publish_awareness_sends_awareness_notification ... ok [INFO] [stdout] test subscriptions::tests::publish_event_sends_event_notification ... ok [INFO] [stdout] test subscriptions::tests::publish_analysis_sends_analysis_notification ... ok [INFO] [stdout] test subscriptions::tests::subscriber_count_increases ... ok [INFO] [stdout] test subscriptions::tests::broadcast_does_not_cross_projects ... ok [INFO] [stdout] test subscriptions::tests::subscribe_returns_receiver ... ok [INFO] [stdout] test subscriptions::tests::unsubscribe_removes_project_channel_when_zero ... ok [INFO] [stdout] test subscriptions::tests::notification_serializes_to_json ... ok [INFO] [stdout] test sync::tests::new_creates_config_with_addr_and_project ... ok [INFO] [stdout] test state::tests::remove_watcher_removes_from_state ... ok [INFO] [stdout] test state::tests::new_has_empty_watchers ... ok [INFO] [stdout] test state::tests::remove_project_deletes_mapping ... ok [INFO] [stdout] test state::tests::new_has_machine_id ... ok [INFO] [stdout] test sync::tests::new_with_string_types ... ok [INFO] [stdout] test sync::tests::peer_config_partial_eq ... ok [INFO] [stdout] test sync::tests::sync_error_connection_display ... ok [INFO] [stdout] test sync::tests::sync_error_conversion_display ... ok [INFO] [stdout] test sync::tests::sync_error_rpc_display ... ok [INFO] [stdout] test sync::tests::sync_error_store_display ... ok [INFO] [stdout] test sync::tests::sync_error_stream_display ... ok [INFO] [stdout] test state::tests::remove_nonexistent_watcher_returns_none ... ok [INFO] [stdout] test state::tests::subscriptions_field_accessible ... ok [INFO] [stdout] test state::tests::remove_tree_removes_from_state ... ok [INFO] [stdout] test tree_state::tests::apply_event_created_adds_directory ... ok [INFO] [stdout] test tree_state::tests::apply_event_created_adds_file ... ok [INFO] [stdout] test tree_state::tests::apply_event_created_duplicate_returns_none ... ok [INFO] [stdout] test tree_state::tests::apply_event_deleted_nonexistent_returns_none ... ok [INFO] [stdout] test tree_state::tests::apply_event_deleted_removes_file ... ok [INFO] [stdout] test llm::tests::from_env_returns_some_when_model_set ... ok [INFO] [stdout] test tree_state::tests::apply_event_modified_returns_none ... ok [INFO] [stdout] test tree_state::tests::apply_event_renamed_with_old_path_works ... ok [INFO] [stdout] test tree_state::tests::apply_event_renamed_without_old_path_returns_none ... ok [INFO] [stdout] test tree_state::tests::apply_rename_moves_node ... ok [INFO] [stdout] test tree_state::tests::apply_rename_nonexistent_returns_none ... ok [INFO] [stdout] test tree_state::tests::apply_rename_to_existing_returns_none ... ok [INFO] [stdout] test tree_state::tests::find_locates_directory ... ok [INFO] [stdout] test tree_state::tests::find_locates_existing_file ... ok [INFO] [stdout] test state::tests::with_machine_id_uses_custom_id ... ok [INFO] [stdout] test tree_state::tests::find_returns_none_for_nonexistent ... ok [INFO] [stdout] test tree_state::tests::from_directory_builds_flat_file_tree ... ok [INFO] [stdout] test tree_state::tests::from_directory_builds_nested_tree ... ok [INFO] [stdout] test tree_state::tests::from_directory_respects_path_filter ... ok [INFO] [stdout] test tree_state::tests::from_directory_skips_symlinks ... ok [INFO] [stdout] test tree_state::tests::from_directory_sorts_dirs_first ... ok [INFO] [stdout] test tree_state::tests::from_directory_handles_non_utf8_names_gracefully ... ok [INFO] [stdout] test tree_state::tests::apply_rename_creates_intermediate_dirs ... ok [INFO] [stdout] test tree_state::tests::full_workflow_scan_modify_delete ... ok [INFO] [stdout] test sync::tests::new_has_empty_last_sync ... ok [INFO] [stdout] test tree_state::tests::new_creates_empty_tree_with_project_id ... ok [INFO] [stdout] test tree_state::tests::tree_patch_add_serializes_correctly ... ok [INFO] [stdout] test tree_state::tests::tree_patch_rename_serializes_correctly ... ok [INFO] [stdout] test tree_state::tests::tree_patch_remove_serializes_correctly ... ok [INFO] [stdout] test tree_state::tests::tree_patch_roundtrips_through_json ... ok [INFO] [stdout] test tree_state::tests::from_directory_stops_at_max_depth ... ok [INFO] [stdout] test sync::tests::with_interval_zero_duration ... ok [INFO] [stdout] test sync::tests::sync_peer_skips_events_from_local_machine_id ... ok [INFO] [stdout] test sync::tests::with_interval_sets_custom_interval ... ok [INFO] [stdout] test sync::tests::new_creates_manager_with_state_and_peers ... ok [INFO] [stdout] test sync::tests::new_has_default_interval_30_seconds ... ok [INFO] [stdout] test sync::tests::event_exists_returns_true_for_duplicate_event ... ok [INFO] [stdout] test sync::tests::event_exists_returns_false_for_new_event ... ok [INFO] [stdout] test sync::tests::new_with_empty_peers ... ok [INFO] [stdout] test llm::tests::model_returns_env_value ... ok [INFO] [stdout] test sync::tests::last_sync_tracks_timestamps_per_peer ... ok [INFO] [stdout] test llm::tests::uses_custom_provider_with_base_url ... ok [INFO] [stdout] test llm::tests::uses_genai_provider_without_base_url ... ok [INFO] [stdout] test tree_state::tests::from_directory_stops_at_max_entries ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 265 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.74s [INFO] [stdout] [INFO] [stderr] Doc-tests ambient_fs_server [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" "4fec32fb7bd2f8ba1675d8455253cef1c4a87b56e9e3d3320db2c88ab3e0520c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4fec32fb7bd2f8ba1675d8455253cef1c4a87b56e9e3d3320db2c88ab3e0520c", kill_on_drop: false }` [INFO] [stdout] 4fec32fb7bd2f8ba1675d8455253cef1c4a87b56e9e3d3320db2c88ab3e0520c