[INFO] cloning repository https://github.com/woodsy-will/forest-inventory-analyzer-rust
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/woodsy-will/forest-inventory-analyzer-rust" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwoodsy-will%2Fforest-inventory-analyzer-rust", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwoodsy-will%2Fforest-inventory-analyzer-rust'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 2ce7d58ef82588274dd63a23aa4ef8cf38b7c9c3
[INFO] testing woodsy-will/forest-inventory-analyzer-rust against beta-2026-03-05 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwoodsy-will%2Fforest-inventory-analyzer-rust" "/workspace/builds/worker-2-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc2/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-2-tc2/source/.cargo/config.toml
[INFO] started tweaking git repo https://github.com/woodsy-will/forest-inventory-analyzer-rust
[INFO] finished tweaking git repo https://github.com/woodsy-will/forest-inventory-analyzer-rust
[INFO] tweaked toml for git repo https://github.com/woodsy-will/forest-inventory-analyzer-rust written to /workspace/builds/worker-2-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/woodsy-will/forest-inventory-analyzer-rust on toolchain beta-2026-03-05
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-03-05" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/woodsy-will/forest-inventory-analyzer-rust 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" "+beta-2026-03-05" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] d57752716e176bcf08328e0a3b0e89a16da242320ffee0af50b92550712b1f61
[INFO] running `Command { std: "docker" "start" "-a" "d57752716e176bcf08328e0a3b0e89a16da242320ffee0af50b92550712b1f61", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "d57752716e176bcf08328e0a3b0e89a16da242320ffee0af50b92550712b1f61", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d57752716e176bcf08328e0a3b0e89a16da242320ffee0af50b92550712b1f61", kill_on_drop: false }`
[INFO] [stdout] d57752716e176bcf08328e0a3b0e89a16da242320ffee0af50b92550712b1f61
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=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" "+beta-2026-03-05" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 98d81c26ad948d9cca8a0cfcd3a57020add9d601f2a813a8e5da67e4c97763f2
[INFO] running `Command { std: "docker" "start" "-a" "98d81c26ad948d9cca8a0cfcd3a57020add9d601f2a813a8e5da67e4c97763f2", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.106
[INFO] [stderr]    Compiling unicode-ident v1.0.22
[INFO] [stderr]    Compiling quote v1.0.44
[INFO] [stderr]    Compiling libc v0.2.180
[INFO] [stderr]    Compiling cfg-if v1.0.4
[INFO] [stderr]    Compiling memchr v2.8.0
[INFO] [stderr]    Compiling pin-project-lite v0.2.16
[INFO] [stderr]    Compiling log v0.4.29
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling zerocopy v0.8.39
[INFO] [stderr]    Compiling stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling futures-core v0.3.31
[INFO] [stderr]    Compiling find-msvc-tools v0.1.9
[INFO] [stderr]    Compiling pkg-config v0.3.32
[INFO] [stderr]    Compiling lock_api v0.4.14
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]    Compiling itoa v1.0.17
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]    Compiling libm v0.2.16
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling writeable v0.6.2
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling litemap v0.8.1
[INFO] [stderr]    Compiling simd-adler32 v0.3.8
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling socket2 v0.6.2
[INFO] [stderr]    Compiling cc v1.2.55
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling icu_properties_data v2.1.2
[INFO] [stderr]    Compiling futures-io v0.3.31
[INFO] [stderr]    Compiling futures-task v0.3.31
[INFO] [stderr]    Compiling icu_normalizer_data v2.1.1
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling slab v0.4.12
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling percent-encoding v2.3.2
[INFO] [stderr]    Compiling regex-syntax v0.8.9
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling zstd-sys v2.0.16+zstd.1.5.7
[INFO] [stderr]    Compiling flate2 v1.1.9
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling encoding_rs v0.8.35
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling zstd-safe v7.2.4
[INFO] [stderr]    Compiling alloc-no-stdlib v2.0.4
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling local-waker v0.1.4
[INFO] [stderr]    Compiling alloc-stdlib v0.2.2
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling convert_case v0.10.0
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.7
[INFO] [stderr]    Compiling rand_core v0.9.5
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling zmij v1.0.19
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]    Compiling bytes v1.11.1
[INFO] [stderr]    Compiling regex-lite v0.1.9
[INFO] [stderr]    Compiling unicode-xid v0.2.6
[INFO] [stderr]    Compiling time-macros v0.2.27
[INFO] [stderr]    Compiling bytestring v1.5.0
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling tracing v0.1.44
[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-impl v2.1.1
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling brotli-decompressor v5.0.0
[INFO] [stderr]    Compiling actix-utils v3.0.1
[INFO] [stderr]    Compiling form_urlencoded v1.2.2
[INFO] [stderr]    Compiling actix-service v2.0.3
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling cookie v0.16.2
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling linux-raw-sys v0.11.0
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling bytemuck v1.25.0
[INFO] [stderr]    Compiling utf8_iter v1.0.4
[INFO] [stderr]    Compiling ryu v1.0.22
[INFO] [stderr]    Compiling cpufeatures v0.2.17
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling anstyle-parse v0.2.7
[INFO] [stderr]    Compiling safe_arch v0.7.4
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling derive_more v2.1.1
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling brotli v8.0.2
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling actix-rt v2.11.0
[INFO] [stderr]    Compiling actix-codec v0.5.2
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling actix-router v0.5.3
[INFO] [stderr]    Compiling time v0.3.47
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling local-channel v0.1.5
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling matrixmultiply v0.3.10
[INFO] [stderr]    Compiling colorchoice v1.0.4
[INFO] [stderr]    Compiling anstyle v1.0.13
[INFO] [stderr]    Compiling is_terminal_polyfill v1.70.2
[INFO] [stderr]    Compiling bumpalo v3.19.1
[INFO] [stderr]    Compiling zip v2.4.2
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]    Compiling anstyle-query v1.1.5
[INFO] [stderr]    Compiling anstream v0.6.21
[INFO] [stderr]    Compiling zopfli v0.8.3
[INFO] [stderr]    Compiling libsqlite3-sys v0.28.0
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling actix-server v2.6.0
[INFO] [stderr]    Compiling actix-web-codegen v4.3.0
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling wide v0.7.33
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling actix-macros v0.2.4
[INFO] [stderr]    Compiling approx v0.5.1
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling num-complex v0.4.6
[INFO] [stderr]    Compiling impl-more v0.1.9
[INFO] [stderr]    Compiling litrs v1.0.0
[INFO] [stderr]    Compiling num-rational v0.4.2
[INFO] [stderr]    Compiling zstd v0.13.3
[INFO] [stderr]    Compiling document-features v0.2.12
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling actix-http v3.11.2
[INFO] [stderr]    Compiling simba v0.8.1
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling rand_distr v0.4.3
[INFO] [stderr]    Compiling nalgebra-macros v0.2.2
[INFO] [stderr]    Compiling parse-size v1.1.0
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling convert_case v0.4.0
[INFO] [stderr]    Compiling anyhow v1.0.101
[INFO] [stderr]    Compiling clap_lex v0.7.7
[INFO] [stderr]    Compiling derive_more v0.99.20
[INFO] [stderr]    Compiling clap_builder v4.5.57
[INFO] [stderr]    Compiling tempfile v3.24.0
[INFO] [stderr]    Compiling hashlink v0.9.1
[INFO] [stderr]    Compiling actix-multipart-derive v0.7.0
[INFO] [stderr]    Compiling clap_derive v4.5.55
[INFO] [stderr]    Compiling crossterm v0.29.0
[INFO] [stderr]    Compiling serde_plain v1.0.2
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling env_filter v0.1.4
[INFO] [stderr]    Compiling codepage v0.1.2
[INFO] [stderr]    Compiling quick-xml v0.31.0
[INFO] [stderr]    Compiling csv-core v0.1.13
[INFO] [stderr]    Compiling fallible-streaming-iterator v0.1.9
[INFO] [stderr]    Compiling actix-web v4.12.1
[INFO] [stderr]    Compiling fallible-iterator v0.3.0
[INFO] [stderr]    Compiling unicode-width v0.2.2
[INFO] [stderr]    Compiling jiff v0.2.19
[INFO] [stderr]    Compiling comfy-table v7.2.2
[INFO] [stderr]    Compiling colored v2.2.0
[INFO] [stderr]    Compiling clap v4.5.57
[INFO] [stderr]    Compiling calamine v0.26.1
[INFO] [stderr]    Compiling csv v1.4.0
[INFO] [stderr]    Compiling nalgebra v0.32.6
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling rust_xlsxwriter v0.79.4
[INFO] [stderr]    Compiling uuid v1.20.0
[INFO] [stderr]    Compiling actix-cors v0.7.1
[INFO] [stderr]    Compiling actix-multipart v0.7.2
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling rusqlite v0.31.0
[INFO] [stderr]    Compiling statrs v0.17.1
[INFO] [stderr]    Compiling forest_inventory_analyzer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 3m 49s
[INFO] running `Command { std: "docker" "inspect" "98d81c26ad948d9cca8a0cfcd3a57020add9d601f2a813a8e5da67e4c97763f2", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "98d81c26ad948d9cca8a0cfcd3a57020add9d601f2a813a8e5da67e4c97763f2", kill_on_drop: false }`
[INFO] [stdout] 98d81c26ad948d9cca8a0cfcd3a57020add9d601f2a813a8e5da67e4c97763f2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=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" "+beta-2026-03-05" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1a9c5236cf059d2151cc599f892c89944cd930a095bfc77f28c2244bb7b18423
[INFO] running `Command { std: "docker" "start" "-a" "1a9c5236cf059d2151cc599f892c89944cd930a095bfc77f28c2244bb7b18423", kill_on_drop: false }`
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling predicates-core v1.0.9
[INFO] [stderr]    Compiling float-cmp v0.10.0
[INFO] [stderr]    Compiling normalize-line-endings v0.3.0
[INFO] [stderr]    Compiling assert_cmd v2.1.2
[INFO] [stderr]    Compiling difflib v0.4.0
[INFO] [stderr]    Compiling termtree v0.5.1
[INFO] [stderr]    Compiling wait-timeout v0.2.1
[INFO] [stderr]    Compiling assert_approx_eq v1.1.0
[INFO] [stderr]    Compiling predicates-tree v1.0.12
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling bstr v1.12.1
[INFO] [stderr]    Compiling actix-router v0.5.3
[INFO] [stderr]    Compiling env_filter v0.1.4
[INFO] [stderr]    Compiling predicates v3.1.3
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling actix-web v4.12.1
[INFO] [stderr]    Compiling actix-multipart v0.7.2
[INFO] [stderr]    Compiling actix-cors v0.7.1
[INFO] [stderr]    Compiling forest_inventory_analyzer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: use of deprecated associated function `assert_cmd::Command::cargo_bin`: incompatible with a custom cargo build-dir, see instead `cargo::cargo_bin_cmd!`
[INFO] [stdout]    --> tests/cli_test.rs:101:14
[INFO] [stdout]     |
[INFO] [stdout] 101 |     Command::cargo_bin("forest-analyzer").unwrap()
[INFO] [stdout]     |              ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 49.98s
[INFO] running `Command { std: "docker" "inspect" "1a9c5236cf059d2151cc599f892c89944cd930a095bfc77f28c2244bb7b18423", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1a9c5236cf059d2151cc599f892c89944cd930a095bfc77f28c2244bb7b18423", kill_on_drop: false }`
[INFO] [stdout] 1a9c5236cf059d2151cc599f892c89944cd930a095bfc77f28c2244bb7b18423
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=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" "+beta-2026-03-05" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 07fdd7fff8dd7b88a96296076848370ad3ccf6067cb9deda7787275216f12d09
[INFO] running `Command { std: "docker" "start" "-a" "07fdd7fff8dd7b88a96296076848370ad3ccf6067cb9deda7787275216f12d09", kill_on_drop: false }`
[INFO] [stderr] warning: use of deprecated associated function `assert_cmd::Command::cargo_bin`: incompatible with a custom cargo build-dir, see instead `cargo::cargo_bin_cmd!`
[INFO] [stderr]    --> tests/cli_test.rs:101:14
[INFO] [stderr]     |
[INFO] [stderr] 101 |     Command::cargo_bin("forest-analyzer").unwrap()
[INFO] [stderr]     |              ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `forest_inventory_analyzer` (test "cli_test") generated 1 warning
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.44s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/forest_inventory_analyzer-51c96c555adcc920)
[INFO] [stdout] 
[INFO] [stdout] running 213 tests
[INFO] [stdout] test analysis::analyzer::tests::test_diameter_distribution_matches_standalone ... ok
[INFO] [stdout] test analysis::analyzer::tests::test_analyzer_empty_inventory ... ok
[INFO] [stdout] test analysis::diameter_distribution::tests::test_basal_area_in_classes ... ok
[INFO] [stdout] test analysis::diameter_distribution::tests::test_class_width_1_inch ... ok
[INFO] [stdout] test analysis::diameter_distribution::tests::test_all_dead_trees ... ok
[INFO] [stdout] test analysis::diameter_distribution::tests::test_class_width_2_inch ... ok
[INFO] [stdout] test analysis::analyzer::tests::test_project_growth_matches_standalone ... ok
[INFO] [stdout] test analysis::analyzer::tests::test_sampling_statistics_matches_standalone ... ok
[INFO] [stdout] test analysis::diameter_distribution::tests::test_distribution_json_roundtrip ... ok
[INFO] [stdout] test analysis::diameter_distribution::tests::test_empty_inventory ... ok
[INFO] [stdout] test analysis::diameter_distribution::tests::test_single_tree_single_class ... ok
[INFO] [stdout] test analysis::diameter_distribution::tests::test_tpa_averaged_across_plots ... ok
[INFO] [stdout] test analysis::diameter_distribution::tests::test_midpoint_calculation ... ok
[INFO] [stdout] test analysis::diameter_distribution::tests::test_excludes_dead_trees ... ok
[INFO] [stdout] test analysis::growth::tests::test_exponential_growth_increases_volume ... ok
[INFO] [stdout] test analysis::diameter_distribution::tests::test_wide_range_of_diameters ... ok
[INFO] [stdout] test analysis::growth::tests::test_all_projections_non_negative ... ok
[INFO] [stdout] test analysis::analyzer::tests::test_stand_metrics_matches_standalone ... ok
[INFO] [stdout] test analysis::growth::tests::test_empty_inventory_error ... ok
[INFO] [stdout] test analysis::growth::tests::test_exponential_monotonic_volume_increase ... ok
[INFO] [stdout] test analysis::growth::tests::test_higher_mortality_lower_tpa ... ok
[INFO] [stdout] test analysis::growth::tests::test_linear_growth ... ok
[INFO] [stdout] test analysis::growth::tests::test_exponential_tpa_decreases_mortality ... ok
[INFO] [stdout] test analysis::growth::tests::test_growth_projection_json_roundtrip ... ok
[INFO] [stdout] test analysis::growth::tests::test_linear_tpa_decreases_to_floor ... ok
[INFO] [stdout] test analysis::growth::tests::test_logistic_growth_increases ... ok
[INFO] [stdout] test analysis::growth::tests::test_logistic_tpa_decreases ... ok
[INFO] [stdout] test analysis::growth::tests::test_logistic_growth_bounded ... ok
[INFO] [stdout] test analysis::growth::tests::test_growth_model_json_roundtrip ... ok
[INFO] [stdout] test analysis::growth::tests::test_linear_volume_increase ... ok
[INFO] [stdout] test analysis::growth::tests::test_zero_mortality_no_tpa_decrease ... ok
[INFO] [stdout] test analysis::metrics::tests::test_empty_inventory_metrics ... ok
[INFO] [stdout] test analysis::growth::tests::test_year_zero_matches_current ... ok
[INFO] [stdout] test analysis::growth::tests::test_zero_mortality_linear_no_tpa_decrease ... ok
[INFO] [stdout] test analysis::growth::tests::test_zero_mortality_logistic_no_tpa_decrease ... ok
[INFO] [stdout] test analysis::growth::tests::test_zero_years ... ok
[INFO] [stdout] test analysis::growth::tests::test_projection_length ... ok
[INFO] [stdout] test analysis::metrics::tests::test_all_dead_trees_metrics ... ok
[INFO] [stdout] test analysis::metrics::tests::test_mean_height_none_when_no_heights ... ok
[INFO] [stdout] test analysis::metrics::tests::test_mean_height_present ... ok
[INFO] [stdout] test analysis::metrics::tests::test_species_count ... ok
[INFO] [stdout] test analysis::metrics::tests::test_metrics_json_roundtrip ... ok
[INFO] [stdout] test analysis::metrics::tests::test_species_mean_dbh ... ok
[INFO] [stdout] test analysis::metrics::tests::test_species_composition_not_empty ... ok
[INFO] [stdout] test analysis::metrics::tests::test_metrics_positive_values ... ok
[INFO] [stdout] test analysis::metrics::tests::test_qmd_reasonable_range ... ok
[INFO] [stdout] test analysis::metrics::tests::test_species_percentages_sum_to_100 ... ok
[INFO] [stdout] test analysis::metrics::tests::test_single_species_inventory ... ok
[INFO] [stdout] test analysis::statistics::tests::test_compute_ci_basic ... ok
[INFO] [stdout] test analysis::statistics::tests::test_compute_ci_higher_confidence_wider ... ok
[INFO] [stdout] test analysis::statistics::tests::test_compute_ci_identical_values ... ok
[INFO] [stdout] test analysis::statistics::tests::test_compute_ci_insufficient_data ... ok
[INFO] [stdout] test analysis::statistics::tests::test_compute_ci_more_data_narrower ... ok
[INFO] [stdout] test analysis::metrics::tests::test_species_sorted_by_basal_area_desc ... ok
[INFO] [stdout] test analysis::statistics::tests::test_sampling_statistics_compute ... ok
[INFO] [stdout] test analysis::statistics::tests::test_sampling_error_percent ... ok
[INFO] [stdout] test analysis::statistics::tests::test_compute_ci_symmetric ... ok
[INFO] [stdout] test analysis::statistics::tests::test_sampling_statistics_insufficient_plots ... ok
[INFO] [stdout] test analysis::statistics::tests::test_sampling_statistics_confidence_levels ... ok
[INFO] [stdout] test analysis::statistics::tests::test_sampling_error_percent_zero_mean ... ok
[INFO] [stdout] test analysis::statistics::tests::test_sampling_statistics_empty_inventory ... ok
[INFO] [stdout] test error::tests::test_error_is_debug ... ok
[INFO] [stdout] test error::tests::test_analysis_error_display ... ok
[INFO] [stdout] test analysis::statistics::tests::test_sampling_statistics_json_roundtrip ... ok
[INFO] [stdout] test error::tests::test_excel_error_display ... ok
[INFO] [stdout] test error::tests::test_io_error_display ... ok
[INFO] [stdout] test analysis::statistics::tests::test_sampling_statistics_two_plots ... ok
[INFO] [stdout] test error::tests::test_io_error_from_conversion ... ok
[INFO] [stdout] test error::tests::test_parse_error_display ... ok
[INFO] [stdout] test error::tests::test_insufficient_data_display ... ok
[INFO] [stdout] test error::tests::test_validation_error_display ... ok
[INFO] [stdout] test error::tests::test_json_error_from_conversion ... ok
[INFO] [stdout] test io::tests::test_json_format_default ... ok
[INFO] [stdout] test models::inventory::tests::test_inventory_json_roundtrip ... ok
[INFO] [stdout] test models::inventory::tests::test_mean_basal_area ... ok
[INFO] [stdout] test models::inventory::tests::test_mean_basal_area_empty ... ok
[INFO] [stdout] test models::inventory::tests::test_mean_tpa ... ok
[INFO] [stdout] test models::inventory::tests::test_mean_tpa_empty ... ok
[INFO] [stdout] test models::inventory::tests::test_mean_volume_bdft ... ok
[INFO] [stdout] test models::inventory::tests::test_mean_volume_bdft_empty ... ok
[INFO] [stdout] test models::inventory::tests::test_mean_volume_cuft_empty ... ok
[INFO] [stdout] test models::inventory::tests::test_mean_volume_cuft ... ok
[INFO] [stdout] test models::inventory::tests::test_new_inventory ... ok
[INFO] [stdout] test models::inventory::tests::test_new_inventory_string_conversion ... ok
[INFO] [stdout] test models::inventory::tests::test_num_plots ... ok
[INFO] [stdout] test models::inventory::tests::test_num_plots_empty ... ok
[INFO] [stdout] test models::inventory::tests::test_num_trees ... ok
[INFO] [stdout] test models::inventory::tests::test_single_plot_means_equal_plot_values ... ok
[INFO] [stdout] test models::inventory::tests::test_num_trees_empty ... ok
[INFO] [stdout] test models::inventory::tests::test_species_list ... ok
[INFO] [stdout] test models::inventory::tests::test_species_list_deduplicates ... ok
[INFO] [stdout] test models::inventory::tests::test_species_list_empty ... ok
[INFO] [stdout] test models::plot::tests::test_basal_area_per_acre ... ok
[INFO] [stdout] test models::plot::tests::test_live_trees_all_dead ... ok
[INFO] [stdout] test models::plot::tests::test_live_trees_empty_plot ... ok
[INFO] [stdout] test models::plot::tests::test_live_trees_filters_correctly ... ok
[INFO] [stdout] test models::plot::tests::test_multiple_metrics_consistent ... ok
[INFO] [stdout] test io::tests::test_json_trait_roundtrip ... ok
[INFO] [stdout] test models::plot::tests::test_plot_json_roundtrip ... ok
[INFO] [stdout] test models::plot::tests::test_quadratic_mean_diameter ... ok
[INFO] [stdout] test models::plot::tests::test_quadratic_mean_diameter_different_sizes ... ok
[INFO] [stdout] test models::plot::tests::test_quadratic_mean_diameter_empty ... ok
[INFO] [stdout] test io::tests::test_csv_trait_roundtrip ... ok
[INFO] [stdout] test models::plot::tests::test_quadratic_mean_diameter_excludes_dead ... ok
[INFO] [stdout] test models::plot::tests::test_trees_per_acre ... ok
[INFO] [stdout] test models::plot::tests::test_trees_per_acre_empty ... ok
[INFO] [stdout] test models::plot::tests::test_volume_bdft_per_acre ... ok
[INFO] [stdout] test models::plot::tests::test_volume_bdft_small_trees_zero ... ok
[INFO] [stdout] test models::plot::tests::test_volume_cuft_per_acre ... ok
[INFO] [stdout] test models::tree::tests::test_basal_area_12_inch_tree ... ok
[INFO] [stdout] test models::tree::tests::test_basal_area_per_acre ... ok
[INFO] [stdout] test models::plot::tests::test_volume_cuft_per_acre_no_height ... ok
[INFO] [stdout] test models::tree::tests::test_basal_area_large_tree ... ok
[INFO] [stdout] test models::tree::tests::test_basal_area_small_tree ... ok
[INFO] [stdout] test models::tree::tests::test_basal_area_zero_dbh ... ok
[INFO] [stdout] test models::tree::tests::test_species_display ... ok
[INFO] [stdout] test models::tree::tests::test_is_live ... ok
[INFO] [stdout] test models::tree::tests::test_species_equality ... ok
[INFO] [stdout] test models::tree::tests::test_species_hash_consistency ... ok
[INFO] [stdout] test models::tree::tests::test_species_inequality ... ok
[INFO] [stdout] test models::tree::tests::test_tree_status_display ... ok
[INFO] [stdout] test models::tree::tests::test_species_json_roundtrip ... ok
[INFO] [stdout] test models::tree::tests::test_tree_json_roundtrip ... ok
[INFO] [stdout] test models::tree::tests::test_tree_status_json_roundtrip ... ok
[INFO] [stdout] test models::tree::tests::test_tree_status_parse_abbreviations ... ok
[INFO] [stdout] test models::tree::tests::test_tree_status_parse_invalid ... ok
[INFO] [stdout] test models::tree::tests::test_tree_status_parse_full_words ... ok
[INFO] [stdout] test models::tree::tests::test_tree_status_parse_case_insensitive ... ok
[INFO] [stdout] test models::tree::tests::test_validate_crown_ratio_above_one ... ok
[INFO] [stdout] test models::tree::tests::test_validate_crown_ratio_boundary_values ... ok
[INFO] [stdout] test models::tree::tests::test_validate_defect_above_one ... ok
[INFO] [stdout] test models::tree::tests::test_validate_crown_ratio_negative ... ok
[INFO] [stdout] test models::tree::tests::test_validate_defect_negative ... ok
[INFO] [stdout] test models::tree::tests::test_validate_defect_boundary_values ... ok
[INFO] [stdout] test models::tree::tests::test_validate_negative_dbh ... ok
[INFO] [stdout] test models::tree::tests::test_validate_negative_expansion_factor ... ok
[INFO] [stdout] test models::tree::tests::test_validate_negative_height ... ok
[INFO] [stdout] test models::tree::tests::test_validate_valid_tree ... ok
[INFO] [stdout] test models::tree::tests::test_validate_zero_expansion_factor ... ok
[INFO] [stdout] test models::tree::tests::test_validate_zero_height ... ok
[INFO] [stdout] test models::tree::tests::test_volume_bdft_negative_clamped_to_zero ... ok
[INFO] [stdout] test models::tree::tests::test_volume_bdft_no_height ... ok
[INFO] [stdout] test models::tree::tests::test_volume_bdft_normal_tree ... ok
[INFO] [stdout] test models::tree::tests::test_volume_bdft_small_tree_below_merchantable ... ok
[INFO] [stdout] test models::tree::tests::test_volume_bdft_with_custom_coefficients ... ok
[INFO] [stdout] test models::tree::tests::test_volume_bdft_with_custom_min_dbh ... ok
[INFO] [stdout] test models::tree::tests::test_volume_bdft_with_default_matches_original ... ok
[INFO] [stdout] test analysis::metrics::tests::test_species_mean_height ... ok
[INFO] [stdout] test analysis::statistics::tests::test_compute_ci_empty ... ok
[INFO] [stdout] test models::tree::tests::test_volume_bdft_with_defect ... ok
[INFO] [stdout] test models::tree::tests::test_volume_cuft_no_height ... ok
[INFO] [stdout] test models::tree::tests::test_volume_cuft_normal_tree ... ok
[INFO] [stdout] test models::inventory::tests::test_species_list_includes_dead_trees ... ok
[INFO] [stdout] test models::plot::tests::test_basal_area_excludes_dead ... ok
[INFO] [stdout] test analysis::statistics::tests::test_compute_ci_two_observations ... ok
[INFO] [stdout] test models::tree::tests::test_volume_cuft_zero_height ... ok
[INFO] [stdout] test models::tree::tests::test_volume_cuft_with_custom_coefficients ... ok
[INFO] [stdout] test models::tree::tests::test_volume_cuft_with_default_matches_original ... ok
[INFO] [stdout] test models::tree::tests::test_volume_cuft_with_defect ... ok
[INFO] [stdout] test models::tree::tests::test_volume_cuft_zero_dbh ... ok
[INFO] [stdout] test models::volume::tests::test_default_bdft_coefficients ... ok
[INFO] [stdout] test models::volume::tests::test_default_cuft_coefficient ... ok
[INFO] [stdout] test models::volume::tests::test_volume_equation_json_roundtrip ... ok
[INFO] [stdout] test visualization::charts::tests::test_format_histogram_with_data ... ok
[INFO] [stdout] test visualization::charts::tests::test_format_histogram_empty ... ok
[INFO] [stdout] test visualization::tables::tests::test_format_growth_table_contains_headers ... ok
[INFO] [stdout] test visualization::charts::tests::test_format_histogram_contains_values ... ok
[INFO] [stdout] test visualization::tables::tests::test_format_growth_table_contains_data ... ok
[INFO] [stdout] test visualization::tables::tests::test_format_growth_table_empty ... ok
[INFO] [stdout] test visualization::tables::tests::test_format_species_table_contains_headers ... ok
[INFO] [stdout] test visualization::tables::tests::test_format_species_table_contains_species_data ... ok
[INFO] [stdout] test visualization::tables::tests::test_format_stand_summary_with_height ... ok
[INFO] [stdout] test visualization::tables::tests::test_format_stand_summary_contains_metrics ... ok
[INFO] [stdout] test visualization::tables::tests::test_format_statistics_table_contains_fields ... ok
[INFO] [stdout] test models::tree::tests::test_validate_valid_tree_no_optionals ... ok
[INFO] [stdout] test models::tree::tests::test_validate_zero_dbh ... ok
[INFO] [stdout] test web::handlers::tests::test_export_json ... ok
[INFO] [stdout] test web::handlers::tests::test_growth_success ... ok
[INFO] [stdout] test web::handlers::tests::test_export_sanitizes_special_characters_in_name ... ok
[INFO] [stdout] test web::handlers::tests::test_growth_not_found ... ok
[INFO] [stdout] test web::handlers::tests::test_distribution_success ... ok
[INFO] [stdout] test web::handlers::tests::test_export_unsupported_format ... ok
[INFO] [stdout] test web::handlers::tests::test_export_not_found ... ok
[INFO] [stdout] test web::handlers::tests::test_static_js ... ok
[INFO] [stdout] test web::handlers::tests::test_static_html ... ok
[INFO] [stdout] test web::handlers::tests::test_static_css ... ok
[INFO] [stdout] test web::handlers::tests::test_metrics_not_found ... ok
[INFO] [stdout] test web::handlers::tests::test_export_csv ... ok
[INFO] [stdout] test web::handlers::tests::test_health_returns_ok ... ok
[INFO] [stdout] test web::handlers::tests::test_statistics_not_found ... ok
[INFO] [stdout] test web::handlers::tests::test_inventory_json_success ... ok
[INFO] [stdout] test web::handlers::tests::test_statistics_success ... ok
[INFO] [stdout] test web::state::tests::test_inventory_insert_and_get ... ok
[INFO] [stdout] test web::state::tests::test_inventory_data_preserved_through_serialization ... ok
[INFO] [stdout] test web::handlers::tests::test_validate_invalid_status_returns_error ... ok
[INFO] [stdout] test web::state::tests::test_inventory_nonexistent_returns_none ... ok
[INFO] [stdout] test web::state::tests::test_inventory_overwrite ... ok
[INFO] [stdout] test web::state::tests::test_inventory_ttl_eviction ... ok
[INFO] [stdout] test web::state::tests::test_inventory_not_evicted_when_fresh ... ok
[INFO] [stdout] test web::handlers::tests::test_validate_invalid_rows_returns_errors ... ok
[INFO] [stdout] test web::handlers::tests::test_metrics_success ... ok
[INFO] [stdout] test web::state::tests::test_pending_insert_and_has ... ok
[INFO] [stdout] test web::state::tests::test_pending_not_evicted_when_fresh ... ok
[INFO] [stdout] test web::state::tests::test_pending_nonexistent_remove_returns_none ... ok
[INFO] [stdout] test web::state::tests::test_pending_remove ... ok
[INFO] [stdout] test web::state::tests::test_pending_get_name ... ok
[INFO] [stdout] test web::handlers::tests::test_validate_valid_rows_promotes_to_inventory ... ok
[INFO] [stdout] test web::handlers::tests::test_validate_unknown_id_returns_404 ... ok
[INFO] [stdout] test web::state::tests::test_multiple_inventories_independent ... ok
[INFO] [stdout] test web::state::tests::test_pending_ttl_eviction ... ok
[INFO] [stdout] test web::state::tests::test_pending_rows_data_preserved ... ok
[INFO] [stdout] test web::state::tests::test_pending_capacity_eviction ... ok
[INFO] [stdout] test web::state::tests::test_inventory_capacity_eviction ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 213 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.18s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/forest_analyzer-4d8c2a5fa7c6ae7f)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/cli_test.rs (/opt/rustwide/target/debug/deps/cli_test-ebad18fe9c8e0dbe)
[INFO] [stdout] 
[INFO] [stdout] running 16 tests
[INFO] [stdout] test test_growth_linear ... ok
[INFO] [stdout] test test_analyze_custom_confidence ... ok
[INFO] [stdout] test test_analyze_success ... ok
[INFO] [stdout] test test_growth_logistic ... ok
[INFO] [stdout] test test_convert_csv_to_json ... ok
[INFO] [stdout] test test_analyze_custom_diameter_width ... ok
[INFO] [stdout] test test_help_flag ... ok
[INFO] [stdout] test test_summary_success ... ok
[INFO] [stdout] test test_missing_input_flag ... ok
[INFO] [stdout] test test_no_subcommand ... ok
[INFO] [stdout] test test_version_flag ... ok
[INFO] [stdout] test test_convert_csv_to_excel ... ok
[INFO] [stdout] test test_growth_exponential ... ok
[INFO] [stdout] test test_growth_with_mortality ... ok
[INFO] [stdout] test test_missing_file ... ok
[INFO] [stdout] test test_growth_invalid_model ... ok
[INFO] [stderr]      Running tests/integration_test.rs (/opt/rustwide/target/debug/deps/integration_test-9bee62e38a1b036b)
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 16 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.27s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 53 tests
[INFO] [stdout] test test_csv_header_only_no_data ... ok
[INFO] [stdout] test test_csv_accepts_valid_data ... ok
[INFO] [stdout] test test_csv_preserves_tree_data ... ok
[INFO] [stdout] test test_csv_rejects_crown_ratio_above_one ... ok
[INFO] [stdout] test test_csv_rejects_defect_above_one ... ok
[INFO] [stdout] test test_csv_rejects_negative_dbh ... ok
[INFO] [stdout] test test_csv_roundtrip_preserves_optional_none_values ... ok
[INFO] [stdout] test test_csv_rejects_zero_dbh ... ok
[INFO] [stdout] test test_analysis_after_format_conversion ... ok
[INFO] [stdout] test test_csv_rejects_zero_expansion_factor ... ok
[INFO] [stdout] test test_csv_species_preserved ... ok
[INFO] [stdout] test test_csv_with_all_optional_fields_empty ... ok
[INFO] [stdout] test test_csv_roundtrip ... ok
[INFO] [stdout] test test_csv_with_utf8_bom ... ok
[INFO] [stdout] test test_csv_with_quoted_commas_in_species_name ... ok
[INFO] [stdout] test test_csv_with_windows_line_endings ... ok
[INFO] [stdout] test test_diameter_distribution ... ok
[INFO] [stdout] test test_diameter_distribution_class_ordering ... ok
[INFO] [stdout] test test_full_analysis_workflow ... ok
[INFO] [stdout] test test_csv_rejects_negative_height ... ok
[INFO] [stdout] test test_diameter_distribution_different_widths ... ok
[INFO] [stdout] test test_growth_empty_inventory_error ... ok
[INFO] [stdout] test test_growth_all_models ... ok
[INFO] [stdout] test test_inventory_all_optional_fields_none ... ok
[INFO] [stdout] test test_inventory_basic_stats ... ok
[INFO] [stdout] test test_csv_rejects_negative_crown_ratio ... ok
[INFO] [stdout] test test_json_compact_roundtrip ... ok
[INFO] [stdout] test test_growth_projection ... ok
[INFO] [stdout] test test_json_missing_required_field_fails ... ok
[INFO] [stdout] test test_json_preserves_volumes ... ok
[INFO] [stdout] test test_csv_to_json_conversion ... ok
[INFO] [stdout] test test_json_rejects_invalid_data ... ok
[INFO] [stdout] test test_json_roundtrip ... ok
[INFO] [stdout] test test_json_with_null_optional_fields ... ok
[INFO] [stdout] test test_json_with_extra_fields_ignored ... ok
[INFO] [stdout] test test_sampling_statistics ... ok
[INFO] [stdout] test test_sampling_statistics_90_vs_95 ... ok
[INFO] [stdout] test test_sampling_statistics_all_metrics_have_ci ... ok
[INFO] [stdout] test test_single_plot_inventory ... ok
[INFO] [stdout] test test_species_list ... ok
[INFO] [stdout] test test_stand_metrics ... ok
[INFO] [stdout] test test_stand_metrics_qmd_in_range ... ok
[INFO] [stdout] test test_stand_metrics_species_percentages ... ok
[INFO] [stdout] test test_tree_basal_area ... ok
[INFO] [stdout] test test_tree_status_parsing ... ok
[INFO] [stdout] test test_tree_volume ... ok
[INFO] [stdout] test test_stand_metrics_volumes_positive ... ok
[INFO] [stdout] test test_json_empty_plots_array ... ok
[INFO] [stdout] test test_large_inventory ... ok
[INFO] [stdout] test test_csv_to_excel_to_json_pipeline ... ok
[INFO] [stdout] test test_excel_preserves_metrics ... ok
[INFO] [stdout] test test_excel_roundtrip ... ok
[INFO] [stdout] test test_json_to_excel_conversion ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 53 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.07s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests forest_inventory_analyzer
[INFO] [stdout] 
[INFO] [stdout] running 7 tests
[INFO] [stdout] test src/models/inventory.rs - models::inventory::ForestInventory::mean_tpa (line 52) ... ok
[INFO] [stdout] test src/models/plot.rs - models::plot::Plot::basal_area_per_acre (line 60) ... ok
[INFO] [stdout] test src/models/tree.rs - models::tree::Tree::basal_area_sqft (line 98) ... ok
[INFO] [stdout] test src/models/plot.rs - models::plot::Plot::trees_per_acre (line 34) ... ok
[INFO] [stdout] test src/models/tree.rs - models::tree::Tree::volume_bdft (line 164) ... ok
[INFO] [stdout] test src/models/tree.rs - models::tree::Tree::volume_cuft (line 126) ... ok
[INFO] [stdout] test src/models/inventory.rs - models::inventory::ForestInventory::mean_basal_area (line 80) ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 7 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 10.39s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "07fdd7fff8dd7b88a96296076848370ad3ccf6067cb9deda7787275216f12d09", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "07fdd7fff8dd7b88a96296076848370ad3ccf6067cb9deda7787275216f12d09", kill_on_drop: false }`
[INFO] [stdout] 07fdd7fff8dd7b88a96296076848370ad3ccf6067cb9deda7787275216f12d09
