[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 try#33835004928d3bf65db4d4712e1330766263b0bd 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-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc2/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-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Zxela/beach-cli on toolchain 33835004928d3bf65db4d4712e1330766263b0bd
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "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" "+33835004928d3bf65db4d4712e1330766263b0bd" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7c9b20875675c17ac9a6bdd8a4edf24a34d7cf4795f772b66e8ca3d57bc1f2fe
[INFO] running `Command { std: "docker" "start" "-a" "7c9b20875675c17ac9a6bdd8a4edf24a34d7cf4795f772b66e8ca3d57bc1f2fe", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7c9b20875675c17ac9a6bdd8a4edf24a34d7cf4795f772b66e8ca3d57bc1f2fe", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7c9b20875675c17ac9a6bdd8a4edf24a34d7cf4795f772b66e8ca3d57bc1f2fe", kill_on_drop: false }`
[INFO] [stdout] 7c9b20875675c17ac9a6bdd8a4edf24a34d7cf4795f772b66e8ca3d57bc1f2fe
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d5071fc4dce37fb6c3a86e825b2ff8950395f037228159ffe05a9dcc67cfc203
[INFO] running `Command { std: "docker" "start" "-a" "d5071fc4dce37fb6c3a86e825b2ff8950395f037228159ffe05a9dcc67cfc203", 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 linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling instability v0.3.11
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling indoc v2.0.7
[INFO] [stderr]    Compiling option-ext v0.2.0
[INFO] [stderr]    Compiling clap_builder v4.5.54
[INFO] [stderr]    Compiling lru v0.12.5
[INFO] [stderr]    Compiling iana-time-zone v0.1.64
[INFO] [stderr]    Compiling cassowary v0.3.0
[INFO] [stderr]    Compiling cc v1.2.54
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling compact_str v0.8.1
[INFO] [stderr]    Compiling dirs-sys v0.4.1
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling directories v5.0.1
[INFO] [stderr]    Compiling tracing v0.1.44
[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 synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.23.0
[INFO] [stderr]    Compiling rustls v0.23.36
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[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 clap_derive v4.5.49
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[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 yoke v0.8.1
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling rustls-webpki v0.103.9
[INFO] [stderr]    Compiling clap v4.5.54
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling ratatui v0.28.1
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling chrono v0.4.43
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling 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 tower v0.5.3
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[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 37.12s
[INFO] running `Command { std: "docker" "inspect" "d5071fc4dce37fb6c3a86e825b2ff8950395f037228159ffe05a9dcc67cfc203", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d5071fc4dce37fb6c3a86e825b2ff8950395f037228159ffe05a9dcc67cfc203", kill_on_drop: false }`
[INFO] [stdout] d5071fc4dce37fb6c3a86e825b2ff8950395f037228159ffe05a9dcc67cfc203
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b589de792fb26ded40af5542b3270d2df589ed36c928062ad0de75a1d9857c9a
[INFO] running `Command { std: "docker" "start" "-a" "b589de792fb26ded40af5542b3270d2df589ed36c928062ad0de75a1d9857c9a", 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 7.81s
[INFO] running `Command { std: "docker" "inspect" "b589de792fb26ded40af5542b3270d2df589ed36c928062ad0de75a1d9857c9a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b589de792fb26ded40af5542b3270d2df589ed36c928062ad0de75a1d9857c9a", kill_on_drop: false }`
[INFO] [stdout] b589de792fb26ded40af5542b3270d2df589ed36c928062ad0de75a1d9857c9a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 227dc4a3e462d331d343a19fbcccd34e50b09fe02cc2e3c2f67eae889f0932a9
[INFO] running `Command { std: "docker" "start" "-a" "227dc4a3e462d331d343a19fbcccd34e50b09fe02cc2e3c2f67eae889f0932a9", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.38s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/vanbeach-599dbad10e0d7194)
[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_sailing ... ok
[INFO] [stdout] test activities::tests::test_activity_label_sunset ... ok
[INFO] [stdout] test activities::tests::test_all_activities_blocked_during_snow ... ok
[INFO] [stdout] test activities::tests::test_all_activities_blocked_during_thunderstorm ... ok
[INFO] [stdout] test activities::tests::test_activity_label_swimming ... ok
[INFO] [stdout] test activities::tests::test_from_str_invalid_input ... ok
[INFO] [stdout] test activities::tests::test_from_str_sunset ... ok
[INFO] [stdout] test activities::tests::test_from_str_swimming_aliases ... ok
[INFO] [stdout] test activities::tests::test_from_str_peace_aliases ... ok
[INFO] [stdout] test activities::tests::test_from_str_with_whitespace ... ok
[INFO] [stdout] test activities::tests::test_full_score_time_slot_produces_score_in_0_100_range ... ok
[INFO] [stdout] test activities::tests::test_get_profile_returns_correct_activity ... 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_sailing_blocked_when_dangerous_wind ... ok
[INFO] [stdout] test activities::tests::test_sailing_not_blocked_with_moderate_wind ... ok
[INFO] [stdout] test activities::tests::test_from_str_sunbathing_aliases ... ok
[INFO] [stdout] test activities::tests::test_sailing_profile_rewards_high_wind ... ok
[INFO] [stdout] test activities::tests::test_score_crowd_inverts_crowd_level ... ok
[INFO] [stdout] test activities::tests::test_score_factors_are_all_in_range ... ok
[INFO] [stdout] test activities::tests::test_score_temperature_returns_1_when_in_ideal_range ... ok
[INFO] [stdout] test activities::tests::test_score_tide_for_high_preference ... ok
[INFO] [stdout] test activities::tests::test_score_tide_for_mid_preference ... ok
[INFO] [stdout] test activities::tests::test_score_time_slot_sets_blocked_false ... ok
[INFO] [stdout] test activities::tests::test_score_wind_handles_zero_min_range ... ok
[INFO] [stdout] test activities::tests::test_score_wind_below_min_for_sailing ... ok
[INFO] [stdout] test activities::tests::test_score_wind_returns_1_when_in_ideal_range ... 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_sanity_gate_block_reason_contains_temperature ... ok
[INFO] [stdout] test activities::tests::test_sanity_gate_block_reason_contains_wind_speed ... ok
[INFO] [stdout] test activities::tests::test_swimming_blocked_with_rain_shower_codes ... 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_peace_time_scorer_peaks_at_early_morning ... ok
[INFO] [stdout] test cache::manager::tests::test_cache_survives_serialization_roundtrip ... ok
[INFO] [stdout] test cache::manager::tests::test_new_creates_xdg_compliant_path ... ok
[INFO] [stdout] test activities::tests::test_from_str_sailing_aliases ... ok
[INFO] [stdout] test cache::manager::tests::test_overwrite_existing_cache ... ok
[INFO] [stdout] test activities::tests::test_score_temperature_scales_between_ideal_and_boundary ... 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_cached_at_timestamp_is_recorded ... ok
[INFO] [stdout] test activities::tests::test_swimming_profile_penalizes_unsafe_water_heavily ... ok
[INFO] [stdout] test activities::tests::test_score_uv_for_high_preference ... ok
[INFO] [stdout] test activities::tests::test_sunbathing_blocked_when_raining ... ok
[INFO] [stdout] test cache::manager::tests::test_read_returns_none_for_missing_key ... ok
[INFO] [stdout] test cache::manager::tests::test_write_creates_file_in_cache_directory ... ok
[INFO] [stdout] test cache::manager::tests::test_write_creates_directory_if_missing ... ok
[INFO] [stdout] test cli::tests::test_cli_parse_no_args ... ok
[INFO] [stdout] test cli::tests::test_cli_parse_plan_only ... ok
[INFO] [stdout] test cli::tests::test_cli_parse_plan_with_activity ... 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_parse_activity_arg_sailing_aliases ... 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 cli::tests::test_parse_activity_arg_swimming_aliases ... 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 cli::tests::test_startup_config_from_cli_no_plan ... ok
[INFO] [stdout] test cli::tests::test_startup_config_from_cli_plan_only ... ok
[INFO] [stdout] test data::beach::tests::test_all_beaches_have_unique_ids ... ok
[INFO] [stdout] test cli::tests::test_startup_config_from_cli_plan_with_activity ... ok
[INFO] [stdout] test data::beach::tests::test_all_beaches_have_water_quality_id ... ok
[INFO] [stdout] test data::beach::tests::test_all_beaches_returns_12_entries ... ok
[INFO] [stdout] test data::beach::tests::test_beaches_array_has_12_entries ... ok
[INFO] [stdout] test data::beach::tests::test_each_beach_has_non_zero_coordinates ... 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 data::tests::test_beach_creation ... 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_water_quality_creation ... ok
[INFO] [stdout] test data::tests::test_tide_state_variants ... ok
[INFO] [stdout] test cache::manager::tests::test_read_returns_data_with_is_expired_true_for_expired_cache ... ok
[INFO] [stdout] test data::tests::test_water_quality_effective_status_downgrades_when_stale ... ok
[INFO] [stdout] test data::tests::test_water_quality_effective_status_keeps_fresh ... ok
[INFO] [stdout] test data::tests::test_tide_info_creation ... ok
[INFO] [stdout] test data::tests::test_water_quality_is_stale_after_48_hours ... ok
[INFO] [stdout] test data::tests::test_water_status_variants ... ok
[INFO] [stdout] test data::tests::test_water_quality_not_stale_within_48_hours ... 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_weather_with_hourly_forecasts ... ok
[INFO] [stdout] test data::tests::test_weather_serialization_roundtrip ... ok
[INFO] [stdout] test data::tests::test_weather_with_hourly_serialization_roundtrip ... 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_height_at_hour_at_high_tide_time ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_invalid_hour ... 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_uv_for_low_preference ... ok
[INFO] [stdout] test activities::tests::test_score_temperature_returns_0_when_far_outside_range ... 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_get_max_tide_height_returns_reasonable_value ... ok
[INFO] [stdout] test activities::tests::test_activity_label_sunbathing ... ok
[INFO] [stdout] test data::tides::tests::test_parse_tide_predictions_for_january_1 ... ok
[INFO] [stdout] test data::tides::tests::test_no_data_for_other_months ... ok
[INFO] [stdout] test data::water_quality::tests::test_cache_integration_write_and_read ... 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::water_quality::tests::test_ecoli_safe_threshold ... ok
[INFO] [stdout] test data::water_quality::tests::test_explicit_closure_in_advisory ... ok
[INFO] [stdout] test data::water_quality::tests::test_fetch_returns_cached_on_fresh_cache ... ok
[INFO] [stdout] test data::water_quality::tests::test_parse_record_with_advisory ... ok
[INFO] [stdout] test data::water_quality::tests::test_parse_valid_record ... ok
[INFO] [stdout] test data::tides::tests::test_tide_state_falling_between_high_and_low ... ok
[INFO] [stdout] test data::tides::tests::test_interpolated_height_is_reasonable ... ok
[INFO] [stdout] test data::water_quality::tests::test_unknown_status_when_no_ecoli_data ... ok
[INFO] [stdout] test data::water_quality::tests::test_url_encoding ... ok
[INFO] [stdout] test data::weather::tests::test_api_hourly_forecast_serialization ... ok
[INFO] [stdout] test data::weather::tests::test_cache_includes_hourly_data_serialization ... 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_forecasts_filtered_to_today ... ok
[INFO] [stdout] test data::weather::tests::test_hourly_forecast_fields_populated ... ok
[INFO] [stdout] test data::weather::tests::test_parse_datetime ... ok
[INFO] [stdout] test data::weather::tests::test_parse_datetime_invalid ... ok
[INFO] [stdout] test data::weather::tests::test_hourly_with_missing_optional_fields ... ok
[INFO] [stdout] test data::weather::tests::test_parse_empty_daily_arrays ... ok
[INFO] [stdout] test data::weather::tests::test_parse_hourly_with_inconsistent_array_lengths ... ok
[INFO] [stdout] test data::weather::tests::test_parse_missing_fields ... ok
[INFO] [stdout] test data::weather::tests::test_parse_response_full_with_hourly ... 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_parse_valid_hourly_response ... ok
[INFO] [stdout] test data::weather::tests::test_parse_valid_response ... ok
[INFO] [stdout] test data::weather::tests::test_weather_client_default ... ok
[INFO] [stdout] test data::weather::tests::test_weather_client_with_timezone ... ok
[INFO] [stdout] test data::weather::tests::test_weather_code_mapping ... ok
[INFO] [stdout] test data::weather::tests::test_weather_data_serialization ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_midpoint_between_tides ... ok
[INFO] [stdout] test data::tests::test_tide_info_hourly_heights_returns_16_values ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_at_low_tide_time ... ok
[INFO] [stdout] test data::tides::tests::test_tide_state_rising_between_low_and_high ... ok
[INFO] [stdout] test data::tests::test_tide_info_hourly_heights_within_range ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_all_hours_valid_day ... ok
[INFO] [stdout] test data::tides::tests::test_get_height_at_hour_consistency_across_day ... ok
[INFO] [stdout] test data::weather::tests::test_parse_malformed_json ... ok
[INFO] [stdout] test activities::tests::test_activity_label_peace ... 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 data::water_quality::tests::test_stale_data_returns_unknown ... ok
[INFO] [stdout] test activities::tests::test_sunset_activity_not_blocked_by_cold_or_wind ... ok
[INFO] [stdout] test activities::tests::test_swimming_not_blocked_when_conditions_good ... ok
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[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' (126) panicked at src/data/tides.rs:740:9:
[INFO] [stdout] First fetch should succeed
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5aa0b5f20dfa - std[ec419fa8110287d5]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5aa0b5f20dfa - std[ec419fa8110287d5]::backtrace_rs::backtrace::trace_unsynchronized::<std[ec419fa8110287d5]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5aa0b5f20dfa - std[ec419fa8110287d5]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5aa0b5f20dfa - <<std[ec419fa8110287d5]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[35159d6ffb30e017]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5aa0b5f394da - <core[35159d6ffb30e017]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5aa0b5f394da - core[35159d6ffb30e017]::fmt::write
[INFO] [stdout]    6:     0x5aa0b5f268a2 - std[ec419fa8110287d5]::io::default_write_fmt::<alloc[a8a7aba520129d98]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/io/mod.rs:621:11
[INFO] [stdout]    7:     0x5aa0b5f268a2 - <alloc[a8a7aba520129d98]::vec::Vec<u8> as std[ec419fa8110287d5]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/io/mod.rs:1976:13
[INFO] [stdout]    8:     0x5aa0b5efcebf - <std[ec419fa8110287d5]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5aa0b5efcebf - std[ec419fa8110287d5]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5aa0b5f17ca9 - std[ec419fa8110287d5]::panicking::default_hook
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5aa0b588a6bc - <alloc[a8a7aba520129d98]::boxed::Box<dyn for<'a, 'b> core[35159d6ffb30e017]::ops::function::Fn<(&'a std[ec419fa8110287d5]::panic::PanicHookInfo<'b>,), Output = ()> + core[35159d6ffb30e017]::marker::Sync + core[35159d6ffb30e017]::marker::Send> as core[35159d6ffb30e017]::ops::function::Fn<(&std[ec419fa8110287d5]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2285:9
[INFO] [stdout]   12:     0x5aa0b588a6bc - test[a8007afcd3effadc]::test_main_inner::<test[a8007afcd3effadc]::test_main_static::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:155:21
[INFO] [stdout]   13:     0x5aa0b5f17f22 - <alloc[a8a7aba520129d98]::boxed::Box<dyn for<'a, 'b> core[35159d6ffb30e017]::ops::function::Fn<(&'a std[ec419fa8110287d5]::panic::PanicHookInfo<'b>,), Output = ()> + core[35159d6ffb30e017]::marker::Sync + core[35159d6ffb30e017]::marker::Send> as core[35159d6ffb30e017]::ops::function::Fn<(&std[ec419fa8110287d5]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2285:9
[INFO] [stdout]   14:     0x5aa0b5f17f22 - std[ec419fa8110287d5]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5aa0b5efcfaa - std[ec419fa8110287d5]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x5aa0b5ef4609 - std[ec419fa8110287d5]::sys::backtrace::__rust_end_short_backtrace::<std[ec419fa8110287d5]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5aa0b5efde4d - __rustc[cfb3622dd870db93]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5aa0b5f39c9c - core[35159d6ffb30e017]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5aa0b583a122 - vanbeach[3d35b3eb96c7db03]::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:     0x5aa0b58511d2 - <core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>> as core[35159d6ffb30e017]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/future/future.rs:133:9
[INFO] [stdout]   21:     0x5aa0b585124d - <core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>> as core[35159d6ffb30e017]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/future/future.rs:133:9
[INFO] [stdout]   22:     0x5aa0b5857fcd - <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b5857ecb - tokio[7abc6380076ff900]::task::coop::with_budget::<core[35159d6ffb30e017]::task::poll::Poll<()>, <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b5857ecb - tokio[7abc6380076ff900]::task::coop::budget::<core[35159d6ffb30e017]::task::poll::Poll<()>, <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b5857ecb - <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b5851940 - <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::Context>::enter::<core[35159d6ffb30e017]::task::poll::Poll<()>, <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b58571dd - <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b58564d4 - <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::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:     0x5aa0b586ebab - <tokio[7abc6380076ff900]::runtime::context::scoped::Scoped<tokio[7abc6380076ff900]::runtime::scheduler::Context>>::set::<<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::option::Option<()>>::{closure#0}, (alloc[a8a7aba520129d98]::boxed::Box<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::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:     0x5aa0b586b969 - tokio[7abc6380076ff900]::runtime::context::set_scheduler::<(alloc[a8a7aba520129d98]::boxed::Box<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>), <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::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:     0x5aa0b5853962 - <std[ec419fa8110287d5]::thread::local::LocalKey<tokio[7abc6380076ff900]::runtime::context::Context>>::try_with::<tokio[7abc6380076ff900]::runtime::context::set_scheduler<(alloc[a8a7aba520129d98]::boxed::Box<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>), <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[a8a7aba520129d98]::boxed::Box<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/local.rs:462:12
[INFO] [stdout]   32:     0x5aa0b58534ee - <std[ec419fa8110287d5]::thread::local::LocalKey<tokio[7abc6380076ff900]::runtime::context::Context>>::with::<tokio[7abc6380076ff900]::runtime::context::set_scheduler<(alloc[a8a7aba520129d98]::boxed::Box<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>), <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[a8a7aba520129d98]::boxed::Box<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/local.rs:426:20
[INFO] [stdout]   33:     0x5aa0b586646d - tokio[7abc6380076ff900]::runtime::context::set_scheduler::<(alloc[a8a7aba520129d98]::boxed::Box<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::Core>, core[35159d6ffb30e017]::option::Option<()>), <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::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:     0x5aa0b5854cc0 - <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::future::future::Future<Output = ()>>>>::{closure#0}, core[35159d6ffb30e017]::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:     0x5aa0b5854fb6 - <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b5855f80 - <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b5879893 - tokio[7abc6380076ff900]::runtime::context::runtime::enter_runtime::<<tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CurrentThread>::block_on<core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b5851471 - <tokio[7abc6380076ff900]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b5807384 - <tokio[7abc6380076ff900]::runtime::runtime::Runtime>::block_on_inner::<core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b580754f - <tokio[7abc6380076ff900]::runtime::runtime::Runtime>::block_on::<core[35159d6ffb30e017]::pin::Pin<&mut dyn core[35159d6ffb30e017]::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:     0x5aa0b583d273 - vanbeach[3d35b3eb96c7db03]::data::tides::tests::test_cache_returns_cached_when_fresh
[INFO] [stdout]                                at /opt/rustwide/workdir/src/data/tides.rs:754:10
[INFO] [stdout]   42:     0x5aa0b5839b47 - vanbeach[3d35b3eb96c7db03]::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:     0x5aa0b5823376 - <vanbeach[3d35b3eb96c7db03]::data::tides::tests::test_cache_returns_cached_when_fresh::{closure#0} as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   44:     0x5aa0b587d99b - <fn() -> core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   45:     0x5aa0b587d99b - test[a8007afcd3effadc]::__rust_begin_short_backtrace::<core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>, fn() -> core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:724:18
[INFO] [stdout]   46:     0x5aa0b588b18b - test[a8007afcd3effadc]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:74
[INFO] [stdout]   47:     0x5aa0b588b18b - <core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   48:     0x5aa0b588b18b - std[ec419fa8110287d5]::panicking::catch_unwind::do_call::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}>, core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   49:     0x5aa0b588b18b - std[ec419fa8110287d5]::panicking::catch_unwind::<core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>, core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   50:     0x5aa0b588b18b - std[ec419fa8110287d5]::panic::catch_unwind::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}>, core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   51:     0x5aa0b588b18b - test[a8007afcd3effadc]::run_test_in_process
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:27
[INFO] [stdout]   52:     0x5aa0b588b18b - test[a8007afcd3effadc]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:668:43
[INFO] [stdout]   53:     0x5aa0b5885b64 - test[a8007afcd3effadc]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:698:41
[INFO] [stdout]   54:     0x5aa0b5885b64 - std[ec419fa8110287d5]::sys::backtrace::__rust_begin_short_backtrace::<test[a8007afcd3effadc]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   55:     0x5aa0b588dd92 - std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked::<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:70:13
[INFO] [stdout]   56:     0x5aa0b588dd92 - <core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   57:     0x5aa0b588dd92 - std[ec419fa8110287d5]::panicking::catch_unwind::do_call::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   58:     0x5aa0b588dd92 - std[ec419fa8110287d5]::panicking::catch_unwind::<(), core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   59:     0x5aa0b588dd92 - std[ec419fa8110287d5]::panic::catch_unwind::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   60:     0x5aa0b588dd92 - std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked::<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:68:26
[INFO] [stdout]   61:     0x5aa0b588dd92 - <std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1} as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   62:     0x5aa0b5f1fcef - <alloc[a8a7aba520129d98]::boxed::Box<dyn core[35159d6ffb30e017]::ops::function::FnOnce<(), Output = ()> + core[35159d6ffb30e017]::marker::Send> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2271:9
[INFO] [stdout]   63:     0x5aa0b5f1fcef - <std[ec419fa8110287d5]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   64:     0x7b7797760aa4 - <unknown>
[INFO] [stdout]   65:     0x7b77977eda64 - 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.09s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "227dc4a3e462d331d343a19fbcccd34e50b09fe02cc2e3c2f67eae889f0932a9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "227dc4a3e462d331d343a19fbcccd34e50b09fe02cc2e3c2f67eae889f0932a9", kill_on_drop: false }`
[INFO] [stdout] 227dc4a3e462d331d343a19fbcccd34e50b09fe02cc2e3c2f67eae889f0932a9
