[INFO] cloning repository https://github.com/eren23/attocodepy_swarmtester_9
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/eren23/attocodepy_swarmtester_9" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Feren23%2Fattocodepy_swarmtester_9", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Feren23%2Fattocodepy_swarmtester_9'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 3282d0da2769b7fa0e43c9dba55ac6e5bf47f74e
[INFO] testing eren23/attocodepy_swarmtester_9/3282d0da2769b7fa0e43c9dba55ac6e5bf47f74e against master#ec6f9a5b4413f74386267ef8efc93712c2ce6db6 for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Feren23%2Fattocodepy_swarmtester_9" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/eren23/attocodepy_swarmtester_9
[INFO] finished tweaking git repo https://github.com/eren23/attocodepy_swarmtester_9
[INFO] tweaked toml for git repo https://github.com/eren23/attocodepy_swarmtester_9 written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/eren23/attocodepy_swarmtester_9 on toolchain ec6f9a5b4413f74386267ef8efc93712c2ce6db6
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/eren23/attocodepy_swarmtester_9 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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded quad-rand v0.2.3
[INFO] [stderr]   Downloaded objc-rs v0.2.8
[INFO] [stderr]   Downloaded noise v0.9.0
[INFO] [stderr]   Downloaded macroquad_macro v0.1.8
[INFO] [stderr]   Downloaded fontdue v0.9.3
[INFO] [stderr]   Downloaded miniquad v0.4.8
[INFO] [stderr]   Downloaded glam v0.27.0
[INFO] [stderr]   Downloaded macroquad v0.4.14
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] d8636b1d4d88fc3bf567b500da16056cbffc9b6103ec347e9ff9e42a2bdd33d5
[INFO] running `Command { std: "docker" "start" "-a" "d8636b1d4d88fc3bf567b500da16056cbffc9b6103ec347e9ff9e42a2bdd33d5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "d8636b1d4d88fc3bf567b500da16056cbffc9b6103ec347e9ff9e42a2bdd33d5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d8636b1d4d88fc3bf567b500da16056cbffc9b6103ec347e9ff9e42a2bdd33d5", kill_on_drop: false }`
[INFO] [stdout] d8636b1d4d88fc3bf567b500da16056cbffc9b6103ec347e9ff9e42a2bdd33d5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 8f0f1dfe9f9c7c73ffb44d09bba6f75f74e7dc59652efda35079e4fd42e88b41
[INFO] running `Command { std: "docker" "start" "-a" "8f0f1dfe9f9c7c73ffb44d09bba6f75f74e7dc59652efda35079e4fd42e88b41", kill_on_drop: false }`
[INFO] [stderr]    Compiling libm v0.2.16
[INFO] [stderr]    Compiling zerocopy v0.8.42
[INFO] [stderr]    Compiling simd-adler32 v0.3.8
[INFO] [stderr]    Compiling quote v1.0.45
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling anstyle-parse v1.0.0
[INFO] [stderr]    Compiling colorchoice v1.0.5
[INFO] [stderr]    Compiling miniquad v0.4.8
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]    Compiling anstyle v1.0.14
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling ttf-parser v0.21.1
[INFO] [stderr]    Compiling bytemuck v1.25.0
[INFO] [stderr]    Compiling clap_lex v1.1.0
[INFO] [stderr]    Compiling glam v0.27.0
[INFO] [stderr]    Compiling quad-rand v0.2.3
[INFO] [stderr]    Compiling memchr v2.8.0
[INFO] [stderr]    Compiling macroquad_macro v0.1.8
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling fdeflate v0.3.7
[INFO] [stderr]    Compiling anstream v1.0.0
[INFO] [stderr]    Compiling rand_xorshift v0.3.0
[INFO] [stderr]    Compiling flate2 v1.1.9
[INFO] [stderr]    Compiling clap_builder v4.6.0
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling png v0.17.16
[INFO] [stderr]    Compiling fontdue v0.9.3
[INFO] [stderr]    Compiling image v0.24.9
[INFO] [stderr]    Compiling macroquad v0.4.14
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling clap_derive v4.6.0
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling clap v4.6.0
[INFO] [stderr]    Compiling rand_distr v0.4.3
[INFO] [stderr]    Compiling noise v0.9.0
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling swarm-economy v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 30.95s
[INFO] running `Command { std: "docker" "inspect" "8f0f1dfe9f9c7c73ffb44d09bba6f75f74e7dc59652efda35079e4fd42e88b41", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8f0f1dfe9f9c7c73ffb44d09bba6f75f74e7dc59652efda35079e4fd42e88b41", kill_on_drop: false }`
[INFO] [stdout] 8f0f1dfe9f9c7c73ffb44d09bba6f75f74e7dc59652efda35079e4fd42e88b41
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] e68234ea8c93efbcc7e172f4256bfb5ecaf0e8c60a99e3bca344d9fa9bbc1e53
[INFO] running `Command { std: "docker" "start" "-a" "e68234ea8c93efbcc7e172f4256bfb5ecaf0e8c60a99e3bca344d9fa9bbc1e53", kill_on_drop: false }`
[INFO] [stderr]    Compiling zerocopy v0.8.42
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling zerocopy-derive v0.8.42
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling ciborium-io v0.2.2
[INFO] [stderr]    Compiling plotters-backend v0.3.7
[INFO] [stderr]    Compiling cast v0.3.0
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling is-terminal v0.4.17
[INFO] [stderr]    Compiling anes v0.1.6
[INFO] [stderr]    Compiling oorandom v11.1.5
[INFO] [stderr]    Compiling plotters-svg v0.3.7
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling plotters v0.3.7
[INFO] [stderr]    Compiling rayon v1.11.0
[INFO] [stderr]    Compiling criterion-plot v0.5.0
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling tinytemplate v1.2.1
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling half v2.7.1
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling ciborium-ll v0.2.2
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling ciborium v0.2.2
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling criterion v0.5.1
[INFO] [stderr]    Compiling noise v0.9.0
[INFO] [stderr]    Compiling rand_distr v0.4.3
[INFO] [stderr]    Compiling swarm-economy v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> src/metrics/tracker.rs:244:9
[INFO] [stdout]     |
[INFO] [stdout] 244 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 35.25s
[INFO] running `Command { std: "docker" "inspect" "e68234ea8c93efbcc7e172f4256bfb5ecaf0e8c60a99e3bca344d9fa9bbc1e53", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e68234ea8c93efbcc7e172f4256bfb5ecaf0e8c60a99e3bca344d9fa9bbc1e53", kill_on_drop: false }`
[INFO] [stdout] e68234ea8c93efbcc7e172f4256bfb5ecaf0e8c60a99e3bca344d9fa9bbc1e53
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 562d8618608e48849a3ade8b33a0815dbe34710ebf81bde2ba119ddd37de9542
[INFO] running `Command { std: "docker" "start" "-a" "562d8618608e48849a3ade8b33a0815dbe34710ebf81bde2ba119ddd37de9542", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `super::*`
[INFO] [stderr]    --> src/metrics/tracker.rs:244:9
[INFO] [stderr]     |
[INFO] [stderr] 244 |     use super::*;
[INFO] [stderr]     |         ^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `swarm-economy` (lib test) generated 1 warning (run `cargo fix --lib -p swarm-economy --tests` to apply 1 suggestion)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.23s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/swarm_economy-40a94b3fe2ff7822)
[INFO] [stdout] 
[INFO] [stdout] running 202 tests
[INFO] [stdout] test agents::actions::tests::movement_clamps_speed_mult ... ok
[INFO] [stdout] test agents::actions::tests::movement_clamps_turn ... ok
[INFO] [stdout] test agents::actions::tests::default_action_is_idle ... ok
[INFO] [stdout] test agents::actions::tests::sanitize_clamps_all_fields ... ok
[INFO] [stdout] test agents::caravan::tests::dissolution_when_at_city ... ok
[INFO] [stdout] test agents::caravan::tests::dissolution_when_spread_too_far ... ok
[INFO] [stdout] test agents::caravan::tests::already_in_caravan_cannot_join_new ... ok
[INFO] [stdout] test agents::caravan::tests::heading_diff_opposite ... ok
[INFO] [stdout] test agents::caravan::tests::heading_diff_same_direction ... ok
[INFO] [stdout] test agents::caravan::tests::form_caravan_with_three_nearby_merchants ... ok
[INFO] [stdout] test agents::caravan::tests::heading_diff_wraps_around ... ok
[INFO] [stdout] test agents::caravan::tests::highest_sociability_initiates_first ... ok
[INFO] [stdout] test agents::caravan::tests::multiple_soldiers_multiple_fees ... ok
[INFO] [stdout] test agents::caravan::tests::no_caravan_if_headings_too_different ... ok
[INFO] [stdout] test agents::caravan::tests::no_caravan_if_low_sociability ... ok
[INFO] [stdout] test agents::caravan::tests::no_caravan_if_too_far_apart ... ok
[INFO] [stdout] test agents::caravan::tests::leader_gets_zero_offset ... ok
[INFO] [stdout] test agents::caravan::tests::movement_uses_slowest_speed_and_leader_heading ... ok
[INFO] [stdout] test agents::caravan::tests::no_caravan_with_only_one_other ... ok
[INFO] [stdout] test agents::caravan::tests::no_dissolution_when_close_together ... ok
[INFO] [stdout] test agents::caravan::tests::soldier_escort_charges_fees ... ok
[INFO] [stdout] test agents::caravan::tests::soldier_out_of_range_not_attached ... ok
[INFO] [stdout] test agents::caravan::tests::spread_exceeds_threshold ... ok
[INFO] [stdout] test agents::caravan::tests::spread_within_threshold ... ok
[INFO] [stdout] test agents::merchant::tests::bankruptcy_after_grace_period ... ok
[INFO] [stdout] test agents::merchant::tests::price_memory_merge_keeps_newer ... ok
[INFO] [stdout] test agents::merchant::tests::fatigue_mult_formula ... ok
[INFO] [stdout] test agents::merchant::tests::ledger_caps_at_50 ... ok
[INFO] [stdout] test agents::merchant::tests::price_memory_respects_ttl ... ok
[INFO] [stdout] test agents::merchant::tests::reflect_at_bounds ... ok
[INFO] [stdout] test agents::merchant::tests::new_merchant_has_correct_defaults ... ok
[INFO] [stdout] test agents::merchant::tests::bankruptcy_resets_when_gold_positive ... ok
[INFO] [stdout] test agents::merchant::tests::inventory_weight_tracking ... ok
[INFO] [stdout] test agents::merchant::tests::collapse_drops_15_percent ... ok
[INFO] [stdout] test agents::merchant::tests::inventory_fill_ratio_correct ... ok
[INFO] [stdout] test agents::merchant::tests::shipwright_gets_extra_carry ... ok
[INFO] [stdout] test agents::traits::tests::deterministic_with_same_seed ... ok
[INFO] [stdout] test agents::merchant::tests::inventory_respects_max_carry ... ok
[INFO] [stdout] test agents::merchant::tests::remove_from_inventory_cleans_up ... ok
[INFO] [stdout] test config::tests::test_invalid_range_detected ... ok
[INFO] [stdout] test config::tests::test_load_default_config ... ok
[INFO] [stdout] test market::crafting::tests::all_tier3_require_workshop ... ok
[INFO] [stdout] test market::crafting::tests::find_available_excludes_tier3_without_workshop ... ok
[INFO] [stdout] test market::crafting::tests::find_available_filters_by_inventory ... ok
[INFO] [stdout] test market::crafting::tests::find_available_includes_tier3_with_workshop ... ok
[INFO] [stdout] test market::crafting::tests::no_tier1_or_tier2_require_workshop ... ok
[INFO] [stdout] test market::crafting::tests::profitability_calculation ... ok
[INFO] [stdout] test market::crafting::tests::profitability_negative_margin ... ok
[INFO] [stdout] test agents::traits::tests::random_traits_in_range ... ok
[INFO] [stdout] test market::crafting::tests::registry_has_16_recipes ... ok
[INFO] [stdout] test market::crafting::tests::start_craft_consumes_inputs ... ok
[INFO] [stdout] test market::crafting::tests::start_craft_fails_without_workshop_for_tier3 ... ok
[INFO] [stdout] test market::crafting::tests::tick_craft_completes_without_specialization ... ok
[INFO] [stdout] test market::crafting::tests::tick_craft_faster_with_matching_specialization ... ok
[INFO] [stdout] test market::crafting::tests::tier_counts ... ok
[INFO] [stdout] test market::gossip::tests::camp_locations_shared_on_gossip ... ok
[INFO] [stdout] test market::crafting::tests::start_craft_fails_insufficient_materials ... ok
[INFO] [stdout] test market::gossip::tests::caravan_shares_camp_knowledge ... ok
[INFO] [stdout] test market::gossip::tests::gossip_exchanges_one_price_entry_each_way ... ok
[INFO] [stdout] test market::gossip::tests::caravan_members_get_full_merge ... ok
[INFO] [stdout] test market::gossip::tests::no_gossip_when_out_of_range ... ok
[INFO] [stdout] test config::tests::test_invalid_tax_rate_detected ... ok
[INFO] [stdout] test market::gossip::tests::known_camps_not_re_shared ... ok
[INFO] [stdout] test market::order_book::tests::avg_price_calculation ... ok
[INFO] [stdout] test market::order_book::tests::basic_match ... ok
[INFO] [stdout] test market::order_book::tests::dynamic_tax_clamped ... ok
[INFO] [stdout] test config::tests::test_profession_distribution_must_sum_to_one ... ok
[INFO] [stdout] test market::order_book::tests::dynamic_tax_lowers_on_low_volume ... ok
[INFO] [stdout] test market::order_book::tests::dynamic_tax_raises_on_high_volume ... ok
[INFO] [stdout] test market::order_book::tests::dynamic_tax_raises_when_treasury_low ... ok
[INFO] [stdout] test market::order_book::tests::expire_keeps_fresh_orders ... ok
[INFO] [stdout] test market::order_book::tests::expire_removes_old_orders ... ok
[INFO] [stdout] test market::order_book::tests::market_hall_doubles_capacity ... ok
[INFO] [stdout] test market::order_book::tests::no_match_when_buy_below_sell ... ok
[INFO] [stdout] test market::order_book::tests::multiple_sells_match_one_buy ... ok
[INFO] [stdout] test market::order_book::tests::npc_demand_austerity_mode ... ok
[INFO] [stdout] test market::order_book::tests::no_self_matching ... ok
[INFO] [stdout] test market::order_book::tests::npc_demand_generates_orders ... ok
[INFO] [stdout] test market::order_book::tests::npc_demand_respects_budget ... ok
[INFO] [stdout] test market::order_book::tests::place_order_adds_to_book ... ok
[INFO] [stdout] test market::order_book::tests::partial_fill ... ok
[INFO] [stdout] test market::order_book::tests::place_order_respects_capacity ... ok
[INFO] [stdout] test market::order_book::tests::price_priority ... ok
[INFO] [stdout] test market::order_book::tests::price_recorded_on_match ... ok
[INFO] [stdout] test agents::traits::tests::random_traits_approximately_centered ... ok
[INFO] [stdout] test market::order_book::tests::scarcity_all_sells ... ok
[INFO] [stdout] test market::order_book::tests::scarcity_all_buys ... ok
[INFO] [stdout] test market::order_book::tests::scarcity_balanced ... ok
[INFO] [stdout] test market::order_book::tests::self_match_skipped_but_other_matches ... ok
[INFO] [stdout] test market::order_book::tests::set_market_hall_updates_capacity ... ok
[INFO] [stdout] test market::order_book::tests::tax_calculation ... ok
[INFO] [stdout] test market::gossip::tests::zero_sociability_prevents_gossip ... ok
[INFO] [stdout] test market::order_book::tests::scarcity_no_orders ... ok
[INFO] [stdout] test metrics::emergence::tests::dbscan_all_noise ... ok
[INFO] [stdout] test market::order_book::tests::time_priority_at_same_price ... ok
[INFO] [stdout] test metrics::emergence::tests::erfc_values ... ok
[INFO] [stdout] test metrics::emergence::tests::detrend_removes_linear ... ok
[INFO] [stdout] test metrics::emergence::tests::dbscan_finds_clusters ... ok
[INFO] [stdout] test metrics::emergence::tests::pearson_r_perfect_positive ... ok
[INFO] [stdout] test metrics::emergence::tests::pearson_r_no_correlation ... ok
[INFO] [stdout] test metrics::emergence::tests::variance_computation ... ok
[INFO] [stdout] test metrics::inequality::tests::gini_empty ... ok
[INFO] [stdout] test metrics::inequality::tests::gini_moderate ... ok
[INFO] [stdout] test metrics::inequality::tests::gini_perfect_equality ... ok
[INFO] [stdout] test metrics::inequality::tests::histogram_all_same ... ok
[INFO] [stdout] test metrics::inequality::tests::histogram_basic ... ok
[INFO] [stdout] test metrics::inequality::tests::histogram_empty ... ok
[INFO] [stdout] test metrics::inequality::tests::lorenz_empty ... ok
[INFO] [stdout] test metrics::inequality::tests::lorenz_equal ... ok
[INFO] [stdout] test metrics::reporter::tests::round2_works ... ok
[INFO] [stdout] test metrics::tracker::tests::road_entropy_concentrated_is_low ... ok
[INFO] [stdout] test metrics::inequality::tests::gini_perfect_inequality ... ok
[INFO] [stdout] test metrics::tracker::tests::road_entropy_empty_is_zero ... ok
[INFO] [stdout] test metrics::inequality::tests::gini_single ... ok
[INFO] [stdout] test metrics::tracker::tests::road_entropy_uniform_is_high ... ok
[INFO] [stdout] test world::bandit::tests::camps_avoid_cities ... ok
[INFO] [stdout] test world::bandit::tests::camp_starvation_destroys_camp ... ok
[INFO] [stdout] test world::bandit::tests::danger_signal_deposited_on_robbery ... ok
[INFO] [stdout] test world::bandit::tests::initial_camp_placement ... ok
[INFO] [stdout] test world::bandit::tests::caravan_of_four_is_immune ... ok
[INFO] [stdout] test world::bandit::tests::respawn_maintains_target_count ... ok
[INFO] [stdout] test world::bandit::tests::camps_only_on_forest_or_hills ... ok
[INFO] [stdout] test world::bandit::tests::robbery_steals_within_configured_range ... ok
[INFO] [stdout] test world::bandit::tests::seasonal_modifier_values ... ok
[INFO] [stdout] test world::reputation::tests::bilinear_sample_at_cell_center ... ok
[INFO] [stdout] test world::reputation::tests::channels_are_independent ... ok
[INFO] [stdout] test world::reputation::tests::decay_reduces_signal ... ok
[INFO] [stdout] test world::reputation::tests::deposit_adds_signal ... ok
[INFO] [stdout] test world::reputation::tests::deposit_clamps_at_one ... ok
[INFO] [stdout] test world::reputation::tests::deposit_out_of_bounds_is_noop ... ok
[INFO] [stdout] test world::reputation::tests::diffusion_spreads_signal ... ok
[INFO] [stdout] test world::reputation::tests::gradient_points_towards_source ... ok
[INFO] [stdout] test world::reputation::tests::grid_dimensions ... ok
[INFO] [stdout] test world::reputation::tests::scanner_detects_asymmetry ... ok
[INFO] [stdout] test world::resource_node::tests::clay_summer_unaffected ... ok
[INFO] [stdout] test world::resource_node::tests::clay_winter_northern_zero ... ok
[INFO] [stdout] test world::resource_node::tests::clay_winter_southern_unaffected ... ok
[INFO] [stdout] test world::resource_node::tests::depletion_at_80_pct_halves_yield ... ok
[INFO] [stdout] test world::resource_node::tests::depletion_clamped_to_one ... ok
[INFO] [stdout] test world::resource_node::tests::exhausted_node_yields_zero ... ok
[INFO] [stdout] test world::resource_node::tests::exhaustion_counter_resets_on_harvest ... ok
[INFO] [stdout] test world::resource_node::tests::exhaustion_no_early_recovery ... ok
[INFO] [stdout] test world::resource_node::tests::exhaustion_recovery_after_2000_ticks ... ok
[INFO] [stdout] test world::resource_node::tests::extraction_increases_depletion ... ok
[INFO] [stdout] test world::resource_node::tests::extraction_sets_harvested_flag ... ok
[INFO] [stdout] test world::resource_node::tests::fish_autumn_penalty ... ok
[INFO] [stdout] test world::resource_node::tests::fish_spring_bonus ... ok
[INFO] [stdout] test world::resource_node::tests::fresh_node_full_yield ... ok
[INFO] [stdout] test world::resource_node::tests::grain_summer_double ... ok
[INFO] [stdout] test world::resource_node::tests::grain_winter_reduced ... ok
[INFO] [stdout] test world::resource_node::tests::herbs_summer_double ... ok
[INFO] [stdout] test world::resource_node::tests::herbs_winter_reduced ... ok
[INFO] [stdout] test world::resource_node::tests::no_regen_when_harvested ... ok
[INFO] [stdout] test world::resource_node::tests::regen_does_not_go_below_zero ... ok
[INFO] [stdout] test world::resource_node::tests::regen_when_not_harvested ... ok
[INFO] [stdout] test world::resource_node::tests::scatter_at_least_one_of_each_commodity ... ok
[INFO] [stdout] test world::resource_node::tests::scatter_avoids_mountains_and_water ... ok
[INFO] [stdout] test world::resource_node::tests::scatter_base_yield_in_range ... ok
[INFO] [stdout] test world::resource_node::tests::scatter_enforces_minimum_six ... ok
[INFO] [stdout] test market::gossip::tests::stale_entries_not_shared ... ok
[INFO] [stdout] test world::resource_node::tests::scatter_generates_correct_count ... ok
[INFO] [stdout] test world::bandit::tests::walled_city_prevents_attack ... ok
[INFO] [stdout] test world::road::tests::decay_reduces_values ... ok
[INFO] [stdout] test world::resource_node::tests::timber_ore_unaffected_by_season ... ok
[INFO] [stdout] test world::resource_node::tests::ticks_per_unit_is_three ... ok
[INFO] [stdout] test world::road::tests::grid_dimensions ... ok
[INFO] [stdout] test world::road::tests::out_of_bounds_returns_zero ... ok
[INFO] [stdout] test world::road::tests::speed_multiplier_range ... ok
[INFO] [stdout] test world::road::tests::traverse_accumulates ... ok
[INFO] [stdout] test world::road::tests::traverse_clamps_at_one ... ok
[INFO] [stdout] test world::road::tests::traverse_increments ... ok
[INFO] [stdout] test world::terrain::tests::coast_adjacent_to_land ... ok
[INFO] [stdout] test world::terrain::tests::deterministic_generation ... ok
[INFO] [stdout] test market::order_book::tests::price_history_capped ... ok
[INFO] [stdout] test world::terrain::tests::impassable_terrain ... ok
[INFO] [stdout] test world::bandit::tests::patrol_stays_within_radius ... ok
[INFO] [stdout] test world::terrain::tests::path_all_cells_passable ... ok
[INFO] [stdout] test world::terrain::tests::height_range_normalised ... ok
[INFO] [stdout] test world::terrain::tests::out_of_bounds_returns_none ... ok
[INFO] [stdout] test world::terrain::tests::path_to_self ... ok
[INFO] [stdout] test world::terrain::tests::unreachable_returns_none ... ok
[INFO] [stdout] test world::terrain::tests::impassable_start_or_goal_returns_none ... ok
[INFO] [stdout] test world::terrain::tests::path_between_passable_neighbours ... ok
[INFO] [stdout] test world::terrain::tests::terrain_classification_covers_all ... ok
[INFO] [stdout] test world::terrain::tests::winter_speed_modifier ... ok
[INFO] [stdout] test world::terrain::tests::prefers_faster_terrain ... ok
[INFO] [stdout] test world::world::tests::tick_advances_state ... ok
[INFO] [stdout] test world::world::tests::world_initializes_without_panic ... ok
[INFO] [stdout] test agents::economy_manager::tests::initial_population_has_all_professions ... ok
[INFO] [stdout] test agents::economy_manager::tests::merchants_get_unique_ids ... ok
[INFO] [stdout] test agents::sensory::tests::nearest_city_returns_closest ... ok
[INFO] [stdout] test agents::economy_manager::tests::gold_conservation_tracked ... ok
[INFO] [stdout] test agents::economy_manager::tests::bankrupt_merchants_removed ... ok
[INFO] [stdout] test world::world::tests::merchants_move_during_tick ... ok
[INFO] [stdout] test agents::sensory::tests::sensory_input_builds_without_panic ... ok
[INFO] [stdout] test agents::economy_manager::tests::initial_population_count ... ok
[INFO] [stdout] test agents::economy_manager::tests::food_crisis_detection ... ok
[INFO] [stdout] test agents::sensory::tests::neighbors_detected_within_range ... ok
[INFO] [stdout] test world::world::tests::season_cycles ... ok
[INFO] [stdout] test agents::sensory::tests::bandit_detected_within_80px ... ok
[INFO] [stdout] test agents::economy_manager::tests::spawn_respects_max_population ... ok
[INFO] [stdout] test world::world::tests::multiple_ticks_without_panic ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 202 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 37.95s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/swarm_economy-03aafd9d95727c7c)
[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/test_bandit.rs (/opt/rustwide/target/debug/deps/test_bandit-f0a792314382d87e)
[INFO] [stdout] 
[INFO] [stdout] running 18 tests
[INFO] [stdout] test camps_spawn_on_forest_terrain ... ok
[INFO] [stdout] test camp_with_no_robberies_gets_destroyed ... ok
[INFO] [stdout] test camps_spawn_on_hills_terrain ... ok
[INFO] [stdout] test bandits_can_attack_near_unwalled_cities ... ok
[INFO] [stdout] test gold_stolen_is_within_configured_range ... ok
[INFO] [stdout] test merchants_within_15px_can_be_attacked ... ok
[INFO] [stdout] test bandits_dont_attack_near_walled_cities ... ok
[INFO] [stdout] test merchants_beyond_15px_are_not_attacked ... ok
[INFO] [stdout] test caravan_of_4_or_more_is_immune ... ok
[INFO] [stdout] test caravan_of_5_is_also_immune ... ok
[INFO] [stdout] test camps_only_spawn_on_forest_or_hills ... ok
[INFO] [stdout] test soldier_nearby_triggers_combat ... ok
[INFO] [stdout] test respawn_reports_camps_spawned ... ok
[INFO] [stdout] test system_respawns_camps_to_maintain_target_count ... ok
[INFO] [stdout] test caravan_of_3_has_repel_chance ... ok
[INFO] [stdout] test bandits_stay_within_camp_patrol_radius_after_many_ticks ... ok
[INFO] [stdout] test summer_increases_attack_frequency ... ok
[INFO] [stdout] test soldier_combat_has_roughly_50_50_outcomes ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 18 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/test_brain_craftsman.rs (/opt/rustwide/target/debug/deps/test_brain_craftsman-31e8c85dc835a5cf)
[INFO] [stdout] 
[INFO] [stdout] running 10 tests
[INFO] [stdout] test travel_toward_city_when_not_at_one ... ok
[INFO] [stdout] test crafting_not_at_city_transitions_to_buying_materials ... ok
[INFO] [stdout] test buys_materials_at_city_when_none ... ok
[INFO] [stdout] test selling_done_transitions_to_buying_materials ... ok
[INFO] [stdout] test picks_highest_margin_recipe ... ok
[INFO] [stderr]      Running tests/test_brain_farmer.rs (/opt/rustwide/target/debug/deps/test_brain_farmer-3dd90292a726ca52)
[INFO] [stdout] test transitions_to_crafting_with_materials ... ok
[INFO] [stdout] test sells_tier1_before_tier0 ... ok
[INFO] [stdout] test crafting_produces_recipe_action ... ok
[INFO] [stdout] test sells_highest_tier_first ... ok
[INFO] [stdout] test inventory_full_without_craftable_transitions_to_selling ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 10 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 14 tests
[INFO] [stdout] test summer_rejects_fish ... ok
[INFO] [stdout] test summer_targets_herbs ... ok
[INFO] [stdout] test travel_to_city_when_full ... ok
[INFO] [stdout] test winter_rejects_grain ... ok
[INFO] [stdout] test sell_priority_grain_first ... ok
[INFO] [stdout] test extract_at_seasonal_target_resource ... ok
[INFO] [stdout] test autumn_targets_all_three ... ok
[INFO] [stdout] test summer_targets_grain ... ok
[INFO] [stdout] test winter_targets_only_fish ... ok
[INFO] [stdout] test winter_rejects_herbs ... ok
[INFO] [stdout] test rest_when_fatigued ... ok
[INFO] [stdout] test sell_priority_herbs_after_grain ... ok
[INFO] [stdout] test sell_priority_fish_last ... ok
[INFO] [stdout] test spring_targets_all_three ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 14 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/test_brain_miner.rs (/opt/rustwide/target/debug/deps/test_brain_miner-dcd443a3dff021b8)
[INFO] [stdout] 
[INFO] [stdout] running 10 tests
[INFO] [stdout] test selling_ore_at_city ... ok
[INFO] [stdout] test extracting_continues_until_full ... ok
[INFO] [stdout] test non_target_commodity_causes_wander ... ok
[INFO] [stdout] test travel_to_city_when_inventory_full ... ok
[INFO] [stdout] test extraction_to_traveling_to_city_when_full ... ok
[INFO] [stdout] test extraction_starts_when_at_node ... ok
[INFO] [stdout] test traveling_to_node_moves_toward_ore ... ok
[INFO] [stdout] test clay_accepted_in_summer ... ok
[INFO] [stdout] test frozen_clay_skipped_in_winter ... ok
[INFO] [stdout] test selling_done_transitions_to_traveling_to_node ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 10 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stderr]      Running tests/test_brain_shipwright.rs (/opt/rustwide/target/debug/deps/test_brain_shipwright-77f8ef7503363441)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 10 tests
[INFO] [stdout] test shipwright_merchant_has_3x_carry_capacity ... ok
[INFO] [stdout] test loading_stays_when_inventory_below_60_percent ... ok
[INFO] [stdout] test winter_rest_does_not_sail ... ok
[INFO] [stdout] test loading_at_city_attempts_to_buy_cargo ... ok
[INFO] [stdout] test sailing_speed_0_8_off_coast_terrain ... ok
[INFO] [stdout] test loading_to_sailing_when_inventory_above_60_percent ... ok
[INFO] [stdout] test unloading_at_city_with_goods_sells ... ok
[INFO] [stdout] test winter_forces_resting_state ... ok
[INFO] [stdout] test unloading_state_issues_sell_action ... ok
[INFO] [stdout] test sailing_speed_1_0_on_coast_terrain ... ok
[INFO] [stdout] 
[INFO] [stderr]      Running tests/test_brain_soldier.rs (/opt/rustwide/target/debug/deps/test_brain_soldier-49b9de358faa823e)
[INFO] [stdout] test result: ok. 10 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 11 tests
[INFO] [stdout] test fighting_charges_toward_bandit_at_full_speed_and_deposits_danger ... ok
[INFO] [stdout] test no_escort_transition_when_low_sociability ... ok
[INFO] [stdout] test patrol_moves_with_reduced_speed_and_follows_roads ... ok
[INFO] [stdout] test no_combat_trigger_when_bandit_outside_engage_range ... ok
[INFO] [stdout] test no_rest_when_fatigue_below_70 ... ok
[INFO] [stdout] test combat_disengage_when_bandit_disappears ... ok
[INFO] [stdout] test combat_trigger_when_bandit_within_engage_range ... ok
[INFO] [stdout] test escort_transition_when_caravan_nearby_and_sociable ... ok
[INFO] [stdout] test rest_when_fatigue_above_70 ... ok
[INFO] [stdout] test combat_disengage_when_bandit_far_away ... ok
[INFO] [stdout] test higher_risk_tolerance_gives_larger_engage_range ... ok
[INFO] [stdout] 
[INFO] [stderr]      Running tests/test_brain_trader.rs (/opt/rustwide/target/debug/deps/test_brain_trader-87bd4d75bc65d806)
[INFO] [stdout] test result: ok. 11 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 12 tests
[INFO] [stdout] test fleeing_clears_when_bandit_far ... ok
[INFO] [stdout] test buying_to_transporting_when_nearly_full ... ok
[INFO] [stdout] test fleeing_clears_when_bandit_none ... ok
[INFO] [stdout] test danger_avoidance_turns_away ... ok
[INFO] [stdout] test greed_affects_buy_quantity_low_greed_diversifies ... ok
[INFO] [stdout] test high_greed_weights_profit_scanner_more ... ok
[INFO] [stdout] test fleeing_triggered_by_nearby_bandit ... ok
[INFO] [stdout] test fleeing_not_triggered_in_caravan ... ok
[INFO] [stdout] test greed_affects_buy_quantity_high_greed_all_in ... ok
[INFO] [stdout] test selling_to_scouting_or_resting_when_empty ... ok
[INFO] [stdout] test transporting_to_selling_at_city_with_goods ... ok
[INFO] [stdout] test scouting_to_buying_transition ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 12 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/test_caravan.rs (/opt/rustwide/target/debug/deps/test_caravan-59eca5dba4cda77c)
[INFO] [stdout] 
[INFO] [stdout] running 22 tests
[INFO] [stdout] test caravan_follows_leader_heading ... ok
[INFO] [stdout] test already_assigned_merchants_cannot_join_new_caravan ... ok
[INFO] [stdout] test caravan_forms_with_valid_candidates ... ok
[INFO] [stderr]      Running tests/test_city.rs (/opt/rustwide/target/debug/deps/test_city-0fd558943c09ab5b)
[INFO] [stdout] test caravan_members_listed_for_price_merge ... ok
[INFO] [stdout] test caravan_group_size_reflects_members ... ok
[INFO] [stdout] test caravan_moves_at_slowest_member_speed ... ok
[INFO] [stdout] test dissolution_event_contains_all_member_ids ... ok
[INFO] [stdout] test dissolution_when_reaching_a_city ... ok
[INFO] [stdout] test dissolution_when_spread_exceeds_100px ... ok
[INFO] [stdout] test empty_candidates_produces_no_caravan ... ok
[INFO] [stdout] test escort_fee_is_0_01_per_tick_per_member ... ok
[INFO] [stdout] test formation_requires_initiator_sociability_above_half ... ok
[INFO] [stdout] test formation_requires_proximity_within_30px ... ok
[INFO] [stdout] test formation_requires_similar_heading_within_pi_over_4 ... ok
[INFO] [stdout] test formation_requires_two_others_minimum ... ok
[INFO] [stdout] test highest_sociability_becomes_leader ... ok
[INFO] [stdout] test larger_caravan_provides_more_safety ... ok
[INFO] [stdout] test multiple_soldiers_multiply_fees ... ok
[INFO] [stdout] test no_caravan_when_all_sociability_at_or_below_half ... ok
[INFO] [stdout] test no_dissolution_when_cohesive_and_away_from_cities ... ok
[INFO] [stdout] test soldier_beyond_30px_not_attached ... ok
[INFO] [stdout] test soldier_within_30px_auto_attaches_as_escort ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 22 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 33 tests
[INFO] [stdout] test population_does_not_grow_when_prosperity_too_low ... ok
[INFO] [stdout] test prosperity_clamped_to_zero_to_hundred ... ok
[INFO] [stdout] test prosperity_max_at_full_stats ... ok
[INFO] [stdout] test crafting_speed_specialization_and_workshop_stacks ... ok
[INFO] [stdout] test population_declines_after_200_ticks_without_food ... ok
[INFO] [stdout] test food_resets_ticks_without_food_counter ... ok
[INFO] [stdout] test population_does_not_decline_before_200_ticks_without_food ... ok
[INFO] [stdout] test population_clamped_to_config_range ... ok
[INFO] [stdout] test population_grows_when_prosperous_and_food_stocked ... ok
[INFO] [stdout] test population_grows_with_fish_as_food ... ok
[INFO] [stdout] test crafting_speed_specialization_bonus ... ok
[INFO] [stdout] test population_does_not_grow_without_food ... ok
[INFO] [stdout] test crafting_speed_base_is_one ... ok
[INFO] [stdout] test population_grows_with_provisions_as_food ... ok
[INFO] [stdout] test crafting_speed_workshop_bonus ... ok
[INFO] [stdout] test tax_adjustment_only_at_tick_500_multiples ... ok
[INFO] [stdout] test tax_adjustment_resets_trade_volume ... ok
[INFO] [stdout] test prosperity_zero_when_empty_city ... ok
[INFO] [stdout] test tax_clamped_at_lower_bound ... ok
[INFO] [stdout] test prosperity_sum_of_four_components ... ok
[INFO] [stdout] test record_trade_accumulates_volume_and_tax ... ok
[INFO] [stdout] test tax_increases_when_trade_above_average ... ok
[INFO] [stdout] test tax_stays_in_range_after_many_adjustments ... ok
[INFO] [stdout] test tax_clamped_at_upper_bound ... ok
[INFO] [stdout] test tax_decreases_when_trade_below_average ... ok
[INFO] [stdout] test warehouse_decay_removes_negligible_entries ... ok
[INFO] [stdout] test upgrade_purchase_succeeds_at_exact_cost ... ok
[INFO] [stdout] test warehouse_decays_when_over_capacity ... ok
[INFO] [stdout] test tax_unchanged_when_trade_equals_average ... ok
[INFO] [stdout] test upgrade_purchase_fails_if_already_owned ... ok
[INFO] [stdout] test upgrade_purchase_deducts_cost_and_adds_upgrade ... ok
[INFO] [stdout] test warehouse_no_decay_under_capacity ... ok
[INFO] [stdout] test upgrade_purchase_fails_if_insufficient_treasury ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 33 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/test_crafting.rs (/opt/rustwide/target/debug/deps/test_crafting-b868d8ccebf10823)
[INFO] [stdout] 
[INFO] [stdout] running 25 tests
[INFO] [stdout] test all_tier3_recipes_have_requires_workshop ... ok
[INFO] [stdout] test engine_creates_with_16_recipes ... ok
[INFO] [stdout] test no_tier1_or_tier2_require_workshop ... ok
[INFO] [stdout] test find_available_includes_tier3_with_workshop ... ok
[INFO] [stdout] test specialization_alternates_decrement ... ok
[INFO] [stdout] test find_available_excludes_tier3_without_workshop ... ok
[INFO] [stdout] test non_matching_specialization_does_not_speed_up ... ok
[INFO] [stdout] test can_have_multiple_concurrent_crafting_jobs ... ok
[INFO] [stdout] test start_craft_returns_insufficient_material_when_quantity_too_low ... ok
[INFO] [stdout] test provisions_takes_3_ticks ... ok
[INFO] [stdout] test concurrent_jobs_consume_separate_materials ... ok
[INFO] [stdout] test specialization_makes_crafting_faster ... ok
[INFO] [stdout] test tier1_bricks_is_clay_plus_timber ... ok
[INFO] [stdout] test tier1_has_6_recipes ... ok
[INFO] [stdout] test start_craft_returns_insufficient_material_when_missing_commodity ... ok
[INFO] [stdout] test tier1_medicine_is_grain_plus_herbs ... ok
[INFO] [stdout] test tier1_metalwork_is_ore_plus_clay ... ok
[INFO] [stdout] test tier1_pottery_is_herbs_plus_clay ... ok
[INFO] [stdout] test tier1_provisions_is_grain_plus_fish ... ok
[INFO] [stdout] test tier3_has_4_recipes ... ok
[INFO] [stdout] test tier1_tools_is_timber_plus_ore ... ok
[INFO] [stdout] test tier3_succeeds_with_workshop ... ok
[INFO] [stdout] test tier3_requires_workshop_returns_error_without_it ... ok
[INFO] [stdout] test tools_takes_5_ticks ... ok
[INFO] [stdout] test tier2_has_6_recipes ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 25 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/test_economy_manager.rs (/opt/rustwide/target/debug/deps/test_economy_manager-fb08dab785b0f4af)
[INFO] [stdout] 
[INFO] [stdout] running 14 tests
[INFO] [stdout] test spawn_initial_population_creates_exact_count ... ok
[INFO] [stdout] test gold_conservation_tracked_each_tick ... ok
[INFO] [stdout] test try_spawn_requires_healthy_economy ... ok
[INFO] [stdout] test alive_count_reflects_living_merchants ... ok
[INFO] [stdout] test initial_population_merchants_are_alive ... ok
[INFO] [stdout] test initial_population_has_unique_ids ... ok
[INFO] [stdout] test profession_distribution_within_tolerance ... ok
[INFO] [stdout] test bankrupt_merchant_marked_dead_after_grace_period ... ok
[INFO] [stdout] test profession_counts_correct ... ok
[INFO] [stdout] test bankrupt_merchant_recovers_if_gold_becomes_positive ... ok
[INFO] [stdout] test rebalancing_occurs_at_interval ... ok
[INFO] [stdout] test emergency_farmer_shift_when_no_food_in_cities ... ok
[INFO] [stdout] test try_spawn_does_not_exceed_max_population ... ok
[INFO] [stdout] test gold_history_capped_at_1000 ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 14 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/test_emergence.rs (/opt/rustwide/target/debug/deps/test_emergence-46eec3d1ace3623c)
[INFO] [stdout] 
[INFO] [stdout] running 14 tests
[INFO] [stdout] test emergence_bandit_avoidance has been running for over 60 seconds
[INFO] [stdout] test emergence_boom_bust_cycles has been running for over 60 seconds
[INFO] [stdout] test emergence_caravan_danger_correlation has been running for over 60 seconds
[INFO] [stdout] test emergence_city_growth has been running for over 60 seconds
[INFO] [stdout] test emergence_economic_migration has been running for over 60 seconds
[INFO] [stdout] test emergence_guild_clustering has been running for over 60 seconds
[INFO] [stdout] test emergence_information_propagation has been running for over 60 seconds
[INFO] [stdout] test emergence_market_specialization has been running for over 60 seconds
[INFO] [stdout] test emergence_price_convergence has been running for over 60 seconds
[INFO] [stdout] test emergence_profession_adaptation has been running for over 60 seconds
[INFO] [stdout] test emergence_seasonal_pricing has been running for over 60 seconds
[INFO] [stdout] test emergence_tax_competition has been running for over 60 seconds
[INFO] [stdout] test emergence_trade_route_formation has been running for over 60 seconds
[INFO] [stdout] test emergence_wealth_inequality has been running for over 60 seconds
[ERROR] error running command: no output for 300 seconds
[INFO] running `Command { std: "docker" "inspect" "562d8618608e48849a3ade8b33a0815dbe34710ebf81bde2ba119ddd37de9542", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "562d8618608e48849a3ade8b33a0815dbe34710ebf81bde2ba119ddd37de9542", kill_on_drop: false }`
[INFO] [stdout] 562d8618608e48849a3ade8b33a0815dbe34710ebf81bde2ba119ddd37de9542
