[INFO] cloning repository https://github.com/nikosalonen/liiga_teletext
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/nikosalonen/liiga_teletext" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnikosalonen%2Fliiga_teletext", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnikosalonen%2Fliiga_teletext'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] bfe0c7fa55fc41a9744553db5b1cdddf30c48bad
[INFO] testing nikosalonen/liiga_teletext against try#bd7d74411512a3dd3b35d2f699c51dd2557c7e7e+cargoflags=-Zbuild-dir-new-layout for pr-149852-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnikosalonen%2Fliiga_teletext" "/workspace/builds/worker-3-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/nikosalonen/liiga_teletext
[INFO] finished tweaking git repo https://github.com/nikosalonen/liiga_teletext
[INFO] tweaked toml for git repo https://github.com/nikosalonen/liiga_teletext written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/nikosalonen/liiga_teletext on toolchain bd7d74411512a3dd3b35d2f699c51dd2557c7e7e
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/nikosalonen/liiga_teletext 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" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 1db62e08ad8715cc87b1aa6053f7d22247617bd141e0f814113bd02e349b63d7
[INFO] running `Command { std: "docker" "start" "-a" "1db62e08ad8715cc87b1aa6053f7d22247617bd141e0f814113bd02e349b63d7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "1db62e08ad8715cc87b1aa6053f7d22247617bd141e0f814113bd02e349b63d7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1db62e08ad8715cc87b1aa6053f7d22247617bd141e0f814113bd02e349b63d7", kill_on_drop: false }`
[INFO] [stdout] 1db62e08ad8715cc87b1aa6053f7d22247617bd141e0f814113bd02e349b63d7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "build" "--frozen" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] d55709515dfd8c5607f4a0f23c794df9a8930e9fe1b4aab80410dd676f4f30c2
[INFO] running `Command { std: "docker" "start" "-a" "d55709515dfd8c5607f4a0f23c794df9a8930e9fe1b4aab80410dd676f4f30c2", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.105
[INFO] [stderr]    Compiling quote v1.0.43
[INFO] [stderr]    Compiling libc v0.2.180
[INFO] [stderr]    Compiling log v0.4.29
[INFO] [stderr]    Compiling itoa v1.0.17
[INFO] [stderr]    Compiling find-msvc-tools v0.1.7
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling foldhash v0.2.0
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling http v1.4.0
[INFO] [stderr]    Compiling cc v1.2.52
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling zmij v1.0.14
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling regex-syntax v0.8.8
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling convert_case v0.10.0
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling sharded-slab v0.1.7
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling socket2 v0.6.1
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling time-core v0.1.7
[INFO] [stderr]    Compiling nu-ansi-term v0.50.3
[INFO] [stderr]    Compiling ryu v1.0.22
[INFO] [stderr]    Compiling iri-string v0.7.10
[INFO] [stderr]    Compiling clap_lex v0.7.7
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling clap_builder v4.5.54
[INFO] [stderr]    Compiling time v0.3.45
[INFO] [stderr]    Compiling dirs-sys v0.5.0
[INFO] [stderr]    Compiling signal-hook-mio v0.2.5
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling serde_spanned v1.0.4
[INFO] [stderr]    Compiling toml_parser v1.0.6+spec-1.1.0
[INFO] [stderr]    Compiling toml_datetime v0.7.5+spec-1.1.0
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling liiga_teletext v0.18.0 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling toml_writer v1.0.6+spec-1.1.0
[INFO] [stderr]    Compiling chrono v0.4.43
[INFO] [stderr]    Compiling dirs v6.0.0
[INFO] [stderr]    Compiling toml v0.9.11+spec-1.1.0
[INFO] [stderr]    Compiling lru v0.16.3
[INFO] [stderr]    Compiling semver v1.0.27
[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 tokio-macros v2.6.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling derive_more-impl v2.1.1
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling derive_more v2.1.1
[INFO] [stderr]    Compiling tracing-subscriber v0.3.22
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]    Compiling crossterm v0.29.0
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling clap v4.5.54
[INFO] [stderr]    Compiling tracing-appender v0.2.4
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.19
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 26s
[INFO] running `Command { std: "docker" "inspect" "d55709515dfd8c5607f4a0f23c794df9a8930e9fe1b4aab80410dd676f4f30c2", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d55709515dfd8c5607f4a0f23c794df9a8930e9fe1b4aab80410dd676f4f30c2", kill_on_drop: false }`
[INFO] [stdout] d55709515dfd8c5607f4a0f23c794df9a8930e9fe1b4aab80410dd676f4f30c2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "--no-run" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] 50715424f19a01285c3e650368a55f179276d7ce7975b83799d0c4361b963ce6
[INFO] running `Command { std: "docker" "start" "-a" "50715424f19a01285c3e650368a55f179276d7ce7975b83799d0c4361b963ce6", kill_on_drop: false }`
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling num_cpus v1.17.0
[INFO] [stderr]    Compiling sdd v3.0.10
[INFO] [stderr]    Compiling deadpool-runtime v0.1.4
[INFO] [stderr]    Compiling assert-json-diff v2.0.2
[INFO] [stderr]    Compiling scc v2.4.0
[INFO] [stderr]    Compiling serial_test_derive v3.3.1
[INFO] [stderr]    Compiling deadpool v0.12.3
[INFO] [stderr]    Compiling hyper-util v0.1.19
[INFO] [stderr]    Compiling serial_test v3.3.1
[INFO] [stderr]    Compiling crossterm v0.29.0
[INFO] [stderr]    Compiling tempfile v3.24.0
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling tracing-subscriber v0.3.22
[INFO] [stderr]    Compiling wiremock v0.6.5
[INFO] [stderr]    Compiling tracing-appender v0.2.4
[INFO] [stderr]    Compiling liiga_teletext v0.18.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1m 38s
[INFO] running `Command { std: "docker" "inspect" "50715424f19a01285c3e650368a55f179276d7ce7975b83799d0c4361b963ce6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "50715424f19a01285c3e650368a55f179276d7ce7975b83799d0c4361b963ce6", kill_on_drop: false }`
[INFO] [stdout] 50715424f19a01285c3e650368a55f179276d7ce7975b83799d0c4361b963ce6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] aba94f43d373e1c4158ab5b5a32ba828cb7999f2bb36b0b7d8411d6637c415e4
[INFO] running `Command { std: "docker" "start" "-a" "aba94f43d373e1c4158ab5b5a32ba828cb7999f2bb36b0b7d8411d6637c415e4", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.40s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/build/liiga_teletext/79a3fcde82c1f7be/deps/liiga_teletext-79a3fcde82c1f7be)
[INFO] [stdout] 
[INFO] [stdout] running 376 tests
[INFO] [stdout] test config::tests::test_config_default_log_file_path ... ok
[INFO] [stdout] test config::tests::test_config_load_invalid_toml ... ok
[INFO] [stdout] test config::tests::test_config_load_from_nonexistent_path ... ok
[INFO] [stdout] test config::tests::test_config_malformed_toml_file ... ok
[INFO] [stdout] test config::tests::test_config_empty_file ... ok
[INFO] [stdout] test config::tests::test_config_missing_required_field ... ok
[INFO] [stdout] test config::tests::test_config_display_with_existing_config ... ok
[INFO] [stdout] test config::tests::test_config_load_existing_file ... ok
[INFO] [stdout] 
[INFO] [stdout] test config::tests::test_config_save_creates_nested_directories ... ok
[INFO] [stdout] test config::tests::test_config_path_generation ... ok
[INFO] [stdout] [38;5;51m╔════════════════════════════════════════════════╗
[INFO] [stdout] [38;5;231m║            API DOMAIN CONFIGURATION            ║
[INFO] [stdout] [38;5;51m╚════════════════════════════════════════════════╝
[INFO] [stdout] [0m[38;5;231m  Enter the API domain URL for fetching game data.
[INFO] [stdout] [0m[38;5;231m  Format: [0m[38;5;46mhttps://example.com/api/v2
[INFO] [stdout] [0m[38;5;51m  • [0m[38;5;231mInclude https:// prefix (or it will be added)
[INFO] [stdout] [0m[38;5;51m  • [0m[38;5;231mDo NOT include trailing slash
[INFO] [stdout] [0m[38;5;231m  Press [0m[38;5;226mEnter[0m[38;5;231m without input to cancel.
[INFO] [stdout] [0mtest config::tests::test_config_load_without_log_file_path ... ok
[INFO] [stdout] test config::tests::test_config_save_new_file ... ok
[INFO] [stdout] [38;5;51m  ────────────────────────────────────────────────
[INFO] [stdout] [0m[38;5;51m  API domain: [0mtest config::tests::test_config_serialization_with_special_characters ... ok
[INFO] [stdout] test config::tests::test_config_save_and_load_roundtrip ... ok
[INFO] [stdout] [38;5;226m  Configuration cancelled.
[INFO] [stdout] [0mtest config::tests::test_config_validation_invalid_configs ... ok
[INFO] [stdout] test config::tests::test_config_validation_valid_configs ... ok
[INFO] [stdout] test config::tests::test_config_save_with_http_prefix ... ok
[INFO] [stdout] test config::tests::test_config_save_to_readonly_directory ... ok
[INFO] [stdout] test config::tests::test_config_without_log_file_path_serialization ... ok
[INFO] [stdout] test config::tests::test_config_save_without_https_prefix ... ok
[INFO] [stdout] test config::tests::test_get_log_dir_path ... ok
[INFO] [stdout] test config::tests::test_log_dir_path_generation ... ok
[INFO] [stdout] test constants::tests::test_env_var_names_are_not_empty ... ok
[INFO] [stdout] test config::tests::test_environment_variable_override ... ok
[INFO] [stdout] test constants::tests::test_polling_constants_are_reasonable ... ok
[INFO] [stdout] test constants::tests::test_retry_constants_are_reasonable ... ok
[INFO] [stdout] test constants::tests::test_tournament_constants_are_valid_months ... ok
[INFO] [stdout] test constants::tests::test_ttl_constants_are_reasonable ... ok
[INFO] [stdout] test config::tests::test_config_with_extra_fields ... ok
[INFO] [stdout] test constants::tests::test_ui_constants_are_reasonable ... ok
[INFO] [stdout] test constants::tests::test_validation_constants_are_reasonable ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_build_tournament_list_preseason ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_build_tournament_list_regular_season ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_build_tournament_list_playoffs ... ok
[INFO] [stdout] 
[INFO] [stdout] [38;5;51m╔════════════════════════════════════════════════╗
[INFO] [stdout] [38;5;231m║             CURRENT CONFIGURATION              ║
[INFO] [stdout] [38;5;51m╚════════════════════════════════════════════════╝
[INFO] [stdout] [0m[38;5;226m  ⚠ No configuration found
[INFO] [stdout] 
[INFO] [stdout] [38;5;51m  Expected location:
[INFO] [stdout] [38;5;231m  /root/.config/liiga_teletext/config.toml
[INFO] [stdout] 
[INFO] [stdout] [38;5;231m  Run the app to create a config, or use:
[INFO] [stdout] [38;5;46m  liiga_teletext --config
[INFO] [stdout] [0mtest config::tests::test_config_display_without_config_file ... ok
[INFO] [stdout] test config::tests::test_config_save_creates_directory ... ok
[INFO] [stdout] test config::tests::test_config_with_various_api_domain_formats ... ok
[INFO] [stdout] test config::tests::test_get_config_path ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_fetch_date_custom_date ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_fetch_date_custom_date_none ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_fetch_date_no_custom_date ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_fetch_date_with_time_deterministic ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_fetch_date_with_time_edge_cases ... ok
[INFO] [stdout] test config::tests::test_config_serialization_deserialization ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_day_data_no_games ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_priority_order ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_game_data_no_goals ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_day_data_success ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_future_games_same_date ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_game_data_success ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_regular_season_start_date_not_found ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_concurrent_tournaments ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_regular_season_start_date_success ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_api_errors_handled ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_tournament_data_success ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_game_data_cache_fallback ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_find_future_games_fallback_invalid_date ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_tournament_data_not_found ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_get_team_name_unknown ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_find_future_games_fallback ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_get_team_name_with_team_name ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_has_actual_goals_no_goals ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_has_actual_goals_with_goals ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_august_transition ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_complex_scenarios ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_edge_cases ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_off_season_months ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_regular_season_months ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_year_boundary ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_process_goal_events_for_historical_game_with_players ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_process_goal_events_with_missing_player ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_should_fetch_detailed_data_finished_game ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_should_fetch_detailed_data_finished_with_score ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_should_fetch_detailed_data_not_finished ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_get_team_name_with_placeholder ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_find_future_games_fallback_no_games ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_tournament_data_no_games ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_no_active_tournaments ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_basic ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_cross_team_same_names ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_expiration ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_single_tournament_with_games ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_game_data_server_error ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_tournament_data_server_error ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_mixed_scenario ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_no_conflicts ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_formatting ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_empty_first_names ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_empty_teams ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_debugging_functions ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_api_integration_disambiguation_flow ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_three_players_same_name ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_unicode_names ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_key_generation ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_detailed_game_cache_basic ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_goal_events_cache_debug_methods ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_get_cached_player_name ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_cached_disambiguated_players ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_stats ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_empty_list ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_goal_events_cache_basic ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_mixed_without_ongoing ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_get_cached_disambiguated_players ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_all_completed ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_single_completed ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_detection ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_mixed_with_ongoing ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_multiple_ongoing ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_all_scheduled ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_playoffs_ongoing ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_single_ongoing ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_single_scheduled ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_tournament_cache_basic ... ok
[INFO] [stdout] test data_fetcher::models::common::tests::test_game_data_structure ... ok
[INFO] [stdout] test data_fetcher::models::common::tests::test_has_goal_events_trait_detailed_team ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_lru_access_order ... ok
[INFO] [stdout] test data_fetcher::models::common::tests::test_has_goal_events_trait_schedule_team ... ok
[INFO] [stdout] test data_fetcher::models::common::tests::test_has_teams_trait_detailed_game ... ok
[INFO] [stdout] test data_fetcher::models::common::tests::test_has_teams_trait_schedule_game ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_detailed_game_default_fields ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_detailed_game_response_serialization ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_detailed_team_serialization ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_detailed_game_serialization ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_penalty_event_serialization ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_period_serialization ... ok
[INFO] [stdout] test data_fetcher::models::goals::tests::test_complex_goal_event_deserialization ... ok
[INFO] [stdout] test data_fetcher::models::goals::tests::test_goal_event_data_goal_type_display ... ok
[INFO] [stdout] test data_fetcher::models::goals::tests::test_goal_event_default_fields ... ok
[INFO] [stdout] test data_fetcher::models::goals::tests::test_goal_event_serialization ... ok
[INFO] [stdout] test data_fetcher::models::players::tests::test_player_clone ... ok
[INFO] [stdout] test data_fetcher::models::goals::tests::test_goal_type_display_safe_fallbacks ... ok
[INFO] [stdout] test data_fetcher::models::players::tests::test_player_serialization ... ok
[INFO] [stdout] test data_fetcher::models::players::tests::test_player_with_special_characters ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_api_game_serialization ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_game_default_fields ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_response_serialization ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_team_default_fields ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_team_serialization ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_game_serialization ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_lru_simple ... ok
[INFO] [stdout] test data_fetcher::models::tests::test_clone_implementations ... ok
[INFO] [stdout] test data_fetcher::models::tests::test_debug_implementations ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_create_basic_goal_events ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_create_basic_goal_events_empty_game ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_determine_game_status_finished_regular ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_determine_game_status_ongoing ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_determine_game_status_overtime ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_determine_game_status_scheduled ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_determine_game_status_shootout ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_create_basic_goal_events_with_scores_but_no_events ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_edge_cases_large_game_time ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_edge_cases_zero_game_time ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_format_time_empty_string ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_format_time_invalid_format ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_format_time_invalid_date ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_format_time_valid_utc ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_format_time_valid_with_timezone ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_goal_event_data_fields ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_empty_game ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_no_video_url ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_multiple_goal_types ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_empty_teams ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_preserves_winning_goal_flag ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_basic ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_missing_player ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_multiple_same_name ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_mixed_scenario ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_fallback_names ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_team_scoped ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_unicode_names ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_goals ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_team_goals_with_disambiguation ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_team_goals_filters_cancelled_goals ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_team_goals_with_disambiguation_filters_cancelled ... ok
[INFO] [stdout] test data_fetcher::processors::time_formatting::tests::test_noon_cutoff_behavior ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_team_goals_with_disambiguation_missing_player ... ok
[INFO] [stdout] test error::tests::test_api_client_error_helper ... ok
[INFO] [stdout] test data_fetcher::processors::time_formatting::tests::test_should_show_todays_games_consistency ... ok
[INFO] [stdout] test data_fetcher::processors::time_formatting::tests::test_should_show_todays_games_deterministic_examples ... ok
[INFO] [stdout] test error::tests::test_api_malformed_json_helper ... ok
[INFO] [stdout] test error::tests::test_api_no_data_helper ... ok
[INFO] [stdout] test error::tests::test_api_game_not_found_helper ... ok
[INFO] [stdout] test error::tests::test_api_not_found_helper ... ok
[INFO] [stdout] test error::tests::test_api_season_not_found_helper ... ok
[INFO] [stdout] test error::tests::test_api_rate_limit_helper ... ok
[INFO] [stdout] test error::tests::test_api_server_error_helper ... ok
[INFO] [stdout] test error::tests::test_api_tournament_not_found_helper ... ok
[INFO] [stdout] test error::tests::test_api_service_unavailable_helper ... ok
[INFO] [stdout] test error::tests::test_custom_error ... ok
[INFO] [stdout] test error::tests::test_api_unexpected_structure_helper ... ok
[INFO] [stdout] test error::tests::test_config_error_helper ... ok
[INFO] [stdout] test error::tests::test_datetime_parse_error_helper ... ok
[INFO] [stdout] test error::tests::test_error_display_formats ... ok
[INFO] [stdout] test error::tests::test_error_from_semver ... ok
[INFO] [stdout] test error::tests::test_error_from_io ... ok
[INFO] [stdout] test error::tests::test_error_from_serde_json ... ok
[INFO] [stdout] test error::tests::test_error_from_toml_deserialize ... ok
[INFO] [stdout] test error::tests::test_error_from_toml_serialize ... ok
[INFO] [stdout] test error::tests::test_is_not_found ... ok
[INFO] [stdout] test error::tests::test_is_retryable ... ok
[INFO] [stdout] test error::tests::test_log_setup_error_helper ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_lru_simple_access_order ... ok
[INFO] [stdout] test error::tests::test_network_timeout_helper ... ok
[INFO] [stdout] test error::tests::test_retry_delay_constants_consistency ... ok
[INFO] [stdout] test error::tests::test_retry_delay_seconds_for_non_retryable_errors ... ok
[INFO] [stdout] test error::tests::test_retry_delay_seconds_for_retryable_errors ... ok
[INFO] [stdout] test error::tests::test_retry_delay_seconds_uses_constants ... ok
[INFO] [stdout] test performance::tests::test_performance_metrics ... ok
[INFO] [stdout] test performance::tests::test_request_deduplicator ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_buffer_size_calculation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_can_fit_two_pages_false_when_wide_mode_disabled ... ok
[INFO] [stdout] test teletext_ui::core::test_video_link_functionality_with_dynamic_layout ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_can_fit_two_pages_with_sufficient_width ... ok
[INFO] [stdout] test error::tests::test_network_connection_helper ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_display_config ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_http_response_cache_basic ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_display_config_comprehensive ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_all_ongoing ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_can_fit_two_pages_with_insufficient_width ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_mode_getter_setter ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_distribute_games_for_wide_display_enabled ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_distribute_games_for_wide_display_disabled ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_distribute_games_for_wide_display_odd_number ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_error_message_display ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_formatting_various_game_states ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_from_config_returns_error_with_invalid_config ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_distribute_games_for_wide_display_insufficient_width ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_game_height_calculation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_game_result_display ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_get_ansi_code_helper ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_from_config_succeeds_with_valid_config ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_group_games_for_compact_display ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_header_truncation_logic ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_multi_column_compact_layout ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_loading_indicator ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_mode_compatibility_validation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_page_navigation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_page_wrapping ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_team_abbreviation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_team_abbreviation_comprehensive ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_teletext_page_config_mode_exclusivity ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_teletext_page_config_validation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_teletext_page_mode_exclusivity ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_mode_spacing ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_format_compact_game ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_terminal_width_validation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_page_preservation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_terminal_width_adaptation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_wide_mode_getter_setter ... ok
[INFO] [stdout] test teletext_ui::footer::tests::test_calculate_footer_position_interactive ... ok
[INFO] [stdout] test teletext_ui::footer::tests::test_calculate_footer_position_non_interactive ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_alignment_calculator_caching ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_alignment_calculator_consistency_across_different_layouts ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_alignment_calculator_creation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_analyze_content_for_fallback_moderate_limits ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_video_link_display ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_analyze_content_for_fallback_strict_limits ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_calculate_layout_uses_fallback_for_narrow_terminal ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_cache_clearing ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_calculate_layout_uses_fallback_for_suboptimal_terminal ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_calculate_layout_uses_normal_for_adequate_terminal ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_column_layout_manager_creation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_content_analysis_empty_games ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_content_analysis_limits ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_content_analysis_with_goal_events ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_content_analysis_with_truncation_strategies ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_dynamic_spacing_calculation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_fallback_layout_for_narrow_terminal ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_fallback_layout_for_suboptimal_terminal ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_fallback_layout_positions_dont_overlap ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_fallback_layout_with_intelligent_truncation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_invalid_goal_types ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_invalid_scores ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_missing_team_names ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_missing_player_names ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_missing_time_and_result ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_sanitize_games ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_valid_game ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_get_play_icon_column_position ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_goal_type_overflow_prevention ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_goal_type_positioning_accuracy_various_lengths ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_goal_type_positions_calculation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_goal_types_validation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_intelligent_truncator_goal_types_validation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_intelligent_truncator_player_name_truncation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_intelligent_truncator_spacing_reduction ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_intelligent_truncator_strategy_determination ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_layout_accessors ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_layout_calculation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_layout_calculation_caching ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_layout_calculation_with_validation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_wide_mode_with_test_games ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_narrow_terminal_layout ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_overflow_prevention_boundary_conditions ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_overflow_prevention_edge_cases ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_goal_type_positioning_accuracy_with_custom_layout ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_overflow_prevention_with_long_goal_types ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_play_icon_alignment_consistency_empty_games ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_play_icon_alignment_consistency_mixed_video_links ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_play_icon_alignment_consistency_multiple_games ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_play_icon_positions_calculation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_teletext_page_validation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_layout_config_default ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_play_icon_positions_with_video_links ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_score_format_validation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_string_caching ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_terminal_width_validation_adequate ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_terminal_width_validation_too_narrow ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_terminal_width_validation_suboptimal ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_wide_mode_layout_calculation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_wide_mode_column_layout_manager_creation ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_format_game_time ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_wide_mode_layout_proportional_spacing ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_format_playing_time ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_wide_mode_layout_with_normal_column_width ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_validate_no_overflow ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_format_score_with_indicators_final ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_format_score_with_indicators_ongoing ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_can_fit_two_pages_disabled ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_format_score_with_indicators_scheduled ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_can_fit_two_pages_enabled ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_should_highlight_score ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_distribute_games_disabled ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_get_column_content_width ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_distribute_games_enabled_even_number ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_validate_terminal_disabled ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_get_right_column_start ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_validate_terminal_suitable ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_validate_terminal_too_narrow ... ok
[INFO] [stdout] test testing_utils::tests::test_create_basic_game ... ok
[INFO] [stdout] test testing_utils::tests::test_create_live_game ... ok
[INFO] [stdout] test testing_utils::tests::test_create_multiple_games ... ok
[INFO] [stdout] test testing_utils::tests::test_create_overtime_game ... ok
[INFO] [stdout] test testing_utils::tests::test_create_powerplay_goal ... ok
[INFO] [stdout] test testing_utils::tests::test_create_shootout_game ... ok
[INFO] [stdout] test testing_utils::tests::test_create_tournament_games ... ok
[INFO] [stdout] test testing_utils::tests::test_create_winning_goal ... ok
[INFO] [stdout] test testing_utils::tests::test_validate_game_data_invalid_empty_team ... ok
[INFO] [stdout] test testing_utils::tests::test_validate_game_data_invalid_overtime_and_shootout ... ok
[INFO] [stdout] test testing_utils::tests::test_validate_game_data_valid ... ok
[INFO] [stdout] test testing_utils::tests::test_validate_goal_events_invalid_empty_scorer ... ok
[INFO] [stdout] test testing_utils::tests::test_validate_goal_events_invalid_minute ... ok
[INFO] [stdout] test testing_utils::tests::test_validate_goal_events_valid ... ok
[INFO] [stdout] test ui::interactive::change_detection::tests::test_calculate_games_hash_empty ... ok
[INFO] [stdout] test ui::interactive::event_handler::tests::test_event_handler_builder ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_wide_mode_manager_creation ... ok
[INFO] [stdout] test testing_utils::tests::test_create_goal_event ... ok
[INFO] [stdout] test ui::interactive::event_handler::tests::test_event_handler_config_default ... ok
[INFO] [stdout] test ui::interactive::event_handler::tests::test_event_result_equality ... ok
[INFO] [stdout] test ui::interactive::event_handler::tests::test_event_handler_creation ... ok
[INFO] [stdout] test ui::interactive::event_handler::tests::test_event_handler_should_exit_default ... ok
[INFO] [stdout] test ui::interactive::navigation_manager::tests::test_format_date_for_display ... ok
[INFO] [stdout] test ui::interactive::navigation_manager::tests::test_loading_indicator_config ... ok
[INFO] [stdout] test ui::interactive::navigation_manager::tests::test_navigation_manager_creation ... ok
[INFO] [stdout] test ui::interactive::navigation_manager::tests::test_navigation_manager_default ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_cache_monitoring_config_default ... ok
[INFO] [stdout] test ui::interactive::navigation_manager::tests::test_is_future_game ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_data_fetch_params ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_refresh_coordinator_with_cache_config ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_refresh_coordinator_default ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_refresh_cycle_config ... ok
[INFO] [stdout] test ui::interactive::series_utils::tests::test_series_type_display ... ok
[INFO] [stdout] test ui::interactive::series_utils::tests::test_series_type_from_string ... ok
[INFO] [stdout] test ui::interactive::series_utils::tests::test_series_type_priority_ordering ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_refresh_coordinator_creation ... ok
[INFO] [stdout] test ui::interactive::terminal_manager::tests::test_terminal_manager_creation ... ok
[INFO] [stdout] test ui::interactive::terminal_manager::tests::test_terminal_manager_default ... ok
[INFO] [stdout] test ui::interactive::terminal_manager::tests::test_terminal_manager_with_config ... ok
[INFO] [stdout] test ui::interactive::terminal_manager::tests::test_terminal_config_debug_mode ... ok
[INFO] [stdout] test ui::interactive::terminal_manager::tests::test_terminal_config_default ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_setter_validation_conflicts ... ok
[INFO] [stdout] test error::tests::test_error_from_reqwest ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_distribute_games_enabled_odd_number ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_tournament_cache_ttl ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_complex_mixed_scenario ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 376 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 5.56s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/build/liiga_teletext/07c08f8308b59fed/deps/liiga_teletext-07c08f8308b59fed)
[INFO] [stdout] 
[INFO] [stdout] running 359 tests
[INFO] [stdout] test config::tests::test_config_default_log_file_path ... ok
[INFO] [stdout] test config::tests::test_config_load_invalid_toml ... ok
[INFO] [stdout] 
[INFO] [stdout] [38;5;51m╔════════════════════════════════════════════════╗
[INFO] [stdout] [38;5;231m║             CURRENT CONFIGURATION              ║
[INFO] [stdout] [38;5;51m╚════════════════════════════════════════════════╝
[INFO] [stdout] [0m[38;5;226m  ⚠ No configuration found
[INFO] [stdout] 
[INFO] [stdout] [38;5;51m  Expected location:
[INFO] [stdout] [38;5;231m  /root/.config/liiga_teletext/config.toml
[INFO] [stdout] 
[INFO] [stdout] [38;5;231m  Run the app to create a config, or use:
[INFO] [stdout] [38;5;46m  liiga_teletext --config
[INFO] [stdout] [0mtest config::tests::test_config_load_from_nonexistent_path ... ok
[INFO] [stdout] test config::tests::test_config_display_without_config_file ... ok
[INFO] [stdout] test config::tests::test_config_path_generation ... ok
[INFO] [stdout] test config::tests::test_config_load_without_log_file_path ... ok
[INFO] [stdout] test config::tests::test_config_empty_file ... ok
[INFO] [stdout] test config::tests::test_config_malformed_toml_file ... ok
[INFO] [stdout] 
[INFO] [stdout] [38;5;51m╔════════════════════════════════════════════════╗
[INFO] [stdout] [38;5;231m║            API DOMAIN CONFIGURATION            ║
[INFO] [stdout] [38;5;51m╚════════════════════════════════════════════════╝
[INFO] [stdout] test config::tests::test_config_display_with_existing_config ... [0mok
[INFO] [stdout] [38;5;231m  Enter the API domain URL for fetching game data.
[INFO] [stdout] [0m[38;5;231m  Format: [0m[38;5;46mhttps://example.com/api/v2
[INFO] [stdout] [0m[38;5;51m  • [0m[38;5;231mInclude https:// prefix (or it will be added)
[INFO] [stdout] [0m[38;5;51m  • [0m[38;5;231mDo NOT include trailing slash
[INFO] [stdout] [0m[38;5;231m  Press [0m[38;5;226mEnter[0m[38;5;231m without input to cancel.
[INFO] [stdout] [0m[38;5;51m  ────────────────────────────────────────────────
[INFO] [stdout] [0m[38;5;51m  API domain: [0m[38;5;226m  Configuration cancelled.
[INFO] [stdout] test config::tests::test_config_save_and_load_roundtrip ... [0mok
[INFO] [stdout] test config::tests::test_config_missing_required_field ... ok
[INFO] [stdout] test config::tests::test_config_save_to_readonly_directory ... ok
[INFO] [stdout] test config::tests::test_config_save_creates_directory ... ok
[INFO] [stdout] test config::tests::test_config_serialization_deserialization ... ok
[INFO] [stdout] test config::tests::test_config_validation_invalid_configs ... ok
[INFO] [stdout] test config::tests::test_config_save_with_http_prefix ... ok
[INFO] [stdout] test config::tests::test_config_save_new_file ... ok
[INFO] [stdout] test config::tests::test_config_save_creates_nested_directories ... ok
[INFO] [stdout] test config::tests::test_config_serialization_with_special_characters ... ok
[INFO] [stdout] test config::tests::test_config_with_extra_fields ... ok
[INFO] [stdout] test config::tests::test_config_without_log_file_path_serialization ... ok
[INFO] [stdout] test config::tests::test_get_config_path ... ok
[INFO] [stdout] test config::tests::test_get_log_dir_path ... ok
[INFO] [stdout] test config::tests::test_log_dir_path_generation ... ok
[INFO] [stdout] test constants::tests::test_env_var_names_are_not_empty ... ok
[INFO] [stdout] test constants::tests::test_polling_constants_are_reasonable ... ok
[INFO] [stdout] test constants::tests::test_retry_constants_are_reasonable ... ok
[INFO] [stdout] test constants::tests::test_ttl_constants_are_reasonable ... ok
[INFO] [stdout] test constants::tests::test_tournament_constants_are_valid_months ... ok
[INFO] [stdout] test config::tests::test_config_save_without_https_prefix ... ok
[INFO] [stdout] test constants::tests::test_validation_constants_are_reasonable ... ok
[INFO] [stdout] test constants::tests::test_ui_constants_are_reasonable ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_build_tournament_list_playoffs ... ok
[INFO] [stdout] test config::tests::test_environment_variable_override ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_build_tournament_list_preseason ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_build_tournament_list_regular_season ... ok
[INFO] [stdout] test config::tests::test_config_with_various_api_domain_formats ... ok
[INFO] [stdout] test config::tests::test_config_load_existing_file ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_fetch_date_custom_date ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_fetch_date_custom_date_none ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_fetch_date_no_custom_date ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_fetch_date_with_time_deterministic ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_fetch_date_with_time_edge_cases ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_api_errors_handled ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_day_data_no_games ... ok
[INFO] [stdout] test config::tests::test_config_validation_valid_configs ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_day_data_success ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_concurrent_tournaments ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_game_data_no_goals ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_game_data_success ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_regular_season_start_date_not_found ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_regular_season_start_date_success ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_future_games_same_date ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_game_data_cache_fallback ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_tournament_data_success ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_tournament_data_no_games ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_find_future_games_fallback ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_find_future_games_fallback_invalid_date ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_get_team_name_unknown ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_get_team_name_with_placeholder ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_get_team_name_with_team_name ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_has_actual_goals_no_goals ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_has_actual_goals_with_goals ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_august_transition ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_complex_scenarios ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_edge_cases ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_off_season_months ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_regular_season_months ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_is_historical_date_year_boundary ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_process_goal_events_for_historical_game_with_players ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_process_goal_events_with_missing_player ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_should_fetch_detailed_data_finished_game ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_should_fetch_detailed_data_finished_with_score ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_should_fetch_detailed_data_not_finished ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_find_future_games_fallback_no_games ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_priority_order ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_no_active_tournaments ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_determine_active_tournaments_single_tournament_with_games ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_game_data_server_error ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_tournament_data_server_error ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_basic ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_cross_team_same_names ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_debugging_functions ... ok
[INFO] [stdout] test data_fetcher::api::core::tests::test_fetch_tournament_data_not_found ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_api_integration_disambiguation_flow ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_expiration ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_three_players_same_name ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_stats ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_mixed_scenario ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_empty_teams ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_detailed_game_cache_basic ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_get_cached_player_name ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_goal_events_cache_debug_methods ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_key_generation ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_get_cached_disambiguated_players ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_cached_disambiguated_players ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_empty_first_names ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_unicode_names ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_all_completed ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_empty_list ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_all_ongoing ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_mixed_with_ongoing ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_goal_events_cache_basic ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_mixed_without_ongoing ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_playoffs_ongoing ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_all_scheduled ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_single_scheduled ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_single_completed ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_single_ongoing ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_multiple_ongoing ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_lru_access_order ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_lru_simple ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_http_response_cache_basic ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_lru_simple_access_order ... ok
[INFO] [stdout] test data_fetcher::models::common::tests::test_game_data_structure ... ok
[INFO] [stdout] test data_fetcher::models::common::tests::test_has_goal_events_trait_detailed_team ... ok
[INFO] [stdout] test data_fetcher::models::common::tests::test_has_goal_events_trait_schedule_team ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_detection ... ok
[INFO] [stdout] test data_fetcher::models::common::tests::test_has_teams_trait_detailed_game ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_detailed_game_default_fields ... ok
[INFO] [stdout] test data_fetcher::models::common::tests::test_has_teams_trait_schedule_game ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_detailed_game_response_serialization ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_penalty_event_serialization ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_detailed_game_serialization ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_period_serialization ... ok
[INFO] [stdout] test data_fetcher::models::goals::tests::test_complex_goal_event_deserialization ... ok
[INFO] [stdout] test data_fetcher::models::goals::tests::test_goal_event_data_goal_type_display ... ok
[INFO] [stdout] test data_fetcher::models::detailed::tests::test_detailed_team_serialization ... ok
[INFO] [stdout] test data_fetcher::models::goals::tests::test_goal_event_default_fields ... ok
[INFO] [stdout] test data_fetcher::models::goals::tests::test_goal_type_display_safe_fallbacks ... ok
[INFO] [stdout] test data_fetcher::models::players::tests::test_player_clone ... ok
[INFO] [stdout] test data_fetcher::models::goals::tests::test_goal_event_serialization ... ok
[INFO] [stdout] test data_fetcher::models::players::tests::test_player_serialization ... ok
[INFO] [stdout] test data_fetcher::models::players::tests::test_player_with_special_characters ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_api_game_serialization ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_game_default_fields ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_response_serialization ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_game_serialization ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_team_default_fields ... ok
[INFO] [stdout] test data_fetcher::models::tests::test_clone_implementations ... ok
[INFO] [stdout] test data_fetcher::models::tests::test_debug_implementations ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_create_basic_goal_events ... ok
[INFO] [stdout] test data_fetcher::models::schedule::tests::test_schedule_team_serialization ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_determine_game_status_finished_regular ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_create_basic_goal_events_with_scores_but_no_events ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_create_basic_goal_events_empty_game ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_determine_game_status_ongoing ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_determine_game_status_overtime ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_determine_game_status_scheduled ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_determine_game_status_shootout ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_format_time_empty_string ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_edge_cases_large_game_time ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_edge_cases_zero_game_time ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_format_time_invalid_date ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_format_time_invalid_format ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_format_time_valid_utc ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_format_time_valid_with_timezone ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_goal_event_data_fields ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_empty_game ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_multiple_goal_types ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_no_video_url ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_preserves_winning_goal_flag ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_basic ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_empty_teams ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_missing_player ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_mixed_scenario ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_multiple_same_name ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_team_scoped ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_disambiguation_unicode_names ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_fallback_names ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_team_goals_filters_cancelled_goals ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_goal_events_with_goals ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_team_goals_with_disambiguation ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_team_goals_with_disambiguation_missing_player ... ok
[INFO] [stdout] test data_fetcher::processors::core::tests::test_process_team_goals_with_disambiguation_filters_cancelled ... ok
[INFO] [stdout] test data_fetcher::processors::time_formatting::tests::test_should_show_todays_games_consistency ... ok
[INFO] [stdout] test data_fetcher::processors::time_formatting::tests::test_should_show_todays_games_deterministic_examples ... ok
[INFO] [stdout] test data_fetcher::processors::time_formatting::tests::test_noon_cutoff_behavior ... ok
[INFO] [stdout] test error::tests::test_api_malformed_json_helper ... ok
[INFO] [stdout] test error::tests::test_api_client_error_helper ... ok
[INFO] [stdout] test error::tests::test_api_game_not_found_helper ... ok
[INFO] [stdout] test error::tests::test_api_no_data_helper ... ok
[INFO] [stdout] test error::tests::test_api_not_found_helper ... ok
[INFO] [stdout] test error::tests::test_api_server_error_helper ... ok
[INFO] [stdout] test error::tests::test_api_rate_limit_helper ... ok
[INFO] [stdout] test error::tests::test_api_season_not_found_helper ... ok
[INFO] [stdout] test error::tests::test_api_service_unavailable_helper ... ok
[INFO] [stdout] test error::tests::test_api_tournament_not_found_helper ... ok
[INFO] [stdout] test error::tests::test_api_unexpected_structure_helper ... ok
[INFO] [stdout] test error::tests::test_config_error_helper ... ok
[INFO] [stdout] test error::tests::test_custom_error ... ok
[INFO] [stdout] test error::tests::test_datetime_parse_error_helper ... ok
[INFO] [stdout] test error::tests::test_error_display_formats ... ok
[INFO] [stdout] test error::tests::test_error_from_io ... ok
[INFO] [stdout] test error::tests::test_error_from_semver ... ok
[INFO] [stdout] test error::tests::test_error_from_serde_json ... ok
[INFO] [stdout] test error::tests::test_error_from_toml_deserialize ... ok
[INFO] [stdout] test error::tests::test_error_from_toml_serialize ... ok
[INFO] [stdout] test error::tests::test_is_not_found ... ok
[INFO] [stdout] test error::tests::test_is_retryable ... ok
[INFO] [stdout] test error::tests::test_log_setup_error_helper ... ok
[INFO] [stdout] test error::tests::test_network_connection_helper ... ok
[INFO] [stdout] test error::tests::test_network_timeout_helper ... ok
[INFO] [stdout] test error::tests::test_retry_delay_constants_consistency ... ok
[INFO] [stdout] test error::tests::test_retry_delay_seconds_for_non_retryable_errors ... ok
[INFO] [stdout] test error::tests::test_retry_delay_seconds_for_retryable_errors ... ok
[INFO] [stdout] test error::tests::test_retry_delay_seconds_uses_constants ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_disambiguation_no_conflicts ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_cache_players_with_formatting ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_tournament_cache_basic ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_has_live_games_from_game_data_complex_mixed_scenario ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_can_fit_two_pages_with_sufficient_width ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_display_config ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_display_config_comprehensive ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_formatting_various_game_states ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_can_fit_two_pages_false_when_wide_mode_disabled ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_buffer_size_calculation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_distribute_games_for_wide_display_disabled ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_distribute_games_for_wide_display_enabled ... ok
[INFO] [stdout] test data_fetcher::cache::core::tests::test_tournament_cache_ttl ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_distribute_games_for_wide_display_odd_number ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_error_message_display ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_distribute_games_for_wide_display_insufficient_width ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_mode_getter_setter ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_from_config_returns_error_with_invalid_config ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_can_fit_two_pages_with_insufficient_width ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_game_height_calculation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_game_result_display ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_mode_compatibility_validation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_format_compact_game ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_get_ansi_code_helper ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_from_config_succeeds_with_valid_config ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_multi_column_compact_layout ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_compact_mode_spacing ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_loading_indicator ... ok
[INFO] [stdout] test teletext_ui::core::test_video_link_functionality_with_dynamic_layout ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_team_abbreviation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_team_abbreviation_comprehensive ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_teletext_page_config_mode_exclusivity ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_teletext_page_config_validation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_page_wrapping ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_group_games_for_compact_display ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_terminal_width_adaptation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_teletext_page_mode_exclusivity ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_terminal_width_validation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_page_preservation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_teletext_page_validation ... ok
[INFO] [stdout] test teletext_ui::footer::tests::test_calculate_footer_position_interactive ... ok
[INFO] [stdout] test teletext_ui::footer::tests::test_calculate_footer_position_non_interactive ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_alignment_calculator_caching ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_alignment_calculator_consistency_across_different_layouts ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_alignment_calculator_creation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_wide_mode_getter_setter ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_analyze_content_for_fallback_moderate_limits ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_analyze_content_for_fallback_strict_limits ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_cache_clearing ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_calculate_layout_uses_fallback_for_suboptimal_terminal ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_calculate_layout_uses_normal_for_adequate_terminal ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_calculate_layout_uses_fallback_for_narrow_terminal ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_column_layout_manager_creation ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_setter_validation_conflicts ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_content_analysis_limits ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_content_analysis_with_goal_events ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_video_link_display ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_content_analysis_with_truncation_strategies ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_dynamic_spacing_calculation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_fallback_layout_for_narrow_terminal ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_fallback_layout_for_suboptimal_terminal ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_fallback_layout_positions_dont_overlap ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_invalid_goal_types ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_invalid_scores ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_fallback_layout_with_intelligent_truncation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_missing_player_names ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_missing_team_names ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_wide_mode_with_test_games ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_missing_time_and_result ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_sanitize_games ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_game_data_validator_valid_game ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_get_play_icon_column_position ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_goal_type_overflow_prevention ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_goal_type_positioning_accuracy_various_lengths ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_goal_type_positioning_accuracy_with_custom_layout ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_goal_type_positions_calculation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_goal_types_validation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_intelligent_truncator_goal_types_validation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_intelligent_truncator_player_name_truncation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_intelligent_truncator_spacing_reduction ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_intelligent_truncator_strategy_determination ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_content_analysis_empty_games ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_layout_calculation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_layout_calculation_caching ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_layout_accessors ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_layout_calculation_with_validation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_layout_config_default ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_narrow_terminal_layout ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_overflow_prevention_boundary_conditions ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_overflow_prevention_edge_cases ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_overflow_prevention_with_long_goal_types ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_play_icon_alignment_consistency_empty_games ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_header_truncation_logic ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_play_icon_alignment_consistency_mixed_video_links ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_play_icon_alignment_consistency_multiple_games ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_play_icon_positions_with_video_links ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_score_format_validation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_string_caching ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_play_icon_positions_calculation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_terminal_width_validation_adequate ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_terminal_width_validation_suboptimal ... ok
[INFO] [stdout] test teletext_ui::core::tests::test_page_navigation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_terminal_width_validation_too_narrow ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_validate_no_overflow ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_wide_mode_column_layout_manager_creation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_wide_mode_layout_calculation ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_wide_mode_layout_proportional_spacing ... ok
[INFO] [stdout] test teletext_ui::layout::tests::test_wide_mode_layout_with_normal_column_width ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_format_game_time ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_format_playing_time ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_can_fit_two_pages_enabled ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_format_score_with_indicators_ongoing ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_format_score_with_indicators_scheduled ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_should_highlight_score ... ok
[INFO] [stdout] test teletext_ui::score_formatting::tests::test_format_score_with_indicators_final ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_get_column_content_width ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_distribute_games_disabled ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_get_right_column_start ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_distribute_games_enabled_odd_number ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_validate_terminal_disabled ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_distribute_games_enabled_even_number ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_validate_terminal_suitable ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_validate_terminal_too_narrow ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_wide_mode_manager_creation ... ok
[INFO] [stdout] test ui::interactive::event_handler::tests::test_event_handler_config_default ... ok
[INFO] [stdout] test teletext_ui::wide_mode::tests::test_can_fit_two_pages_disabled ... ok
[INFO] [stdout] test ui::interactive::event_handler::tests::test_event_handler_creation ... ok
[INFO] [stdout] test ui::interactive::event_handler::tests::test_event_handler_builder ... ok
[INFO] [stdout] test ui::interactive::event_handler::tests::test_event_handler_should_exit_default ... ok
[INFO] [stdout] test ui::interactive::navigation_manager::tests::test_loading_indicator_config ... ok
[INFO] [stdout] test ui::interactive::navigation_manager::tests::test_navigation_manager_default ... ok
[INFO] [stdout] test ui::interactive::navigation_manager::tests::test_navigation_manager_creation ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_cache_monitoring_config_default ... ok
[INFO] [stdout] test ui::interactive::navigation_manager::tests::test_is_future_game ... ok
[INFO] [stdout] test ui::interactive::navigation_manager::tests::test_format_date_for_display ... ok
[INFO] [stdout] test ui::interactive::change_detection::tests::test_calculate_games_hash_empty ... ok
[INFO] [stdout] test ui::interactive::event_handler::tests::test_event_result_equality ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_refresh_coordinator_creation ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_refresh_coordinator_default ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_refresh_cycle_config ... ok
[INFO] [stdout] test ui::interactive::series_utils::tests::test_series_type_display ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_data_fetch_params ... ok
[INFO] [stdout] test ui::interactive::refresh_coordinator::tests::test_refresh_coordinator_with_cache_config ... ok
[INFO] [stdout] test ui::interactive::terminal_manager::tests::test_terminal_config_default ... ok
[INFO] [stdout] test ui::interactive::terminal_manager::tests::test_terminal_manager_creation ... ok
[INFO] [stdout] test ui::interactive::terminal_manager::tests::test_terminal_manager_default ... ok
[INFO] [stdout] test ui::interactive::series_utils::tests::test_series_type_from_string ... ok
[INFO] [stdout] test ui::interactive::series_utils::tests::test_series_type_priority_ordering ... ok
[INFO] [stdout] test ui::interactive::terminal_manager::tests::test_terminal_config_debug_mode ... ok
[INFO] [stdout] test ui::interactive::terminal_manager::tests::test_terminal_manager_with_config ... ok
[INFO] [stdout] test error::tests::test_error_from_reqwest ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 359 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.89s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/comprehensive_end_to_end_tests.rs (/opt/rustwide/target/debug/build/liiga_teletext/3d45517efbe3e88a/deps/comprehensive_end_to_end_tests-3d45517efbe3e88a)
[INFO] [stdout] 
[INFO] [stdout] running 7 tests
[INFO] [stdout] test test_complete_application_flow_all_scenarios ... ok
[INFO] [stdout] test test_error_handling_comprehensive_scenarios ... ok
[INFO] [stdout] test test_performance_comprehensive_scenarios ... ok
[INFO] [stdout] test test_different_terminal_sizes_comprehensive ... ok
[INFO] [stdout] test test_layout_system_all_game_scenarios ... ok
[INFO] [stdout] test test_backward_compatibility_comprehensive ... ok
[INFO] [stdout] test test_interactive_mode_comprehensive_integration ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 7 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/disambiguation_display_tests.rs (/opt/rustwide/target/debug/build/liiga_teletext/82ec7680aef9ff0b/deps/disambiguation_display_tests-82ec7680aef9ff0b)
[INFO] [stdout] 
[INFO] [stdout] running 8 tests
[INFO] [stdout] test test_normal_mode_displays_disambiguated_names_correctly ... ok
[INFO] [stdout] test test_name_truncation_works_properly_with_disambiguated_names ... ok
[INFO] [stdout] test test_compact_mode_handles_disambiguated_names_within_space_constraints ... ok
[INFO] [stdout] test test_all_modes_handle_unicode_disambiguated_names ... ok
[INFO] [stdout] test test_wide_mode_maintains_consistent_disambiguation_logic ... ok
[INFO] [stdout] test test_disambiguation_error_scenarios_in_display ... ok
[INFO] [stdout] test test_disambiguation_scoped_per_team_no_cross_team_escalation ... ok
[INFO] [stdout] test test_disambiguation_performance_with_many_players ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 8 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/disambiguation_integration_tests.rs (/opt/rustwide/target/debug/build/liiga_teletext/b378c62a733d25ae/deps/disambiguation_integration_tests-b378c62a733d25ae)
[INFO] [stdout] 
[INFO] [stdout] running 7 tests
[INFO] [stdout] test test_edge_cases_and_error_resilience ... ok
[INFO] [stdout] test test_cross_team_disambiguation_isolation ... ok
[INFO] [stdout] test test_unicode_character_handling_in_disambiguation ... ok
[INFO] [stdout] test test_end_to_end_disambiguation_with_real_world_names ... ok
[INFO] [stdout] test test_goal_events_show_correct_disambiguated_scorer_names ... ok
[INFO] [stdout] test test_performance_impact_with_large_datasets ... ok
[INFO] [stdout] test test_complete_data_flow_api_to_display ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 7 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/game_display_integration_tests.rs (/opt/rustwide/target/debug/build/liiga_teletext/37464c9cbb86217e/deps/game_display_integration_tests-37464c9cbb86217e)
[INFO] [stdout] 
[INFO] [stdout] running 16 tests
[INFO] [stdout] test test_ansi_positioning_code_correctness ... ok
[INFO] [stdout] test test_goal_type_positioning_and_overflow_prevention ... ok
[INFO] [stdout] test test_complete_game_display_scenarios_normal_mode ... ok
[INFO] [stdout] test test_complete_game_display_scenarios_wide_mode ... ok
[INFO] [stdout] test test_layout_system_integration_different_widths ... ok
[INFO] [stdout] test test_wide_mode_layout_integration_different_game_types ... ok
[INFO] [stdout] test test_wide_mode_play_icon_alignment_different_column_widths ... ok
[INFO] [stdout] test test_play_icon_alignment_consistency ... ok
[INFO] [stdout] test test_wide_mode_backward_compatibility ... ok
[INFO] [stdout] test test_wide_mode_vs_normal_mode_play_icon_consistency ... ok
[INFO] [stdout] test test_complete_game_display_with_layout_calculation ... ok
[INFO] [stdout] test test_wide_mode_play_icon_alignment ... ok
[INFO] [stdout] test test_game_display_error_handling ... ok
[INFO] [stdout] test test_wide_mode_rendering_with_layout_system ... ok
[INFO] [stderr]      Running tests/integration_tests.rs (/opt/rustwide/target/debug/build/liiga_teletext/70825d8ff69d8fcf/deps/integration_tests-70825d8ff69d8fcf)
[INFO] [stderr]      Running tests/interactive_layout_integration_tests.rs (/opt/rustwide/target/debug/build/liiga_teletext/ce5b40b8f85c8553/deps/interactive_layout_integration_tests-ce5b40b8f85c8553)
[INFO] [stdout] test test_game_display_layout_performance ... ok
[INFO] [stdout] test test_wide_mode_insufficient_width_fallback ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 16 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 25 tests
[INFO] [stdout] test test_compact_mode_terminal_width_constraints ... ok
[INFO] [stdout] test test_compact_mode_various_terminal_sizes ... ok
[INFO] [stdout] test test_compact_mode_with_dates ... ok
[INFO] [stdout] test test_compact_mode_non_interactive ... ok
[INFO] [stdout] test test_compact_mode_preserves_styling ... ok
[INFO] [stdout] test test_config_validation ... ok
[INFO] [stdout] test test_ongoing_games ... ok
[INFO] [stdout] test test_game_result_data_creation ... ok
[INFO] [stdout] test test_goal_event_processing ... ok
[INFO] [stdout] test test_compact_mode_basic_functionality ... ok
[INFO] [stdout] test test_special_situations ... ok
[INFO] [stdout] test test_end_to_end_multiple_games ... ok
[INFO] [stdout] test test_wide_mode_cli_integration ... ok
[INFO] [stdout] test test_wide_mode_game_distribution_integration ... ok
[INFO] [stdout] test test_wide_mode_mutual_exclusivity ... ok
[INFO] [stdout] test test_wide_mode_performance_edge_cases ... ok
[INFO] [stdout] test test_page_navigation ... ok
[INFO] [stdout] test test_wide_mode_with_different_game_states ... ok
[INFO] [stdout] test test_config_integration ... ok
[INFO] [stdout] test test_wide_mode_fallback_behavior ... ok
[INFO] [stdout] test test_wide_mode_with_goal_scorers ... ok
[INFO] [stdout] test test_different_tournament_types ... ok
[INFO] [stdout] test test_teletext_ui_generation ... ok
[INFO] [stdout] test test_wide_mode_terminal_widths ... ok
[INFO] [stdout] test test_error_handling ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 25 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 11 tests
[INFO] [stdout] test test_buffered_rendering_with_layout ... ok
[INFO] [stdout] test test_layout_consistency_across_refreshes ... ok
[INFO] [stdout] test test_layout_with_goal_events_in_interactive_mode ... ok
[INFO] [stdout] test test_interactive_state_layout_integration ... ok
[INFO] [stdout] test test_layout_cache_performance ... ok
[INFO] [stdout] test test_resize_handling_in_interactive_mode ... ok
[INFO] [stdout] test test_layout_updates_during_refresh ... ok
[INFO] [stdout] test test_layout_system_handles_empty_games_gracefully ... ok
[INFO] [stdout] test test_interactive_refresh_cycle_with_layout_updates ... ok
[INFO] [stdout] test test_wide_mode_layout_integration ... ok
[INFO] [stderr]      Running tests/multiple_goals_disambiguation_test.rs (/opt/rustwide/target/debug/build/liiga_teletext/f8085d9214a55d64/deps/multiple_goals_disambiguation_test-f8085d9214a55d64)
[INFO] [stdout] test test_layout_system_performance_under_frequent_updates ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 11 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/no_games_message_test.rs (/opt/rustwide/target/debug/build/liiga_teletext/e001ce4136819601/deps/no_games_message_test-e001ce4136819601)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stderr]      Running tests/simple_disambiguation_test.rs (/opt/rustwide/target/debug/build/liiga_teletext/dd14e8775efbec69/deps/simple_disambiguation_test-dd14e8775efbec69)
[INFO] [stdout] test test_create_error_page_includes_navigation_hint_for_specific_date ... ok
[INFO] [stdout] test test_create_error_page_includes_navigation_hint_for_today ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 7 tests
[INFO] [stdout] test test_ui_modes_with_verified_disambiguation ... ok
[INFO] [stdout] test test_name_truncation_with_disambiguation ... ok
[INFO] [stdout] test test_disambiguation_error_scenarios ... ok
[INFO] [stdout] test test_disambiguation_edge_cases ... ok
[INFO] [stdout] test test_disambiguation_logic_works_correctly ... ok
[INFO] [stdout] test test_disambiguation_consistency_across_modes ... ok
[INFO] [stdout] test test_disambiguation_context_functionality ... ok
[INFO] [stderr]    Doc-tests liiga_teletext
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 7 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.08s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 46 tests
[INFO] [stdout] test src/data_fetcher/api/urls.rs - data_fetcher::api::urls::build_schedule_url (line 58) ... ok
[INFO] [stdout] test src/data_fetcher/api/orchestrator.rs - data_fetcher::api::orchestrator::fetch_liiga_data (line 36) - compile ... ok
[INFO] [stdout] test src/config/user_prompts.rs - config::user_prompts::prompt_for_api_domain (line 163) - compile ... ok
[INFO] [stdout] test src/data_fetcher/api/urls.rs - data_fetcher::api::urls::build_tournament_schedule_url (line 80) ... ok
[INFO] [stdout] test src/data_fetcher/api/urls.rs - data_fetcher::api::urls::build_game_url (line 37) ... ok
[INFO] [stdout] test src/data_fetcher/api/urls.rs - data_fetcher::api::urls::create_tournament_key (line 101) ... ok
[INFO] [stdout] test src/data_fetcher/cache/player_cache.rs - data_fetcher::cache::player_cache::cache_players (line 68) ... ok
[INFO] [stdout] test src/data_fetcher/cache/player_cache.rs - data_fetcher::cache::player_cache::cache_players_with_disambiguation (line 137) ... ok
[INFO] [stdout] test src/data_fetcher/cache/player_cache.rs - data_fetcher::cache::player_cache::cache_players_with_formatting (line 105) ... ok
[INFO] [stdout] test src/data_fetcher/api/urls.rs - data_fetcher::api::urls::build_tournament_url (line 15) ... ok
[INFO] [stdout] test src/data_fetcher/cache/player_cache.rs - data_fetcher::cache::player_cache::get_cached_disambiguated_players (line 217) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/disambiguation.rs - data_fetcher::player_names::disambiguation::group_players_by_last_name (line 366) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/disambiguation.rs - data_fetcher::player_names::disambiguation::DisambiguationContext::new (line 458) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/disambiguation.rs - data_fetcher::player_names::disambiguation::format_with_disambiguation (line 27) ... ok
[INFO] [stdout] test src/data_fetcher/cache/player_cache.rs - data_fetcher::cache::player_cache::get_cached_player_name (line 264) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/disambiguation.rs - data_fetcher::player_names::disambiguation::is_disambiguation_needed (line 332) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/formatting.rs - data_fetcher::player_names::formatting::create_fallback_name (line 196) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/formatting.rs - data_fetcher::player_names::formatting::extract_first_chars (line 146) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/formatting.rs - data_fetcher::player_names::formatting::extract_first_initial (line 117) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/formatting.rs - data_fetcher::player_names::formatting::format_for_display_with_first_initial (line 87) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/disambiguation.rs - data_fetcher::player_names::disambiguation::get_players_needing_disambiguation (line 112) ... ok
[INFO] [stdout] test src/data_fetcher/processors/game_status.rs - data_fetcher::processors::game_status::format_time (line 123) ... ok
[INFO] [stdout] test src/data_fetcher/processors/goal_events.rs - data_fetcher::processors::goal_events::process_team_goals (line 193) ... ok
[INFO] [stdout] test src/data_fetcher/processors/game_status.rs - data_fetcher::processors::game_status::determine_game_status (line 26) ... ok
[INFO] [stdout] test src/data_fetcher/cache/player_cache.rs - data_fetcher::cache::player_cache::get_cached_players (line 27) ... ok
[INFO] [stdout] test src/data_fetcher/processors/goal_events.rs - data_fetcher::processors::goal_events::process_team_goals_with_disambiguation (line 134) ... ok
[INFO] [stdout] test src/data_fetcher/processors/player_fetching.rs - data_fetcher::processors::player_fetching::try_fetch_player_names_for_game (line 25) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/formatting.rs - data_fetcher::player_names::formatting::format_for_display (line 41) ... ok
[INFO] [stdout] test src/lib.rs - (line 8) - compile ... ok
[INFO] [stdout] test src/data_fetcher/cache/player_cache.rs - data_fetcher::cache::player_cache::has_cached_disambiguated_players (line 315) ... ok
[INFO] [stdout] test src/data_fetcher/processors/goal_events.rs - data_fetcher::processors::goal_events::process_goal_events (line 74) ... ok
[INFO] [stdout] test src/data_fetcher/processors/time_formatting.rs - data_fetcher::processors::time_formatting::should_show_todays_games_with_time (line 53) ... ok
[INFO] [stdout] test src/data_fetcher/processors/time_formatting.rs - data_fetcher::processors::time_formatting::should_show_todays_games (line 21) ... ok
[INFO] [stdout] test src/teletext_ui/content.rs - teletext_ui::content::TeletextPage::add_game_result (line 14) ... ok
[INFO] [stdout] test src/teletext_ui/content.rs - teletext_ui::content::TeletextPage::add_error_message (line 66) ... ok
[INFO] [stdout] test src/teletext_ui/pagination.rs - teletext_ui::pagination::TeletextPage::next_page (line 166) ... ok
[INFO] [stdout] test src/teletext_ui/pagination.rs - teletext_ui::pagination::TeletextPage::previous_page (line 198) ... ok
[INFO] [stdout] test src/teletext_ui/validation.rs - teletext_ui::validation::TeletextPage::validate_compact_mode_compatibility (line 17) ... ok
[INFO] [stdout] test src/teletext_ui/core.rs - teletext_ui::core::TeletextPage::render_buffered (line 385) ... FAILED
[INFO] [stdout] test src/teletext_ui/core.rs - teletext_ui::core::TeletextPage::handle_resize (line 208) ... FAILED
[INFO] [stdout] test src/teletext_ui/core.rs - teletext_ui::core::TeletextPage::from_config (line 149) ... ok
[INFO] [stdout] test src/ui/components/abbreviations.rs - ui::components::abbreviations::get_team_abbreviation (line 15) ... ok
[INFO] [stdout] test src/ui/teletext/game_result.rs - ui::teletext::game_result::GameResultData::new (line 37) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/disambiguation.rs - data_fetcher::player_names::disambiguation::group_players_by_last_name_indices (line 408) ... ok
[INFO] [stdout] test src/data_fetcher/player_names/formatting.rs - data_fetcher::player_names::formatting::build_full_name (line 21) ... ok
[INFO] [stdout] test src/teletext_ui/core.rs - teletext_ui::core::TeletextPage::new (line 81) ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- src/teletext_ui/core.rs - teletext_ui::core::TeletextPage::render_buffered (line 385) stdout ----
[INFO] [stdout] Test executable failed (exit status: 1).
[INFO] [stdout] 
[INFO] [stdout] stdout:
[INFO] [stdout] [?25l
[INFO] [stdout] stderr:
[INFO] [stdout] Error: Io(Os { code: 2, kind: NotFound, message: "No such file or directory" })
[INFO] [stdout] Error: "the test returned a termination value with a non-zero status code (1) which indicates a failure"
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] ---- src/teletext_ui/core.rs - teletext_ui::core::TeletextPage::handle_resize (line 208) stdout ----
[INFO] [stdout] Test executable failed (exit status: 1).
[INFO] [stdout] 
[INFO] [stdout] stdout:
[INFO] [stdout] [?25l
[INFO] [stdout] stderr:
[INFO] [stdout] Error: Io(Os { code: 11, kind: WouldBlock, message: "Resource temporarily unavailable" })
[INFO] [stdout] Error: "the test returned a termination value with a non-zero status code (1) which indicates a failure"
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     src/teletext_ui/core.rs - teletext_ui::core::TeletextPage::handle_resize (line 208)
[INFO] [stdout]     src/teletext_ui/core.rs - teletext_ui::core::TeletextPage::render_buffered (line 385)
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 44 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.07s
[INFO] [stdout] 
[INFO] [stdout] all doctests ran in 2.67s; merged doctests compilation took 2.56s
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] running `Command { std: "docker" "inspect" "aba94f43d373e1c4158ab5b5a32ba828cb7999f2bb36b0b7d8411d6637c415e4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "aba94f43d373e1c4158ab5b5a32ba828cb7999f2bb36b0b7d8411d6637c415e4", kill_on_drop: false }`
[INFO] [stdout] aba94f43d373e1c4158ab5b5a32ba828cb7999f2bb36b0b7d8411d6637c415e4
