[INFO] cloning repository https://github.com/GlebMan-n/synoplayer [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/GlebMan-n/synoplayer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGlebMan-n%2Fsynoplayer", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGlebMan-n%2Fsynoplayer'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 7f82b64a68f3b020610c5e4a432f46c4e8a75ce4 [INFO] testing GlebMan-n/synoplayer against master#f9988fefd3add01f414f52b414308e7872622fee for pr-155114 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGlebMan-n%2Fsynoplayer" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/GlebMan-n/synoplayer [INFO] finished tweaking git repo https://github.com/GlebMan-n/synoplayer [INFO] tweaked toml for git repo https://github.com/GlebMan-n/synoplayer written to /workspace/builds/worker-3-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/GlebMan-n/synoplayer on toolchain f9988fefd3add01f414f52b414308e7872622fee [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/GlebMan-n/synoplayer 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" "+f9988fefd3add01f414f52b414308e7872622fee" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded wiremock v0.6.5 [INFO] [stderr] Downloaded tokio-test v0.4.5 [INFO] [stderr] Downloaded cookie_store v0.22.1 [INFO] [stderr] Downloaded instability v0.3.12 [INFO] [stderr] Downloaded predicates-core v1.0.10 [INFO] [stderr] Downloaded float-cmp v0.10.0 [INFO] [stderr] Downloaded clap_complete v4.6.0 [INFO] [stderr] Downloaded predicates v3.1.4 [INFO] [stderr] Downloaded assert_cmd v2.2.0 [INFO] [stderr] Downloaded predicates-tree v1.0.13 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 1668973c7c6d5cd070493eb14cd88b5f8ce9b69e9f5b08f1ef4cf695faec6dfb [INFO] running `Command { std: "docker" "start" "-a" "1668973c7c6d5cd070493eb14cd88b5f8ce9b69e9f5b08f1ef4cf695faec6dfb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "1668973c7c6d5cd070493eb14cd88b5f8ce9b69e9f5b08f1ef4cf695faec6dfb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "1668973c7c6d5cd070493eb14cd88b5f8ce9b69e9f5b08f1ef4cf695faec6dfb", kill_on_drop: false }` [INFO] [stdout] 1668973c7c6d5cd070493eb14cd88b5f8ce9b69e9f5b08f1ef4cf695faec6dfb [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 231651e98144d850baca6ee372dc0297043e59231d32c5272da2227730c73b5d [INFO] running `Command { std: "docker" "start" "-a" "231651e98144d850baca6ee372dc0297043e59231d32c5272da2227730c73b5d", kill_on_drop: false }` [INFO] [stderr] Compiling bytes v1.11.1 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling futures-task v0.3.32 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling num-conv v0.2.0 [INFO] [stderr] Compiling time-core v0.1.8 [INFO] [stderr] Compiling deranged v0.5.8 [INFO] [stderr] Compiling cookie v0.18.1 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling darling_macro v0.23.0 [INFO] [stderr] Compiling regex-syntax v0.8.10 [INFO] [stderr] Compiling psl-types v2.0.11 [INFO] [stderr] Compiling instability v0.3.12 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling clap_builder v4.6.0 [INFO] [stderr] Compiling signal-hook-mio v0.2.5 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling time-macros v0.2.27 [INFO] [stderr] Compiling strum_macros v0.26.4 [INFO] [stderr] Compiling clap_derive v4.6.0 [INFO] [stderr] Compiling openssl v0.10.76 [INFO] [stderr] Compiling toml_write v0.1.2 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling darling v0.23.0 [INFO] [stderr] Compiling winnow v0.7.15 [INFO] [stderr] Compiling option-ext v0.2.0 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling tokio v1.50.0 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling http v1.4.0 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling crossterm v0.28.1 [INFO] [stderr] Compiling time v0.3.47 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling rustls-webpki v0.103.9 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling strum v0.26.3 [INFO] [stderr] Compiling toml_edit v0.22.27 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling chrono v0.4.44 [INFO] [stderr] Compiling ratatui v0.29.0 [INFO] [stderr] Compiling dirs v6.0.0 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling rustls v0.23.37 [INFO] [stderr] Compiling clap v4.6.0 [INFO] [stderr] Compiling clap_complete v4.6.0 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling native-tls v0.2.18 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling publicsuffix v2.3.0 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling tracing-subscriber v0.3.23 [INFO] [stderr] Compiling cookie_store v0.22.1 [INFO] [stderr] Compiling toml v0.8.23 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling tower v0.5.3 [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.20 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling synoplayer v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 52.61s [INFO] running `Command { std: "docker" "inspect" "231651e98144d850baca6ee372dc0297043e59231d32c5272da2227730c73b5d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "231651e98144d850baca6ee372dc0297043e59231d32c5272da2227730c73b5d", kill_on_drop: false }` [INFO] [stdout] 231651e98144d850baca6ee372dc0297043e59231d32c5272da2227730c73b5d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 5363a6cc265d9db96dbc32c52b486be6a85aab35bd44f203ac75dfd588547149 [INFO] running `Command { std: "docker" "start" "-a" "5363a6cc265d9db96dbc32c52b486be6a85aab35bd44f203ac75dfd588547149", kill_on_drop: false }` [INFO] [stderr] Compiling tokio v1.50.0 [INFO] [stderr] Compiling futures-macro v0.3.32 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling rustix v1.1.4 [INFO] [stderr] Compiling predicates-core v1.0.10 [INFO] [stderr] Compiling float-cmp v0.10.0 [INFO] [stderr] Compiling num_cpus v1.17.0 [INFO] [stderr] Compiling difflib v0.4.0 [INFO] [stderr] Compiling termtree v0.5.1 [INFO] [stderr] Compiling normalize-line-endings v0.3.0 [INFO] [stderr] Compiling deadpool-runtime v0.1.4 [INFO] [stderr] Compiling assert_cmd v2.2.0 [INFO] [stderr] Compiling wait-timeout v0.2.1 [INFO] [stderr] Compiling predicates-tree v1.0.13 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling cookie_store v0.22.1 [INFO] [stderr] Compiling assert-json-diff v2.0.2 [INFO] [stderr] Compiling tempfile v3.27.0 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling bstr v1.12.1 [INFO] [stderr] Compiling tracing-subscriber v0.3.23 [INFO] [stderr] Compiling predicates v3.1.4 [INFO] [stderr] Compiling futures-executor v0.3.32 [INFO] [stderr] Compiling futures v0.3.32 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling tokio-stream v0.1.18 [INFO] [stderr] Compiling deadpool v0.12.3 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling tokio-test v0.4.5 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling wiremock v0.6.5 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling synoplayer v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: function `test_track` is never used [INFO] [stdout] --> src/player/engine.rs:437:8 [INFO] [stdout] | [INFO] [stdout] 437 | fn test_track() -> TrackInfo { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 45.69s [INFO] running `Command { std: "docker" "inspect" "5363a6cc265d9db96dbc32c52b486be6a85aab35bd44f203ac75dfd588547149", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5363a6cc265d9db96dbc32c52b486be6a85aab35bd44f203ac75dfd588547149", kill_on_drop: false }` [INFO] [stdout] 5363a6cc265d9db96dbc32c52b486be6a85aab35bd44f203ac75dfd588547149 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 27082b1bcd840fe671d2bb0cfd907f24f745d0452783fb81a487deb4752bd2fb [INFO] running `Command { std: "docker" "start" "-a" "27082b1bcd840fe671d2bb0cfd907f24f745d0452783fb81a487deb4752bd2fb", kill_on_drop: false }` [INFO] [stderr] warning: function `test_track` is never used [INFO] [stderr] --> src/player/engine.rs:437:8 [INFO] [stderr] | [INFO] [stderr] 437 | fn test_track() -> TrackInfo { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: `synoplayer` (lib test) generated 1 warning [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.49s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/synoplayer-bdc4ffe7025d6cf3) [INFO] [stdout] [INFO] [stdout] running 149 tests [INFO] [stdout] test api::album::tests::list_albums_parses_response ... ok [INFO] [stdout] test api::client::tests::new_client_is_not_authenticated ... ok [INFO] [stdout] test api::client::tests::set_and_clear_sid ... ok [INFO] [stdout] test api::auth::tests::login_returns_2fa_required ... ok [INFO] [stdout] test api::client::tests::build_url_with_discovered_path ... ok [INFO] [stdout] test api::client::tests::request_success_parses_data ... ok [INFO] [stdout] test api::artist::tests::list_artists_parses_response ... ok [INFO] [stdout] test api::auth::tests::discover_populates_api_paths ... ok [INFO] [stdout] test api::client::tests::build_url_fallback_for_known_apis ... ok [INFO] [stdout] test api::auth::tests::login_sets_sid_on_success ... ok [INFO] [stdout] test api::auth::tests::login_returns_error_on_wrong_password ... ok [INFO] [stdout] test api::client::tests::base_url_strips_trailing_slash ... ok [INFO] [stdout] test api::composer::tests::list_composers_parses_response ... ok [INFO] [stdout] test api::client::tests::request_session_expired_returns_session_error ... ok [INFO] [stdout] test api::client::tests::build_url_unknown_api_fails ... ok [INFO] [stdout] test api::client::tests::request_error_returns_syno_error ... ok [INFO] [stdout] test api::cover::tests::cover_url_contains_song_id ... ok [INFO] [stdout] test api::auth::tests::logout_clears_sid ... ok [INFO] [stdout] test api::folder::tests::list_subfolder ... ok [INFO] [stdout] test api::favorites::tests::list_returns_songs_from_playlist ... ok [INFO] [stdout] test api::folder::tests::list_root_folders ... ok [INFO] [stdout] test api::pin::tests::list_returns_total_count ... ok [INFO] [stdout] test api::playlist::tests::create_playlist_sends_name ... ok [INFO] [stdout] test api::favorites::tests::list_returns_empty_when_no_playlist ... ok [INFO] [stdout] test api::pin::tests::list_pinned_items ... ok [INFO] [stdout] test api::playlist::tests::delete_playlist_sends_id ... ok [INFO] [stdout] test api::pin::tests::unpin_sends_id ... ok [INFO] [stdout] test api::pin::tests::list_parses_item_types ... ok [INFO] [stdout] test api::playlist::tests::list_playlists_parses_response ... ok [INFO] [stdout] test api::genre::tests::list_genres_parses_response ... ok [INFO] [stdout] test api::playlist::tests::update_songs_deletes_and_recreates ... ok [INFO] [stdout] test api::playlist::tests::get_playlist_info_returns_songs ... ok [INFO] [stdout] test api::lyrics::tests::get_lyrics_parses_text ... ok [INFO] [stdout] test api::pin::tests::pin_sends_id ... ok [INFO] [stdout] test cache::manager::tests::cleanup_expired_removes_old_entries ... ok [INFO] [stdout] test cache::manager::tests::clear_older_than_days_removes_old_entries ... ok [INFO] [stdout] test cache::manager::tests::clear_removes_all ... ok [INFO] [stdout] test cache::manager::tests::disabled_cache_does_not_store ... ok [INFO] [stdout] test cache::manager::tests::file_path_returns_local_path ... ok [INFO] [stdout] test cache::manager::tests::get_entry_meta_returns_none_for_missing ... ok [INFO] [stdout] test cache::manager::tests::integrity_check_detects_corruption ... ok [INFO] [stdout] test cache::manager::tests::get_entry_meta_returns_stored_metadata ... ok [INFO] [stdout] test cache::manager::tests::list_entries_returns_all_cached ... ok [INFO] [stdout] test cache::manager::tests::miss_returns_none ... ok [INFO] [stdout] test cache::manager::tests::put_with_meta_stores_song_metadata ... ok [INFO] [stdout] test cache::manager::tests::put_without_meta_has_empty_metadata_fields ... ok [INFO] [stdout] test cache::manager::tests::status_reports_correct_stats ... ok [INFO] [stdout] test cache::manager::tests::store_and_retrieve ... ok [INFO] [stdout] test cache::storage::tests::content_hash_detects_changes ... ok [INFO] [stdout] test cache::storage::tests::delete_removes_file ... ok [INFO] [stdout] test api::radio::tests::add_radio_station_sends_params ... ok [INFO] [stdout] test cache::storage::tests::file_count_counts_audio_files ... ok [INFO] [stdout] test cache::storage::tests::hash_id_differs_for_different_ids ... ok [INFO] [stdout] test cache::storage::tests::hash_id_is_deterministic ... ok [INFO] [stdout] test cache::storage::tests::read_nonexistent_returns_error ... ok [INFO] [stdout] test cache::storage::tests::total_size_sums_files ... ok [INFO] [stdout] test cache::storage::tests::write_and_read_roundtrip ... ok [INFO] [stdout] test config::model::tests::base_url_http ... ok [INFO] [stdout] test api::radio::tests::list_radio_stations ... ok [INFO] [stdout] test config::model::tests::base_url_https ... ok [INFO] [stdout] test config::model::tests::defaults_when_optional_missing ... ok [INFO] [stdout] test config::model::tests::empty_string_parses_to_defaults ... ok [INFO] [stdout] test config::model::tests::serialize_roundtrip ... ok [INFO] [stdout] test config::model::tests::parse_full_config ... ok [INFO] [stdout] test credentials::store::tests::base64_roundtrip ... ok [INFO] [stdout] test credentials::store::tests::encrypted_file_clear ... ok [INFO] [stdout] test credentials::store::tests::encrypted_file_overwrite ... ok [INFO] [stdout] test credentials::store::tests::encrypted_file_save_and_load ... ok [INFO] [stdout] test credentials::store::tests::exists_returns_false_when_empty ... ok [INFO] [stdout] test credentials::store::tests::load_from_nonexistent_returns_none ... ok [INFO] [stdout] test api::playlist::tests::rename_playlist_sends_params ... ok [INFO] [stdout] test cache::storage::tests::exists_returns_true_after_write ... ok [INFO] [stdout] test history::tests::clear_removes_all ... ok [INFO] [stdout] test history::tests::empty_history_returns_empty ... ok [INFO] [stdout] test credentials::store::tests::base64_unicode_roundtrip ... ok [INFO] [stdout] test history::tests::add_and_list ... ok [INFO] [stdout] test ipc::client::tests::send_to_nonexistent_socket_fails ... ok [INFO] [stdout] test ipc::protocol::tests::error_response ... ok [INFO] [stdout] test ipc::protocol::tests::malformed_json_fails ... ok [INFO] [stdout] test ipc::protocol::tests::request_serialize_roundtrip ... ok [INFO] [stdout] test ipc::protocol::tests::response_ok_without_data ... ok [INFO] [stdout] test history::tests::entries_persist_across_instances ... ok [INFO] [stdout] test ipc::protocol::tests::response_with_now_playing ... ok [INFO] [stdout] test history::tests::max_entries_trims_oldest ... ok [INFO] [stdout] test ipc::server::tests::server_handles_malformed_json ... ok [INFO] [stdout] test ipc::tests::check_existing_socket_nonexistent ... ok [INFO] [stdout] test ipc::tests::check_existing_socket_stale ... ok [INFO] [stdout] test ipc::tests::socket_guard_removes_file ... ok [INFO] [stdout] test ipc::tests::socket_path_is_absolute ... ok [INFO] [stdout] test playback::tests::format_duration_minutes_seconds ... ok [INFO] [stdout] test playback::tests::format_duration_zero ... ok [INFO] [stdout] test history::tests::list_respects_limit ... ok [INFO] [stdout] test ipc::protocol::tests::response_with_queue_list ... ok [INFO] [stdout] test ipc::server::tests::server_start_and_connect ... ok [INFO] [stdout] test playback::tests::song_meta_extracts_tag_fields ... ok [INFO] [stdout] test playback::tests::track_from_song_with_metadata ... ok [INFO] [stdout] test playback::tests::track_from_song_without_additional ... ok [INFO] [stdout] test player::engine::tests::default_volume_is_80 ... ok [INFO] [stdout] test player::engine::tests::new_engine_is_stopped ... ok [INFO] [stdout] test player::engine::tests::stop_from_stopped_is_noop ... ok [INFO] [stdout] test api::song::tests::set_rating_sends_correct_params ... ok [INFO] [stdout] test player::queue::tests::clear_empties_queue ... ok [INFO] [stdout] test player::queue::tests::add_and_current ... ok [INFO] [stdout] test player::engine::tests::which_exists_finds_sh ... ok [INFO] [stdout] test player::engine::tests::which_exists_fails_for_nonexistent ... ok [INFO] [stdout] test player::queue::tests::from_songs_sets_current_to_first ... ok [INFO] [stdout] test player::queue::tests::new_queue_is_empty ... ok [INFO] [stdout] test player::queue::tests::next_advances ... ok [INFO] [stdout] test player::engine::tests::set_volume_clamps_to_100 ... ok [INFO] [stdout] test player::queue::tests::next_at_end_returns_false ... ok [INFO] [stdout] test player::queue::tests::prev_at_start_returns_false ... ok [INFO] [stdout] test player::queue::tests::prev_goes_back ... ok [INFO] [stdout] test player::queue::tests::prev_on_empty_returns_false ... ok [INFO] [stdout] test player::queue::tests::remove_adjusts_index ... ok [INFO] [stdout] test player::queue::tests::remove_current_adjusts ... ok [INFO] [stdout] test player::queue::tests::remove_last_when_current_adjusts ... ok [INFO] [stdout] test player::queue::tests::repeat_all_prev_wraps_around ... ok [INFO] [stdout] test api::stream::tests::stream_url_fails_without_auth ... ok [INFO] [stdout] test player::queue::tests::repeat_all_wraps_around ... ok [INFO] [stdout] test player::queue::tests::repeat_one_stays_on_track ... ok [INFO] [stdout] test player::queue::tests::from_empty_songs_has_no_current ... ok [INFO] [stdout] test player::queue::tests::shuffle_keeps_current_at_front ... ok [INFO] [stdout] test player::queue::tests::shuffle_preserves_all_songs ... ok [INFO] [stdout] test player::state::tests::initial_state_is_stopped ... ok [INFO] [stdout] test player::state::tests::pause_from_playing ... ok [INFO] [stdout] test player::state::tests::pause_from_stopped_does_nothing ... ok [INFO] [stdout] test player::state::tests::play_creates_playing_state ... ok [INFO] [stdout] test player::state::tests::resume_from_paused ... ok [INFO] [stdout] test player::state::tests::resume_from_stopped_does_nothing ... ok [INFO] [stdout] test player::state::tests::stop_from_paused ... ok [INFO] [stdout] test player::state::tests::stop_from_playing ... ok [INFO] [stdout] test player::state::tests::track_info_accessible_in_playing_and_paused ... ok [INFO] [stdout] test tui::app::tests::now_playing_progress ... ok [INFO] [stdout] test tui::app::tests::now_playing_zero_duration ... ok [INFO] [stdout] test tui::app::tests::stateful_list_empty ... ok [INFO] [stdout] test tui::app::tests::stateful_list_next_previous ... ok [INFO] [stdout] test tui::app::tests::stateful_list_page_navigation ... ok [INFO] [stdout] test tui::app::tests::tab_switching ... ok [INFO] [stdout] test player::queue::tests::next_on_empty_returns_false ... ok [INFO] [stdout] test cache::manager::tests::lru_eviction_removes_oldest ... ok [INFO] [stdout] test api::song::tests::get_info_returns_song_with_rating ... ok [INFO] [stdout] test api::song::tests::list_includes_rating_in_additional ... ok [INFO] [stdout] test api::song::tests::list_songs_parses_response ... ok [INFO] [stdout] test api::search::tests::search_returns_songs_albums_artists ... ok [INFO] [stdout] test api::song::tests::clear_rating_sends_zero ... ok [INFO] [stdout] test api::song::tests::search_songs_sends_keyword ... ok [INFO] [stdout] test api::stream::tests::stream_url_contains_song_id_and_sid ... ok [INFO] [stdout] test api::stream::tests::transcode_url_uses_transcode_method ... ok [INFO] [stdout] test api::stream::tests::stream_bytes_returns_audio_data ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 149 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 2.32s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/synoplayer-aca5558d20210df7) [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/api_parsing.rs (/opt/rustwide/target/debug/deps/api_parsing-796261c21191480d) [INFO] [stdout] [INFO] [stdout] running 13 tests [INFO] [stdout] test parse_album_list_response ... ok [INFO] [stdout] test parse_auth_login_2fa ... ok [INFO] [stdout] test parse_auth_login_success ... ok [INFO] [stdout] test parse_auth_login_wrong_password ... ok [INFO] [stdout] test parse_error_session_expired ... ok [INFO] [stdout] test parse_playlist_list_response ... ok [INFO] [stdout] test pin_item_display_name_prefers_name_over_title ... ok [INFO] [stdout] test parse_song_list_response ... ok [INFO] [stdout] test parse_song_rating_range ... ok [INFO] [stdout] test parse_api_info_response ... ok [INFO] [stdout] test parse_pin_list_response ... ok [INFO] [stdout] test error_code_mapping ... ok [INFO] [stdout] test parse_error_no_permission ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 13 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.05s [INFO] [stdout] [INFO] [stderr] Running tests/cli_integration.rs (/opt/rustwide/target/debug/deps/cli_integration-668418e19c876d4b) [INFO] [stdout] [INFO] [stdout] running 18 tests [INFO] [stdout] test cli_download_help ... ok [INFO] [stdout] test cli_playlist_play_help_shows_repeat ... ok [INFO] [stdout] test cli_help_shows_usage ... ok [INFO] [stdout] test cli_history_help ... ok [INFO] [stdout] test cli_unknown_command_fails ... ok [INFO] [stdout] test cli_config_show_works ... ok [INFO] [stdout] test cli_no_tui_is_valid_subcommand ... ok [INFO] [stdout] test cli_history_no_args_works ... ok [INFO] [stdout] test cli_cache_status_works ... ok [INFO] [stdout] test cli_rate_requires_args ... ok [INFO] [stdout] test cli_rate_help ... ok [INFO] [stdout] test cli_version_shows_version ... ok [INFO] [stdout] test cli_favorites_help ... ok [INFO] [stdout] test cli_tui_help ... ok [INFO] [stdout] test cli_help_lists_tui_command ... ok [INFO] [stdout] test cli_download_without_args_tries_current_track ... ok [INFO] [stdout] test cli_unfavorite_without_args_tries_current_track ... ok [INFO] [stdout] test cli_favorite_without_args_tries_current_track ... ok [INFO] [stderr] Doc-tests synoplayer [INFO] [stdout] [INFO] [stdout] test result: ok. 18 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.12s [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] running `Command { std: "docker" "inspect" "27082b1bcd840fe671d2bb0cfd907f24f745d0452783fb81a487deb4752bd2fb", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "27082b1bcd840fe671d2bb0cfd907f24f745d0452783fb81a487deb4752bd2fb", kill_on_drop: false }` [INFO] [stdout] 27082b1bcd840fe671d2bb0cfd907f24f745d0452783fb81a487deb4752bd2fb