[INFO] fetching crate ambient-fs-server 0.1.1...
[INFO] testing ambient-fs-server-0.1.1 against 1.94.0 for beta-1.95-1
[INFO] extracting crate ambient-fs-server 0.1.1 into /workspace/builds/worker-0-tc1/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-0-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate ambient-fs-server 0.1.1 on toolchain 1.94.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.94.0" "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" "+1.94.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded hostname v0.4.2
[INFO] [stderr]   Downloaded ambient-fs-core v0.1.1
[INFO] [stderr]   Downloaded native-tls v0.2.16
[INFO] [stderr]   Downloaded ambient-fs-store v0.1.1
[INFO] [stderr]   Downloaded webpki-root-certs v1.0.6
[INFO] [stderr]   Downloaded wasm-streams v0.5.0
[INFO] [stderr]   Downloaded ambient-fs-watcher v0.1.1
[INFO] [stderr]   Downloaded aws-lc-rs v1.15.4
[INFO] [stderr]   Downloaded value-ext v0.1.3
[INFO] [stderr]   Downloaded ambient-fs-analyzer v0.1.1
[INFO] [stderr]   Downloaded tonic-build v0.12.3
[INFO] [stderr]   Downloaded genai v0.5.3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 0b2e0f31045fcff6a5e7d693fb035a1985714ce48acdc3e1dc43690cdab55a6e
[INFO] running `Command { std: "docker" "start" "-a" "0b2e0f31045fcff6a5e7d693fb035a1985714ce48acdc3e1dc43690cdab55a6e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "0b2e0f31045fcff6a5e7d693fb035a1985714ce48acdc3e1dc43690cdab55a6e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0b2e0f31045fcff6a5e7d693fb035a1985714ce48acdc3e1dc43690cdab55a6e", kill_on_drop: false }`
[INFO] [stdout] 0b2e0f31045fcff6a5e7d693fb035a1985714ce48acdc3e1dc43690cdab55a6e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 9fabcb0dc3e4b06f7f70da87d9d14525ccb29532fb94a2e8e32ef3c375af1cbb
[INFO] running `Command { std: "docker" "start" "-a" "9fabcb0dc3e4b06f7f70da87d9d14525ccb29532fb94a2e8e32ef3c375af1cbb", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.182
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling log v0.4.29
[INFO] [stderr]    Compiling futures-task v0.3.32
[INFO] [stderr]    Compiling futures-io v0.3.32
[INFO] [stderr]    Compiling quote v1.0.44
[INFO] [stderr]    Compiling futures-channel v0.3.32
[INFO] [stderr]    Compiling http v1.4.0
[INFO] [stderr]    Compiling vcpkg v0.2.15
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling anyhow v1.0.101
[INFO] [stderr]    Compiling aws-lc-rs v1.15.4
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]    Compiling rustls-pki-types v1.14.0
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling openssl-probe v0.2.1
[INFO] [stderr]    Compiling getrandom v0.4.1
[INFO] [stderr]    Compiling rustls v0.23.36
[INFO] [stderr]    Compiling syn v2.0.116
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling zerocopy v0.8.39
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling regex-syntax v0.8.9
[INFO] [stderr]    Compiling bytes v1.11.1
[INFO] [stderr]    Compiling linux-raw-sys v0.11.0
[INFO] [stderr]    Compiling prettyplease v0.2.37
[INFO] [stderr]    Compiling foreign-types-shared v0.1.1
[INFO] [stderr]    Compiling bitflags v2.11.0
[INFO] [stderr]    Compiling native-tls v0.2.16
[INFO] [stderr]    Compiling foreign-types v0.3.2
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling fixedbitset v0.5.7
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling multimap v0.10.1
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling unicase v2.9.0
[INFO] [stderr]    Compiling rustls-native-certs v0.8.3
[INFO] [stderr]    Compiling hashbrown v0.12.3
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling hashlink v0.11.0
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling petgraph v0.7.1
[INFO] [stderr]    Compiling notify-types v2.1.0
[INFO] [stderr]    Compiling arrayvec v0.7.6
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling matchit v0.7.3
[INFO] [stderr]    Compiling fallible-streaming-iterator v0.1.9
[INFO] [stderr]    Compiling fallible-iterator v0.3.0
[INFO] [stderr]    Compiling sharded-slab v0.1.7
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling socket2 v0.6.2
[INFO] [stderr]    Compiling cc v1.2.56
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling inotify-sys v0.1.5
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling inotify v0.11.0
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling nu-ansi-term v0.50.3
[INFO] [stderr]    Compiling notify v8.2.0
[INFO] [stderr]    Compiling hostname v0.4.2
[INFO] [stderr]    Compiling tempfile v3.25.0
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling eventsource-stream v0.2.3
[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 synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.21.3
[INFO] [stderr]    Compiling aws-lc-sys v0.37.1
[INFO] [stderr]    Compiling matchers v0.2.0
[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 ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]    Compiling derive_more-impl v2.1.1
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling async-stream v0.3.6
[INFO] [stderr]    Compiling tracing-subscriber v0.3.22
[INFO] [stderr]    Compiling prost v0.13.5
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling prost-types v0.13.5
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling darling_macro v0.21.3
[INFO] [stderr]    Compiling pin-project v1.1.10
[INFO] [stderr]    Compiling darling v0.21.3
[INFO] [stderr]    Compiling serde_with_macros v3.16.1
[INFO] [stderr]    Compiling derive_more v2.1.1
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling serde_with v3.16.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling prost-build v0.13.5
[INFO] [stderr]    Compiling tonic-build v0.12.3
[INFO] [stderr]    Compiling chrono v0.4.43
[INFO] [stderr]    Compiling value-ext v0.1.3
[INFO] [stderr]    Compiling axum-core v0.4.5
[INFO] [stderr]    Compiling futures-executor v0.3.32
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling futures v0.3.32
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling ambient-fs-server v0.1.1 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling ambient-fs-core v0.1.1
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]    Compiling ambient-fs-analyzer v0.1.1
[INFO] [stderr]    Compiling ambient-fs-watcher v0.1.1
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling axum v0.7.9
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling tower v0.4.13
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling rusqlite v0.38.0
[INFO] [stderr]    Compiling ambient-fs-store v0.1.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling hyper-timeout v0.5.2
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling tonic v0.12.3
[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 32s
[INFO] running `Command { std: "docker" "inspect" "9fabcb0dc3e4b06f7f70da87d9d14525ccb29532fb94a2e8e32ef3c375af1cbb", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9fabcb0dc3e4b06f7f70da87d9d14525ccb29532fb94a2e8e32ef3c375af1cbb", kill_on_drop: false }`
[INFO] [stdout] 9fabcb0dc3e4b06f7f70da87d9d14525ccb29532fb94a2e8e32ef3c375af1cbb
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cdeefb85fb390c289347285a33f11c3981390219f7bd41585cafd5af9c685018
[INFO] running `Command { std: "docker" "start" "-a" "cdeefb85fb390c289347285a33f11c3981390219f7bd41585cafd5af9c685018", kill_on_drop: false }`
[INFO] [stderr]    Compiling bitflags v2.11.0
[INFO] [stderr]    Compiling getrandom v0.4.1
[INFO] [stderr]    Compiling yansi v1.0.1
[INFO] [stderr]    Compiling diff v0.1.13
[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 notify-types v2.1.0
[INFO] [stderr]    Compiling inotify v0.11.0
[INFO] [stderr]    Compiling rusqlite v0.38.0
[INFO] [stderr]    Compiling pretty_assertions v1.4.1
[INFO] [stderr]    Compiling notify v8.2.0
[INFO] [stderr]    Compiling reqwest v0.13.2
[INFO] [stderr]    Compiling ambient-fs-watcher v0.1.1
[INFO] [stderr]    Compiling ambient-fs-store v0.1.1
[INFO] [stderr]    Compiling genai v0.5.3
[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 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 ambient-fs-server v0.1.1 (/opt/rustwide/workdir)
[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 24.79s
[INFO] running `Command { std: "docker" "inspect" "cdeefb85fb390c289347285a33f11c3981390219f7bd41585cafd5af9c685018", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cdeefb85fb390c289347285a33f11c3981390219f7bd41585cafd5af9c685018", kill_on_drop: false }`
[INFO] [stdout] cdeefb85fb390c289347285a33f11c3981390219f7bd41585cafd5af9c685018
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 38040ffbdeb18bc5a49f5c7514ca1c8d83356ae9479621345a6fe4860d3ac445
[INFO] running `Command { std: "docker" "start" "-a" "38040ffbdeb18bc5a49f5c7514ca1c8d83356ae9479621345a6fe4860d3ac445", 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.27s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/ambient_fs_server-42ae661c7ad2b553)
[INFO] [stdout] 
[INFO] [stdout] running 265 tests
[INFO] [stdout] test agents::tests::activity_is_done_checks_flag ... ok
[INFO] [stdout] test agents::tests::active_agent_count_excludes_stale ... ok
[INFO] [stdout] test agents::tests::activity_new_creates_minimal ... ok
[INFO] [stdout] test agents::tests::activity_serialize_minimal ... ok
[INFO] [stdout] test agents::tests::activity_serialize_full ... 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_count_returns_zero_initially ... ok
[INFO] [stdout] test agents::tests::agent_transitions_between_files ... ok
[INFO] [stdout] test agents::tests::agent_completes_file_work ... ok
[INFO] [stdout] test agents::tests::calculate_pass_rate_empty_returns_one ... ok
[INFO] [stdout] test agents::tests::calculate_pass_rate_all_valid ... ok
[INFO] [stdout] test agents::tests::calculate_pass_rate_mixed ... ok
[INFO] [stdout] test agents::tests::calculate_pass_rate_none_valid ... ok
[INFO] [stdout] test agents::tests::calculate_pass_rate_with_empty_lines ... ok
[INFO] [stdout] test agents::tests::get_active_agent_multiple_files_per_agent ... ok
[INFO] [stdout] test agents::tests::get_active_agent_returns_agent_with_file ... 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_active_agent_skips_stale_agents ... ok
[INFO] [stdout] test agents::tests::get_all_agents_excludes_stale ... 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::process_line_empty_returns_none ... ok
[INFO] [stdout] test agents::tests::get_reference_count_survives_done_activity ... ok
[INFO] [stdout] test agents::tests::process_line_invalid_json_returns_none ... ok
[INFO] [stdout] test agents::tests::multiple_agents_different_files ... ok
[INFO] [stdout] test agents::tests::process_line_valid_json_returns_activity ... ok
[INFO] [stdout] test agents::tests::process_line_with_optional_fields ... ok
[INFO] [stdout] test agents::tests::process_line_with_whitespace ... ok
[INFO] [stdout] test agents::tests::prune_stale_removes_old_agents ... ok
[INFO] [stdout] test agents::tests::get_reference_count_tracks_multiple_files_independently ... ok
[INFO] [stdout] test agents::tests::process_line_missing_required_field_returns_none ... ok
[INFO] [stdout] test agents::tests::update_adds_file_to_agent ... ok
[INFO] [stdout] test agents::tests::prune_stale_resets_counts_for_stale_agent_files ... ok
[INFO] [stdout] test agents::tests::prune_stale_preserves_counts_for_shared_files ... ok
[INFO] [stdout] test agents::tests::state_is_stale_timeout ... ok
[INFO] [stdout] test agents::tests::update_copies_intent_and_tool ... ok
[INFO] [stdout] test agents::tests::process_line_empty_string_fields_returns_none ... ok
[INFO] [stdout] test agents::tests::prune_stale_returns_zero_when_no_stale ... ok
[INFO] [stdout] test agents::tests::get_reference_count_accumulates_multiple_activities ... ok
[INFO] [stdout] test agents::tests::state_new_creates_empty ... ok
[INFO] [stdout] test agents::tests::update_creates_new_agent ... ok
[INFO] [stdout] test agents::tests::get_reference_count_increments_on_activity ... ok
[INFO] [stdout] test agents::tests::get_reference_count_returns_zero_for_unknown_file ... ok
[INFO] [stdout] test agents::tests::update_does_not_duplicate_files ... ok
[INFO] [stdout] test agents::tests::update_done_removes_file_from_active ... ok
[INFO] [stdout] test agents::tests::update_updates_last_seen ... ok
[INFO] [stdout] test agents::tests::with_default_timeout_uses_5_minutes ... ok
[INFO] [stdout] test gateway::tests::buffer_event_adds_to_buffer ... ok
[INFO] [stdout] test gateway::tests::forward_event_does_not_go_back_to_sender ... ok
[INFO] [stdout] test gateway::tests::forward_event_to_other_daemons ... ok
[INFO] [stdout] test gateway::tests::forward_event_to_multiple_daemons ... ok
[INFO] [stdout] test gateway::tests::is_stale_returns_true_when_timeout_exceeded ... ok
[INFO] [stdout] test gateway::tests::new_creates_connection_with_timestamps ... ok
[INFO] [stdout] test gateway::tests::new_service_impl_creates_instance ... ok
[INFO] [stdout] test gateway::tests::new_creates_server_with_addr ... ok
[INFO] [stdout] test gateway::tests::get_buffered_events_returns_all_for_project ... ok
[INFO] [stdout] test gateway::tests::get_buffered_events_returns_empty_for_unknown_project ... ok
[INFO] [stdout] test gateway::tests::register_daemon_adds_to_routing_table ... 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::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 gateway::tests::buffer_evicts_oldest_when_full ... 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 gateway::tests::register_with_valid_params_succeeds ... 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 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_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 grpc::tests::message_to_file_event_invalid_source_returns_none ... ok
[INFO] [stdout] test gateway::tests::update_last_seen_refreshes_timestamp ... 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_missing_cache_returns_zeros ... ok
[INFO] [stdout] test awareness::tests::build_awareness_with_source_id_sets_modified_by_label ... ok
[INFO] [stdout] test awareness::tests::build_awareness_with_activity_has_nonzero_chat_references ... ok
[INFO] [stdout] test awareness::tests::build_awareness_with_event_only_returns_partial_awareness ... ok
[INFO] [stdout] test awareness::tests::build_awareness_filters_by_project_and_file ... ok
[INFO] [stdout] test awareness::tests::build_awareness_with_no_activity_has_zero_chat_references ... ok
[INFO] [stdout] test awareness::tests::build_awareness_with_active_agent_populates_agent_field ... ok
[INFO] [stdout] test awareness::tests::build_awareness_chat_references_independent_per_file ... 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 pipeline::tests::analyze_file_returns_none_for_renamed_event ... ok
[INFO] [stdout] test awareness::tests::build_awareness_with_event_and_analysis_returns_full_awareness ... ok
[INFO] [stdout] test pipeline::tests::analyze_file_analyzes_and_returns_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_handles_missing_file_gracefully ... ok
[INFO] [stdout] test pipeline::tests::analyze_file_counts_todos_correctly ... ok
[INFO] [stdout] test pipeline::tests::analyze_file_counts_lines_correctly ... ok
[INFO] [stdout] test pipeline::tests::with_defaults_uses_default_config ... ok
[INFO] [stdout] test protocol::tests::error_response ... ok
[INFO] [stdout] test pipeline::tests::analyze_file_handles_empty_file ... ok
[INFO] [stdout] test pipeline::tests::analyze_file_caches_result ... 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::full_roundtrip_subscribe_request ... ok
[INFO] [stdout] test protocol::tests::error_with_data ... 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::full_roundtrip_error_response ... 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 pipeline::tests::analyze_file_returns_none_on_second_call_with_same_hash ... ok
[INFO] [stdout] test pipeline::tests::analyze_file_returns_none_when_cache_is_fresh ... ok
[INFO] [stdout] test protocol::tests::request_with_id_is_not_notification ... ok
[INFO] [stdout] test protocol::tests::request_with_array_params ... ok
[INFO] [stdout] test pipeline::tests::analyze_file_reanalyzes_when_hash_changes ... 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_success_serialize_result_only ... ok
[INFO] [stdout] test protocol::tests::response_with_null_id ... ok
[INFO] [stdout] test protocol::tests::success_response ... ok
[INFO] [stdout] test socket::tests::bind_creates_socket_file ... ok
[INFO] [stdout] test protocol::tests::response_error_serialize_error_only ... ok
[INFO] [stdout] test socket::tests::connection_state_add_subscription ... ok
[INFO] [stdout] test socket::tests::connection_state_new_starts_empty ... ok
[INFO] [stdout] test socket::tests::connection_state_get_receiver ... ok
[INFO] [stdout] test socket::tests::bind_twice_returns_error ... ok
[INFO] [stdout] test socket::tests::connection_state_remove_subscription ... ok
[INFO] [stdout] test socket::tests::connection_state_remove_nonexistent_returns_false ... ok
[INFO] [stdout] test socket::tests::bind_removes_existing_file ... ok
[INFO] [stdout] test llm::tests::custom_provider_reads_openai_api_key ... ok
[INFO] [stdout] test socket::tests::new_creates_server_with_path ... 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 socket::tests::client_disconnect_handled_gracefully ... ok
[INFO] [stdout] test socket::tests::multiple_concurrent_connections ... ok
[INFO] [stdout] test socket::tests::handle_invalid_json_returns_error ... ok
[INFO] [stdout] test socket::tests::handle_empty_lines_ignored ... ok
[INFO] [stdout] test socket::tests::query_events_with_invalid_params_type_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::query_events_with_limit ... ok
[INFO] [stdout] test socket::tests::query_events_returns_empty_array ... 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::query_events_with_project_id_filter ... ok
[INFO] [stdout] test socket::tests::run_accepts_connections ... ok
[INFO] [stdout] test socket::tests::query_events_with_real_db_returns_events ... ok
[INFO] [stdout] test socket::tests::subscribe_returns_project_id ... ok
[INFO] [stdout] test socket::tests::subscribe_request_returns_success ... ok
[INFO] [stdout] test socket::tests::unknown_method_returns_error ... ok
[INFO] [stdout] test socket::tests::query_events_with_source_filter ... ok
[INFO] [stdout] test socket::tests::subscribe_without_params_returns_error ... ok
[INFO] [stdout] test state::tests::add_multiple_projects ... ok
[INFO] [stdout] test state::tests::add_project_overwrites_existing ... ok
[INFO] [stdout] test llm::tests::different_models_all_enable_feature ... ok
[INFO] [stdout] test state::tests::has_project_returns_true_after_add ... 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::new_creates_state_with_store_path ... ok
[INFO] [stdout] test llm::tests::from_env_returns_none_when_model_not_set ... ok
[INFO] [stdout] test state::tests::new_has_empty_trees ... ok
[INFO] [stdout] test state::tests::new_has_empty_projects ... ok
[INFO] [stdout] test socket::tests::subscribe_without_project_id_returns_error ... ok
[INFO] [stdout] test socket::tests::run_ends_on_shutdown_signal ... ok
[INFO] [stdout] test socket::tests::unsubscribe_returns_true ... ok
[INFO] [stdout] test state::tests::add_watcher_stores_watcher ... ok
[INFO] [stdout] test state::tests::has_project_returns_false_for_empty ... ok
[INFO] [stdout] test state::tests::get_project_returns_path_for_known ... ok
[INFO] [stdout] test state::tests::new_has_machine_id ... ok
[INFO] [stdout] test state::tests::new_has_empty_watchers ... ok
[INFO] [stdout] test state::tests::clone_shares_same_state ... ok
[INFO] [stdout] test subscriptions::tests::active_projects_lists_subscribed ... ok
[INFO] [stdout] test state::tests::get_project_returns_none_for_unknown ... 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 state::tests::remove_nonexistent_watcher_returns_none ... ok
[INFO] [stdout] test subscriptions::tests::different_projects_independent ... ok
[INFO] [stdout] test subscriptions::tests::explicit_unsubscribe_decreases_count ... ok
[INFO] [stdout] test subscriptions::tests::mixed_notifications_all_delivered ... ok
[INFO] [stdout] test subscriptions::tests::multiple_events_broadcast_correctly ... ok
[INFO] [stdout] test state::tests::remove_nonexistent_project_returns_none ... ok
[INFO] [stdout] test subscriptions::tests::notification_serializes_to_json ... ok
[INFO] [stdout] test subscriptions::tests::publish_analysis_sends_analysis_notification ... ok
[INFO] [stdout] test subscriptions::tests::publish_awareness_sends_awareness_notification ... ok
[INFO] [stdout] test subscriptions::tests::dropping_receiver_decreases_count ... ok
[INFO] [stdout] test subscriptions::tests::publish_event_sends_event_notification ... ok
[INFO] [stdout] test state::tests::remove_project_deletes_mapping ... ok
[INFO] [stdout] test subscriptions::tests::subscriber_count_increases ... ok
[INFO] [stdout] test subscriptions::tests::subscribe_returns_receiver ... ok
[INFO] [stdout] test llm::tests::from_env_returns_some_when_model_set ... ok
[INFO] [stdout] test subscriptions::tests::unsubscribe_removes_project_channel_when_zero ... ok
[INFO] [stdout] test subscriptions::tests::broadcast_does_not_cross_projects ... 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::add_tree_stores_tree ... ok
[INFO] [stdout] test state::tests::remove_nonexistent_tree_returns_none ... 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_store_display ... ok
[INFO] [stdout] test sync::tests::sync_error_stream_display ... ok
[INFO] [stdout] test sync::tests::sync_error_rpc_display ... ok
[INFO] [stdout] test state::tests::subscriptions_field_accessible ... ok
[INFO] [stdout] test state::tests::with_machine_id_uses_custom_id ... 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 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 state::tests::remove_tree_removes_from_state ... ok
[INFO] [stdout] test state::tests::add_project_inserts_mapping ... ok
[INFO] [stdout] test tree_state::tests::apply_rename_nonexistent_returns_none ... ok
[INFO] [stdout] test tree_state::tests::apply_rename_moves_node ... ok
[INFO] [stdout] test tree_state::tests::apply_rename_creates_intermediate_dirs ... ok
[INFO] [stdout] test tree_state::tests::find_locates_existing_file ... 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::from_directory_builds_flat_file_tree ... ok
[INFO] [stdout] test tree_state::tests::from_directory_handles_non_utf8_names_gracefully ... ok
[INFO] [stdout] test tree_state::tests::from_directory_builds_nested_tree ... ok
[INFO] [stdout] test tree_state::tests::find_returns_none_for_nonexistent ... ok
[INFO] [stdout] test tree_state::tests::from_directory_sorts_dirs_first ... 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::full_workflow_scan_modify_delete ... 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_remove_serializes_correctly ... ok
[INFO] [stdout] test tree_state::tests::tree_patch_rename_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::new_creates_manager_with_state_and_peers ... ok
[INFO] [stdout] test sync::tests::new_with_empty_peers ... ok
[INFO] [stdout] test sync::tests::new_has_default_interval_30_seconds ... ok
[INFO] [stdout] test sync::tests::event_exists_returns_false_for_new_event ... 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 sync::tests::new_has_empty_last_sync ... ok
[INFO] [stdout] test sync::tests::event_exists_returns_true_for_duplicate_event ... ok
[INFO] [stdout] test sync::tests::sync_peer_skips_events_from_local_machine_id ... ok
[INFO] [stdout] test sync::tests::with_interval_zero_duration ... ok
[INFO] [stdout] test sync::tests::with_interval_sets_custom_interval ... 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 3.30s
[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" "38040ffbdeb18bc5a49f5c7514ca1c8d83356ae9479621345a6fe4860d3ac445", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "38040ffbdeb18bc5a49f5c7514ca1c8d83356ae9479621345a6fe4860d3ac445", kill_on_drop: false }`
[INFO] [stdout] 38040ffbdeb18bc5a49f5c7514ca1c8d83356ae9479621345a6fe4860d3ac445
