[INFO] cloning repository https://github.com/Zxela/beach-cli
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Zxela/beach-cli" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FZxela%2Fbeach-cli", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FZxela%2Fbeach-cli'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 14c7853d88774fae90f34d2f1a70c904bd704550
[INFO] testing Zxela/beach-cli against master#ec6f9a5b4413f74386267ef8efc93712c2ce6db6 for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FZxela%2Fbeach-cli" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Zxela/beach-cli
[INFO] finished tweaking git repo https://github.com/Zxela/beach-cli
[INFO] tweaked toml for git repo https://github.com/Zxela/beach-cli written to /workspace/builds/worker-4-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Zxela/beach-cli 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/Zxela/beach-cli 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]  Downloading crates ...
[INFO] [stderr]   Downloaded cc v1.2.54
[INFO] [stderr]   Downloaded clap v4.5.54
[INFO] [stderr]   Downloaded clap_builder v4.5.54
[INFO] [stderr]   Downloaded ratatui v0.28.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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] 8f3a2e4994113a3cf4e56512d168e7ff8fbbd7438b85ea1d1e03080ad73b2c3d
[INFO] running `Command { std: "docker" "start" "-a" "8f3a2e4994113a3cf4e56512d168e7ff8fbbd7438b85ea1d1e03080ad73b2c3d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "8f3a2e4994113a3cf4e56512d168e7ff8fbbd7438b85ea1d1e03080ad73b2c3d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8f3a2e4994113a3cf4e56512d168e7ff8fbbd7438b85ea1d1e03080ad73b2c3d", kill_on_drop: false }`
[INFO] [stdout] 8f3a2e4994113a3cf4e56512d168e7ff8fbbd7438b85ea1d1e03080ad73b2c3d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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] c16b25cefff8cc8812bca1dff15a2a4ef7e09c0c3f41e0e40703a442d461fa57
[INFO] running `Command { std: "docker" "start" "-a" "c16b25cefff8cc8812bca1dff15a2a4ef7e09c0c3f41e0e40703a442d461fa57", kill_on_drop: false }`
[INFO] [stderr]    Compiling log v0.4.29
[INFO] [stderr]    Compiling find-msvc-tools v0.1.8
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling zmij v1.0.16
[INFO] [stderr]    Compiling instability v0.3.11
[INFO] [stderr]    Compiling linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling unicode-width v0.1.14
[INFO] [stderr]    Compiling option-ext v0.2.0
[INFO] [stderr]    Compiling indoc v2.0.7
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling clap_builder v4.5.54
[INFO] [stderr]    Compiling compact_str v0.8.1
[INFO] [stderr]    Compiling dirs-sys v0.4.1
[INFO] [stderr]    Compiling cc v1.2.54
[INFO] [stderr]    Compiling lru v0.12.5
[INFO] [stderr]    Compiling cassowary v0.3.0
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling iana-time-zone v0.1.64
[INFO] [stderr]    Compiling directories v5.0.1
[INFO] [stderr]    Compiling signal-hook-mio v0.2.5
[INFO] [stderr]    Compiling crossterm v0.28.1
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling unicode-truncate v1.1.0
[INFO] [stderr]    Compiling rustls v0.23.36
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.23.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling rustls-webpki v0.103.9
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling clap v4.5.54
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling ratatui v0.28.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling chrono v0.4.43
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling hyper-util v0.1.19
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling vanbeach v0.2.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 50.40s
[INFO] running `Command { std: "docker" "inspect" "c16b25cefff8cc8812bca1dff15a2a4ef7e09c0c3f41e0e40703a442d461fa57", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c16b25cefff8cc8812bca1dff15a2a4ef7e09c0c3f41e0e40703a442d461fa57", kill_on_drop: false }`
[INFO] [stdout] c16b25cefff8cc8812bca1dff15a2a4ef7e09c0c3f41e0e40703a442d461fa57
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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] 9c1fcbcc65f567eef390056ef6e1799adf21f1fd0d6ff56df82cb04264f94855
[INFO] running `Command { std: "docker" "start" "-a" "9c1fcbcc65f567eef390056ef6e1799adf21f1fd0d6ff56df82cb04264f94855", kill_on_drop: false }`
[INFO] [stderr]    Compiling tempfile v3.24.0
[INFO] [stderr]    Compiling vanbeach v0.2.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 8.73s
[INFO] running `Command { std: "docker" "inspect" "9c1fcbcc65f567eef390056ef6e1799adf21f1fd0d6ff56df82cb04264f94855", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9c1fcbcc65f567eef390056ef6e1799adf21f1fd0d6ff56df82cb04264f94855", kill_on_drop: false }`
[INFO] [stdout] 9c1fcbcc65f567eef390056ef6e1799adf21f1fd0d6ff56df82cb04264f94855
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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] 78a8893b887ae6ba0f9854dc8e2c6cf7c43b9549364de00f47aea835f9e18514
[INFO] running `Command { std: "docker" "start" "-a" "78a8893b887ae6ba0f9854dc8e2c6cf7c43b9549364de00f47aea835f9e18514", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.39s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/vanbeach-599dbad10e0d7194)
[INFO] [stdout] 
[INFO] [stdout] running 164 tests
[INFO] [stdout] test activities::tests::test_activity_all_returns_five_activities ... ok
[INFO] [stdout] test activities::tests::test_activity_label_peace ... ok
[INFO] [stdout] test activities::tests::test_activity_label_sailing ... ok
[INFO] [stdout] test activities::tests::test_activity_label_swimming ... ok
[INFO] [stdout] test activities::tests::test_all_activities_blocked_during_snow ... ok
[INFO] [stdout] test activities::tests::test_from_str_invalid_input ... ok
[INFO] [stdout] test activities::tests::test_activity_label_sunset ... ok
[INFO] [stdout] test activities::tests::test_all_activities_blocked_during_thunderstorm ... ok
[INFO] [stdout] test activities::tests::test_from_str_sailing_aliases ... ok
[INFO] [stdout] test activities::tests::test_from_str_peace_aliases ... ok
[INFO] [stdout] test activities::tests::test_from_str_sunbathing_aliases ... ok
[INFO] [stdout] test activities::tests::test_from_str_swimming_aliases ... ok
[INFO] [stdout] test activities::tests::test_from_str_with_whitespace ... ok
[INFO] [stdout] test activities::tests::test_activity_label_sunbathing ... ok
[INFO] [stdout] test activities::tests::test_sailing_blocked_when_dangerous_wind ... ok
[INFO] [stdout] test activities::tests::test_sanity_gate_block_reason_contains_temperature ... ok
[INFO] [stdout] test activities::tests::test_score_factors_are_all_in_range ... ok
[INFO] [stdout] test activities::tests::test_score_temperature_returns_0_when_far_outside_range ... ok
[INFO] [stdout] test activities::tests::test_score_temperature_returns_1_when_in_ideal_range ... ok
[INFO] [stdout] test activities::tests::test_score_temperature_scales_between_ideal_and_boundary ... ok
[INFO] [stdout] test activities::tests::test_full_score_time_slot_produces_score_in_0_100_range ... ok
[INFO] [stdout] test activities::tests::test_from_str_sunset ... ok
[INFO] [stdout] test activities::tests::test_score_tide_for_high_preference ... ok
[INFO] [stdout] test activities::tests::test_peace_activity_not_blocked_by_cold_or_wind ... ok
[INFO] [stdout] test activities::tests::test_peace_profile_heavily_weights_crowd_aversion ... ok
[INFO] [stdout] test activities::tests::test_peace_time_scorer_peaks_at_early_morning ... ok
[INFO] [stdout] test activities::tests::test_sailing_profile_rewards_high_wind ... ok
[INFO] [stdout] test activities::tests::test_sanity_gate_block_reason_contains_wind_speed ... ok
[INFO] [stdout] test activities::tests::test_score_tide_for_mid_preference ... ok
[INFO] [stdout] test activities::tests::test_score_uv_for_high_preference ... ok
[INFO] [stdout] test activities::tests::test_score_water_quality_returns_0_for_closed_1_for_safe ... ok
[INFO] [stdout] test activities::tests::test_score_crowd_inverts_crowd_level ... ok
[INFO] [stdout] test activities::tests::test_sailing_not_blocked_with_moderate_wind ... ok
[INFO] [stdout] test activities::tests::test_score_time_slot_sets_blocked_false ... ok
[INFO] [stdout] test activities::tests::test_get_profile_returns_correct_activity ... ok
[INFO] [stdout] test activities::tests::test_score_wind_below_min_for_sailing ... ok
[INFO] [stdout] test activities::tests::test_score_wind_handles_zero_min_range ... ok
[INFO] [stdout] test activities::tests::test_score_wind_returns_1_when_in_ideal_range ... ok
[INFO] [stdout] test activities::tests::test_sunbathing_blocked_when_cold ... ok
[INFO] [stdout] test activities::tests::test_sunbathing_blocked_when_overcast ... ok
[INFO] [stdout] test activities::tests::test_sunbathing_blocked_when_raining ... ok
[INFO] [stdout] test activities::tests::test_sunset_activity_not_blocked_by_cold_or_wind ... ok
[INFO] [stdout] test activities::tests::test_sunset_time_scorer_dynamic_peaks_at_sunset_hour ... ok
[INFO] [stdout] test activities::tests::test_sunset_time_scorer_dynamic_scores_decrease_with_distance ... ok
[INFO] [stdout] test activities::tests::test_sunset_time_scorer_dynamic_with_early_sunset ... ok
[INFO] [stdout] test activities::tests::test_sunset_time_scorer_dynamic_with_late_sunset ... ok
[INFO] [stdout] test activities::tests::test_sunset_time_scorer_peaks_at_evening_hours ... ok
[INFO] [stdout] test activities::tests::test_swimming_blocked_when_cold ... ok
[INFO] [stdout] test activities::tests::test_swimming_blocked_when_raining ... ok
[INFO] [stdout] test activities::tests::test_swimming_blocked_with_drizzle_codes ... ok
[INFO] [stdout] test activities::tests::test_swimming_blocked_with_rain_shower_codes ... ok
[INFO] [stdout] test activities::tests::test_swimming_not_blocked_when_conditions_good ... ok
[INFO] [stdout] test activities::tests::test_swimming_profile_penalizes_unsafe_water_heavily ... ok
[INFO] [stdout] test activities::tests::test_tide_preference_derives ... ok
[INFO] [stdout] test activities::tests::test_time_slot_score_has_correct_metadata ... ok
[INFO] [stdout] test activities::tests::test_uv_preference_derives ... ok
[INFO] [stdout] test activities::tests::test_score_uv_for_low_preference ... ok
[INFO] [stdout] test cache::manager::tests::test_new_creates_xdg_compliant_path ... ok
[INFO] [stdout] test cache::manager::tests::test_read_returns_none_for_missing_key ... ok
[INFO] [stdout] test cache::manager::tests::test_cache_survives_serialization_roundtrip ... ok
[INFO] [stdout] test cache::manager::tests::test_read_returns_data_with_is_expired_false_for_fresh_cache ... ok
[INFO] [stdout] test cache::manager::tests::test_overwrite_existing_cache ... ok
[INFO] [stdout] test cli::tests::test_parse_activity_arg_invalid ... ok
[INFO] [stdout] test cli::tests::test_parse_activity_arg_peace_aliases ... ok
[INFO] [stdout] test cli::tests::test_cli_parse_plan_only ... ok
[INFO] [stdout] test cli::tests::test_parse_activity_arg_swimming_aliases ... ok
[INFO] [stdout] test cli::tests::test_startup_config_from_cli_no_plan ... ok
[INFO] [stdout] test cli::tests::test_startup_config_from_cli_plan_with_activity ... ok
[INFO] [stdout] test cli::tests::test_cli_parse_plan_with_activity ... ok
[INFO] [stdout] test cli::tests::test_startup_config_default ... ok
[INFO] [stdout] test cli::tests::test_startup_config_from_cli_invalid_activity ... ok
[INFO] [stdout] test data::beach::tests::test_all_beaches_have_unique_ids ... ok
[INFO] [stdout] test data::beach::tests::test_all_beaches_have_water_quality_id ... ok
[INFO] [stdout] test cache::manager::tests::test_cached_at_timestamp_is_recorded ... ok
[INFO] [stdout] test cache::manager::tests::test_write_creates_file_in_cache_directory ... ok
[INFO] [stdout] test data::beach::tests::test_all_beaches_returns_12_entries ... ok
[INFO] [stdout] test data::beach::tests::test_each_beach_has_non_zero_coordinates ... ok
[INFO] [stdout] test data::beach::tests::test_beaches_array_has_12_entries ... ok
[INFO] [stdout] test data::beach::tests::test_each_beach_has_valid_vancouver_coordinates ... ok
[INFO] [stdout] test data::beach::tests::test_get_beach_by_id_english_bay ... ok
[INFO] [stdout] test data::beach::tests::test_get_beach_by_id_returns_correct_beach ... ok
[INFO] [stdout] test data::beach::tests::test_get_beach_by_id_returns_none_for_invalid_id ... ok
[INFO] [stdout] test data::beach::tests::test_specific_beach_coordinates ... ok
[INFO] [stdout] test data::tests::test_beach_conditions_creation ... ok
[INFO] [stdout] test cli::tests::test_parse_activity_arg_sailing_aliases ... ok
[INFO] [stdout] test data::tests::test_hourly_forecast_creation ... ok
[INFO] [stdout] test data::tests::test_hourly_forecast_serialization_roundtrip ... ok
[INFO] [stdout] test data::tests::test_tide_state_variants ... ok
[INFO] [stdout] test cli::tests::test_parse_activity_arg_sunbathing_aliases ... ok
[INFO] [stdout] test cli::tests::test_parse_activity_arg_sunset ... ok
[INFO] [stdout] test data::tests::test_beach_creation ... ok
[INFO] [stdout] test data::tests::test_water_quality_creation ... ok
[INFO] [stdout] test data::tests::test_weather_condition_variants ... ok
[INFO] [stdout] test data::tests::test_weather_hourly_default_backwards_compat ... ok
[INFO] [stdout] test data::tests::test_water_status_variants ... ok
[INFO] [stdout] test data::tests::test_weather_with_hourly_serialization_roundtrip ... ok
[INFO] [stdout] test data::tests::test_weather_serialization_roundtrip ... ok
[INFO] [stdout] test data::tests::test_weather_with_hourly_forecasts ... ok
[INFO] [stdout] test cache::manager::tests::test_write_creates_directory_if_missing ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_at_high_tide_time ... ok
[INFO] [stdout] test cache::manager::tests::test_read_returns_data_with_is_expired_true_for_expired_cache ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_invalid_hour ... ok
[INFO] [stdout] test data::tests::test_tide_info_creation ... ok
[INFO] [stdout] test data::tests::test_water_quality_effective_status_keeps_fresh ... ok
[INFO] [stdout] test data::tests::test_water_quality_not_stale_within_48_hours ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_returns_none_for_no_data ... ok
[INFO] [stdout] test data::tides::tests::test_fetch_tides_returns_valid_tide_info ... ok
[INFO] [stdout] test data::tides::tests::test_find_next_high_low ... ok
[INFO] [stdout] test data::tides::tests::test_get_max_tide_height_returns_reasonable_value ... ok
[INFO] [stdout] test data::tides::tests::test_no_data_for_other_months ... ok
[INFO] [stdout] test data::tests::test_water_quality_effective_status_downgrades_when_stale ... ok
[INFO] [stdout] test data::tides::tests::test_parse_tide_predictions_for_january_1 ... ok
[INFO] [stdout] test data::water_quality::tests::test_cache_key_generation ... ok
[INFO] [stdout] test data::water_quality::tests::test_create_unknown_status ... ok
[INFO] [stdout] test data::water_quality::tests::test_default_implementation ... ok
[INFO] [stdout] test data::water_quality::tests::test_ecoli_advisory_threshold ... ok
[INFO] [stdout] test data::water_quality::tests::test_ecoli_closed_threshold ... ok
[INFO] [stdout] test data::tests::test_water_quality_is_stale_after_48_hours ... ok
[INFO] [stdout] test data::water_quality::tests::test_explicit_closure_in_advisory ... ok
[INFO] [stdout] test data::water_quality::tests::test_cache_integration_write_and_read ... ok
[INFO] [stdout] test data::water_quality::tests::test_parse_valid_record ... ok
[INFO] [stdout] test data::water_quality::tests::test_ecoli_safe_threshold ... ok
[INFO] [stdout] test data::water_quality::tests::test_unknown_status_when_no_ecoli_data ... ok
[INFO] [stdout] test data::water_quality::tests::test_stale_data_returns_unknown ... ok
[INFO] [stdout] test data::weather::tests::test_api_hourly_forecast_serialization ... ok
[INFO] [stdout] test data::tides::tests::test_interpolated_height_is_reasonable ... ok
[INFO] [stdout] test data::tides::tests::test_tide_state_falling_between_high_and_low ... ok
[INFO] [stdout] test data::weather::tests::test_degrees_to_direction ... ok
[INFO] [stdout] test data::weather::tests::test_existing_fetch_weather_still_parses_response ... ok
[INFO] [stdout] test data::weather::tests::test_hourly_array_has_expected_length ... ok
[INFO] [stdout] test data::weather::tests::test_hourly_forecast_fields_correctly_extracted ... ok
[INFO] [stdout] test data::weather::tests::test_hourly_forecast_fields_populated ... ok
[INFO] [stdout] test data::weather::tests::test_hourly_with_missing_optional_fields ... ok
[INFO] [stdout] test data::weather::tests::test_hourly_forecasts_filtered_to_today ... ok
[INFO] [stdout] test data::weather::tests::test_parse_datetime_invalid ... ok
[INFO] [stdout] test data::weather::tests::test_parse_datetime ... ok
[INFO] [stdout] test data::weather::tests::test_parse_empty_daily_arrays ... ok
[INFO] [stdout] test data::weather::tests::test_parse_malformed_json ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_at_low_tide_time ... ok
[INFO] [stdout] test data::weather::tests::test_parse_hourly_with_inconsistent_array_lengths ... ok
[INFO] [stdout] test data::tests::test_tide_info_hourly_heights_returns_16_values ... ok
[INFO] [stdout] test data::weather::tests::test_parse_missing_fields ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_all_hours_valid_day ... ok
[INFO] [stdout] test data::weather::tests::test_parse_response_full_with_hourly ... ok
[INFO] [stdout] test data::tides::tests::test_tide_state_rising_between_low_and_high ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_midpoint_between_tides ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_consistency_across_day ... ok
[INFO] [stdout] test data::tests::test_tide_info_hourly_heights_within_range ... ok
[INFO] [stdout] test data::weather::tests::test_parse_response_full_without_hourly ... ok
[INFO] [stdout] test data::weather::tests::test_parse_time ... ok
[INFO] [stdout] test data::weather::tests::test_parse_time_invalid ... ok
[INFO] [stdout] test data::weather::tests::test_weather_client_default ... ok
[INFO] [stdout] test data::weather::tests::test_parse_valid_hourly_response ... ok
[INFO] [stdout] test data::weather::tests::test_parse_valid_response ... ok
[INFO] [stdout] test data::weather::tests::test_weather_data_serialization ... ok
[INFO] [stdout] test data::weather::tests::test_weather_client_with_timezone ... ok
[INFO] [stdout] test cli::tests::test_startup_config_from_cli_plan_only ... ok
[INFO] [stdout] test data::water_quality::tests::test_fetch_returns_cached_on_fresh_cache ... ok
[INFO] [stdout] test data::water_quality::tests::test_url_encoding ... ok
[INFO] [stdout] test data::weather::tests::test_cache_includes_hourly_data_serialization ... ok
[INFO] [stdout] test data::weather::tests::test_weather_code_mapping ... ok
[INFO] [stdout] test cli::tests::test_cli_parse_no_args ... ok
[INFO] [stdout] test data::water_quality::tests::test_parse_record_with_advisory ... ok
[INFO] [stdout] test data::tides::tests::test_cache_returns_cached_when_fresh ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- data::tides::tests::test_cache_returns_cached_when_fresh stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'data::tides::tests::test_cache_returns_cached_when_fresh' (127) panicked at src/data/tides.rs:740:9:
[INFO] [stdout] First fetch should succeed
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5e21df14aeca - std[29689e6404d28ef9]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5e21df14aeca - std[29689e6404d28ef9]::backtrace_rs::backtrace::trace_unsynchronized::<std[29689e6404d28ef9]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5e21df14aeca - std[29689e6404d28ef9]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5e21df14aeca - <<std[29689e6404d28ef9]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[e929cb53b82a81ca]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5e21df1635aa - <core[e929cb53b82a81ca]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5e21df1635aa - core[e929cb53b82a81ca]::fmt::write
[INFO] [stdout]    6:     0x5e21df150972 - std[29689e6404d28ef9]::io::default_write_fmt::<alloc[9d7caffeb3b5d2c6]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/io/mod.rs:621:11
[INFO] [stdout]    7:     0x5e21df150972 - <alloc[9d7caffeb3b5d2c6]::vec::Vec<u8> as std[29689e6404d28ef9]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/io/mod.rs:1976:13
[INFO] [stdout]    8:     0x5e21df126f8f - <std[29689e6404d28ef9]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5e21df126f8f - std[29689e6404d28ef9]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5e21df141d29 - std[29689e6404d28ef9]::panicking::default_hook
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5e21deab40fc - <alloc[9d7caffeb3b5d2c6]::boxed::Box<dyn for<'a, 'b> core[e929cb53b82a81ca]::ops::function::Fn<(&'a std[29689e6404d28ef9]::panic::PanicHookInfo<'b>,), Output = ()> + core[e929cb53b82a81ca]::marker::Send + core[e929cb53b82a81ca]::marker::Sync> as core[e929cb53b82a81ca]::ops::function::Fn<(&std[29689e6404d28ef9]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/alloc/src/boxed.rs:2285:9
[INFO] [stdout]   12:     0x5e21deab40fc - test[a24b3028667022f7]::test_main_inner::<test[a24b3028667022f7]::test_main_static::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/test/src/lib.rs:155:21
[INFO] [stdout]   13:     0x5e21df141fa2 - <alloc[9d7caffeb3b5d2c6]::boxed::Box<dyn for<'a, 'b> core[e929cb53b82a81ca]::ops::function::Fn<(&'a std[29689e6404d28ef9]::panic::PanicHookInfo<'b>,), Output = ()> + core[e929cb53b82a81ca]::marker::Send + core[e929cb53b82a81ca]::marker::Sync> as core[e929cb53b82a81ca]::ops::function::Fn<(&std[29689e6404d28ef9]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/alloc/src/boxed.rs:2285:9
[INFO] [stdout]   14:     0x5e21df141fa2 - std[29689e6404d28ef9]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5e21df12707a - std[29689e6404d28ef9]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x5e21df11bf49 - std[29689e6404d28ef9]::sys::backtrace::__rust_end_short_backtrace::<std[29689e6404d28ef9]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5e21df127f1d - __rustc[3aed6af316653e63]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5e21df163d6c - core[e929cb53b82a81ca]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5e21dea73c12 - vanbeach[48854c08640dbb51]::data::tides::tests::test_cache_returns_cached_when_fresh::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/data/tides.rs:740:9
[INFO] [stdout]   20:     0x5e21dea8ae02 - <core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>> as core[e929cb53b82a81ca]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/core/src/future/future.rs:133:9
[INFO] [stdout]   21:     0x5e21dea8ae7d - <core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>> as core[e929cb53b82a81ca]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/core/src/future/future.rs:133:9
[INFO] [stdout]   22:     0x5e21dea6dc9d - <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:753:70
[INFO] [stdout]   23:     0x5e21dea6db9b - tokio[1d6f27d76f712b9b]::task::coop::with_budget::<core[e929cb53b82a81ca]::task::poll::Poll<()>, <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/task/coop/mod.rs:167:5
[INFO] [stdout]   24:     0x5e21dea6db9b - tokio[1d6f27d76f712b9b]::task::coop::budget::<core[e929cb53b82a81ca]::task::poll::Poll<()>, <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/task/coop/mod.rs:133:5
[INFO] [stdout]   25:     0x5e21dea6db9b - <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:753:25
[INFO] [stdout]   26:     0x5e21dea677a0 - <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::Context>::enter::<core[e929cb53b82a81ca]::task::poll::Poll<()>, <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:442:19
[INFO] [stdout]   27:     0x5e21dea6cead - <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:752:44
[INFO] [stdout]   28:     0x5e21dea6c1a4 - <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}, core[e929cb53b82a81ca]::option::Option<()>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:840:68
[INFO] [stdout]   29:     0x5e21deaa06ab - <tokio[1d6f27d76f712b9b]::runtime::context::scoped::Scoped<tokio[1d6f27d76f712b9b]::runtime::scheduler::Context>>::set::<<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}, core[e929cb53b82a81ca]::option::Option<()>>::{closure#0}, (alloc[9d7caffeb3b5d2c6]::boxed::Box<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::Core>, core[e929cb53b82a81ca]::option::Option<()>)>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   30:     0x5e21dea9d4e9 - tokio[1d6f27d76f712b9b]::runtime::context::set_scheduler::<(alloc[9d7caffeb3b5d2c6]::boxed::Box<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::Core>, core[e929cb53b82a81ca]::option::Option<()>), <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}, core[e929cb53b82a81ca]::option::Option<()>>::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context.rs:176:38
[INFO] [stdout]   31:     0x5e21dea697c2 - <std[29689e6404d28ef9]::thread::local::LocalKey<tokio[1d6f27d76f712b9b]::runtime::context::Context>>::try_with::<tokio[1d6f27d76f712b9b]::runtime::context::set_scheduler<(alloc[9d7caffeb3b5d2c6]::boxed::Box<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::Core>, core[e929cb53b82a81ca]::option::Option<()>), <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}, core[e929cb53b82a81ca]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[9d7caffeb3b5d2c6]::boxed::Box<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::Core>, core[e929cb53b82a81ca]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/thread/local.rs:462:12
[INFO] [stdout]   32:     0x5e21dea6934e - <std[29689e6404d28ef9]::thread::local::LocalKey<tokio[1d6f27d76f712b9b]::runtime::context::Context>>::with::<tokio[1d6f27d76f712b9b]::runtime::context::set_scheduler<(alloc[9d7caffeb3b5d2c6]::boxed::Box<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::Core>, core[e929cb53b82a81ca]::option::Option<()>), <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}, core[e929cb53b82a81ca]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[9d7caffeb3b5d2c6]::boxed::Box<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::Core>, core[e929cb53b82a81ca]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/thread/local.rs:426:20
[INFO] [stdout]   33:     0x5e21dea97fed - tokio[1d6f27d76f712b9b]::runtime::context::set_scheduler::<(alloc[9d7caffeb3b5d2c6]::boxed::Box<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::Core>, core[e929cb53b82a81ca]::option::Option<()>), <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}, core[e929cb53b82a81ca]::option::Option<()>>::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context.rs:176:17
[INFO] [stdout]   34:     0x5e21dea6ab20 - <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>::{closure#0}, core[e929cb53b82a81ca]::option::Option<()>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:840:27
[INFO] [stdout]   35:     0x5e21dea6ae16 - <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[e929cb53b82a81ca]::pin::Pin<&mut core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:740:24
[INFO] [stdout]   36:     0x5e21dea6bc50 - <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:200:33
[INFO] [stdout]   37:     0x5e21dea634a3 - tokio[1d6f27d76f712b9b]::runtime::context::runtime::enter_runtime::<<tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CurrentThread>::block_on<core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>::{closure#0}, ()>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   38:     0x5e21dea672d1 - <tokio[1d6f27d76f712b9b]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/scheduler/current_thread/mod.rs:188:9
[INFO] [stdout]   39:     0x5e21dea30dc4 - <tokio[1d6f27d76f712b9b]::runtime::runtime::Runtime>::block_on_inner::<core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/runtime.rs:368:52
[INFO] [stdout]   40:     0x5e21dea30f8f - <tokio[1d6f27d76f712b9b]::runtime::runtime::Runtime>::block_on::<core[e929cb53b82a81ca]::pin::Pin<&mut dyn core[e929cb53b82a81ca]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.49.0/src/runtime/runtime.rs:342:18
[INFO] [stdout]   41:     0x5e21dea77083 - vanbeach[48854c08640dbb51]::data::tides::tests::test_cache_returns_cached_when_fresh
[INFO] [stdout]                                at /opt/rustwide/workdir/src/data/tides.rs:754:10
[INFO] [stdout]   42:     0x5e21dea73637 - vanbeach[48854c08640dbb51]::data::tides::tests::test_cache_returns_cached_when_fresh::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/data/tides.rs:735:52
[INFO] [stdout]   43:     0x5e21dea4d426 - <vanbeach[48854c08640dbb51]::data::tides::tests::test_cache_returns_cached_when_fresh::{closure#0} as core[e929cb53b82a81ca]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   44:     0x5e21deaa73db - <fn() -> core[e929cb53b82a81ca]::result::Result<(), alloc[9d7caffeb3b5d2c6]::string::String> as core[e929cb53b82a81ca]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   45:     0x5e21deaa73db - test[a24b3028667022f7]::__rust_begin_short_backtrace::<core[e929cb53b82a81ca]::result::Result<(), alloc[9d7caffeb3b5d2c6]::string::String>, fn() -> core[e929cb53b82a81ca]::result::Result<(), alloc[9d7caffeb3b5d2c6]::string::String>>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/test/src/lib.rs:724:18
[INFO] [stdout]   46:     0x5e21deab4bcb - test[a24b3028667022f7]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/test/src/lib.rs:747:74
[INFO] [stdout]   47:     0x5e21deab4bcb - <core[e929cb53b82a81ca]::panic::unwind_safe::AssertUnwindSafe<test[a24b3028667022f7]::run_test_in_process::{closure#0}> as core[e929cb53b82a81ca]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   48:     0x5e21deab4bcb - std[29689e6404d28ef9]::panicking::catch_unwind::do_call::<core[e929cb53b82a81ca]::panic::unwind_safe::AssertUnwindSafe<test[a24b3028667022f7]::run_test_in_process::{closure#0}>, core[e929cb53b82a81ca]::result::Result<(), alloc[9d7caffeb3b5d2c6]::string::String>>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/panicking.rs:581:40
[INFO] [stdout]   49:     0x5e21deab4bcb - std[29689e6404d28ef9]::panicking::catch_unwind::<core[e929cb53b82a81ca]::result::Result<(), alloc[9d7caffeb3b5d2c6]::string::String>, core[e929cb53b82a81ca]::panic::unwind_safe::AssertUnwindSafe<test[a24b3028667022f7]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/panicking.rs:544:19
[INFO] [stdout]   50:     0x5e21deab4bcb - std[29689e6404d28ef9]::panic::catch_unwind::<core[e929cb53b82a81ca]::panic::unwind_safe::AssertUnwindSafe<test[a24b3028667022f7]::run_test_in_process::{closure#0}>, core[e929cb53b82a81ca]::result::Result<(), alloc[9d7caffeb3b5d2c6]::string::String>>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/panic.rs:359:14
[INFO] [stdout]   51:     0x5e21deab4bcb - test[a24b3028667022f7]::run_test_in_process
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/test/src/lib.rs:747:27
[INFO] [stdout]   52:     0x5e21deab4bcb - test[a24b3028667022f7]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/test/src/lib.rs:668:43
[INFO] [stdout]   53:     0x5e21deaae2e4 - test[a24b3028667022f7]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/test/src/lib.rs:698:41
[INFO] [stdout]   54:     0x5e21deaae2e4 - std[29689e6404d28ef9]::sys::backtrace::__rust_begin_short_backtrace::<test[a24b3028667022f7]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   55:     0x5e21deab77d2 - std[29689e6404d28ef9]::thread::lifecycle::spawn_unchecked::<test[a24b3028667022f7]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/thread/lifecycle.rs:70:13
[INFO] [stdout]   56:     0x5e21deab77d2 - <core[e929cb53b82a81ca]::panic::unwind_safe::AssertUnwindSafe<std[29689e6404d28ef9]::thread::lifecycle::spawn_unchecked<test[a24b3028667022f7]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[e929cb53b82a81ca]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   57:     0x5e21deab77d2 - std[29689e6404d28ef9]::panicking::catch_unwind::do_call::<core[e929cb53b82a81ca]::panic::unwind_safe::AssertUnwindSafe<std[29689e6404d28ef9]::thread::lifecycle::spawn_unchecked<test[a24b3028667022f7]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/panicking.rs:581:40
[INFO] [stdout]   58:     0x5e21deab77d2 - std[29689e6404d28ef9]::panicking::catch_unwind::<(), core[e929cb53b82a81ca]::panic::unwind_safe::AssertUnwindSafe<std[29689e6404d28ef9]::thread::lifecycle::spawn_unchecked<test[a24b3028667022f7]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/panicking.rs:544:19
[INFO] [stdout]   59:     0x5e21deab77d2 - std[29689e6404d28ef9]::panic::catch_unwind::<core[e929cb53b82a81ca]::panic::unwind_safe::AssertUnwindSafe<std[29689e6404d28ef9]::thread::lifecycle::spawn_unchecked<test[a24b3028667022f7]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/panic.rs:359:14
[INFO] [stdout]   60:     0x5e21deab77d2 - std[29689e6404d28ef9]::thread::lifecycle::spawn_unchecked::<test[a24b3028667022f7]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/thread/lifecycle.rs:68:26
[INFO] [stdout]   61:     0x5e21deab77d2 - <std[29689e6404d28ef9]::thread::lifecycle::spawn_unchecked<test[a24b3028667022f7]::run_test::{closure#1}, ()>::{closure#1} as core[e929cb53b82a81ca]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   62:     0x5e21df149dbf - <alloc[9d7caffeb3b5d2c6]::boxed::Box<dyn core[e929cb53b82a81ca]::ops::function::FnOnce<(), Output = ()> + core[e929cb53b82a81ca]::marker::Send> as core[e929cb53b82a81ca]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/alloc/src/boxed.rs:2271:9
[INFO] [stdout]   63:     0x5e21df149dbf - <std[29689e6404d28ef9]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/ec6f9a5b4413f74386267ef8efc93712c2ce6db6/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   64:     0x7db92cde0aa4 - <unknown>
[INFO] [stdout]   65:     0x7db92ce6da64 - clone
[INFO] [stdout]   66:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     data::tides::tests::test_cache_returns_cached_when_fresh
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 163 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.22s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "78a8893b887ae6ba0f9854dc8e2c6cf7c43b9549364de00f47aea835f9e18514", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "78a8893b887ae6ba0f9854dc8e2c6cf7c43b9549364de00f47aea835f9e18514", kill_on_drop: false }`
[INFO] [stdout] 78a8893b887ae6ba0f9854dc8e2c6cf7c43b9549364de00f47aea835f9e18514
