[INFO] cloning repository https://github.com/imaviso/subsonic [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/imaviso/subsonic" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fimaviso%2Fsubsonic", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fimaviso%2Fsubsonic'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 89d2e3a8b64bca11342b9ec4bfabf88fc5d75bae [INFO] testing imaviso/subsonic against master#f9988fefd3add01f414f52b414308e7872622fee for pr-155114 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fimaviso%2Fsubsonic" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/imaviso/subsonic [INFO] finished tweaking git repo https://github.com/imaviso/subsonic [INFO] tweaked toml for git repo https://github.com/imaviso/subsonic written to /workspace/builds/worker-4-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/imaviso/subsonic 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/imaviso/subsonic 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] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded selectors v0.33.0 [INFO] [stderr] Downloaded serde_json v1.0.146 [INFO] [stderr] Downloaded scraper v0.25.0 [INFO] [stderr] Downloaded compression-codecs v0.4.37 [INFO] [stderr] Downloaded mimalloc v0.1.48 [INFO] [stderr] Downloaded ogg_pager v0.7.0 [INFO] [stderr] Downloaded libredox v0.1.11 [INFO] [stderr] Downloaded dsl_auto_type v0.2.0 [INFO] [stderr] Downloaded async-compression v0.4.41 [INFO] [stderr] Downloaded lofty_attr v0.11.1 [INFO] [stderr] Downloaded scheduled-thread-pool v0.2.7 [INFO] [stderr] Downloaded diesel_table_macro_syntax v0.3.0 [INFO] [stderr] Downloaded r2d2 v0.8.10 [INFO] [stderr] Downloaded webpki-root-certs v1.0.5 [INFO] [stderr] Downloaded reqwest v0.13.1 [INFO] [stderr] Downloaded zerocopy-derive v0.8.37 [INFO] [stderr] Downloaded diesel_derives v2.3.6 [INFO] [stderr] Downloaded zerocopy v0.8.37 [INFO] [stderr] Downloaded lofty v0.22.4 [INFO] [stderr] Downloaded libmimalloc-sys v0.1.44 [INFO] [stderr] Downloaded diesel v2.3.5 [INFO] [stderr] Downloaded aws-lc-sys v0.37.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 303d5d1f1f692617f1d1e9242c19422514de1c3a7b8112ce8c9966874502f805 [INFO] running `Command { std: "docker" "start" "-a" "303d5d1f1f692617f1d1e9242c19422514de1c3a7b8112ce8c9966874502f805", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "303d5d1f1f692617f1d1e9242c19422514de1c3a7b8112ce8c9966874502f805", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "303d5d1f1f692617f1d1e9242c19422514de1c3a7b8112ce8c9966874502f805", kill_on_drop: false }` [INFO] [stdout] 303d5d1f1f692617f1d1e9242c19422514de1c3a7b8112ce8c9966874502f805 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 90dcb663ffad55969014eeb0e1d5ec41efe9665239c7655251ada5e919859732 [INFO] running `Command { std: "docker" "start" "-a" "90dcb663ffad55969014eeb0e1d5ec41efe9665239c7655251ada5e919859732", kill_on_drop: false }` [INFO] [stderr] Compiling syn v2.0.111 [INFO] [stderr] Compiling find-msvc-tools v0.1.5 [INFO] [stderr] Compiling stable_deref_trait v1.2.1 [INFO] [stderr] Compiling itoa v1.0.16 [INFO] [stderr] Compiling siphasher v1.0.2 [INFO] [stderr] Compiling fastrand v2.3.0 [INFO] [stderr] Compiling dunce v1.0.5 [INFO] [stderr] Compiling fs_extra v1.3.0 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Compiling socket2 v0.6.1 [INFO] [stderr] Compiling signal-hook-registry v1.4.7 [INFO] [stderr] Compiling aws-lc-rs v1.15.4 [INFO] [stderr] Compiling zstd-safe v7.2.4 [INFO] [stderr] Compiling simd-adler32 v0.3.8 [INFO] [stderr] Compiling rustls v0.23.36 [INFO] [stderr] Compiling brotli-decompressor v5.0.0 [INFO] [stderr] Compiling compression-core v0.4.31 [INFO] [stderr] Compiling http v1.4.0 [INFO] [stderr] Compiling serde_json v1.0.146 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling cc v1.2.50 [INFO] [stderr] Compiling phf_shared v0.13.1 [INFO] [stderr] Compiling dtoa v1.0.11 [INFO] [stderr] Compiling ryu v1.0.21 [INFO] [stderr] Compiling getrandom v0.2.16 [INFO] [stderr] Compiling regex-syntax v0.8.8 [INFO] [stderr] Compiling openssl-probe v0.2.1 [INFO] [stderr] Compiling diesel_derives v2.3.6 [INFO] [stderr] Compiling rayon-core v1.13.0 [INFO] [stderr] Compiling dtoa-short v0.3.5 [INFO] [stderr] Compiling either v1.15.0 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling rustls-native-certs v0.8.3 [INFO] [stderr] Compiling servo_arc v0.4.3 [INFO] [stderr] Compiling scheduled-thread-pool v0.2.7 [INFO] [stderr] Compiling base64ct v1.8.1 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling phf_generator v0.13.1 [INFO] [stderr] Compiling string_cache v0.9.0 [INFO] [stderr] Compiling rustc-hash v2.1.1 [INFO] [stderr] Compiling ogg_pager v0.7.0 [INFO] [stderr] Compiling phf_codegen v0.13.1 [INFO] [stderr] Compiling string_cache_codegen v0.6.1 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling password-hash v0.5.0 [INFO] [stderr] Compiling r2d2 v0.8.10 [INFO] [stderr] Compiling blake2 v0.10.6 [INFO] [stderr] Compiling flate2 v1.1.5 [INFO] [stderr] Compiling selectors v0.33.0 [INFO] [stderr] Compiling ego-tree v0.10.0 [INFO] [stderr] Compiling cmake v0.1.57 [INFO] [stderr] Compiling downcast-rs v2.0.2 [INFO] [stderr] Compiling matchit v0.8.4 [INFO] [stderr] Compiling data-encoding v2.9.0 [INFO] [stderr] Compiling brotli v8.0.2 [INFO] [stderr] Compiling argon2 v0.5.3 [INFO] [stderr] Compiling web_atoms v0.2.3 [INFO] [stderr] Compiling rayon v1.11.0 [INFO] [stderr] Compiling dirs v6.0.0 [INFO] [stderr] Compiling md-5 v0.10.6 [INFO] [stderr] Compiling urlencoding v2.1.3 [INFO] [stderr] Compiling aws-lc-sys v0.37.0 [INFO] [stderr] Compiling zstd-sys v2.0.16+zstd.1.5.7 [INFO] [stderr] Compiling libsqlite3-sys v0.35.0 [INFO] [stderr] Compiling libmimalloc-sys v0.1.44 [INFO] [stderr] Compiling regex-automata v0.4.13 [INFO] [stderr] Compiling mimalloc v0.1.48 [INFO] [stderr] Compiling serde_path_to_error v0.1.20 [INFO] [stderr] Compiling matchers v0.2.0 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling darling_core v0.21.3 [INFO] [stderr] Compiling diesel_table_macro_syntax v0.3.0 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling phf_macros v0.13.1 [INFO] [stderr] Compiling cssparser-macros v0.6.1 [INFO] [stderr] Compiling derive_more-impl v2.1.1 [INFO] [stderr] Compiling thiserror-impl v2.0.17 [INFO] [stderr] Compiling lofty_attr v0.11.1 [INFO] [stderr] Compiling zstd v0.13.3 [INFO] [stderr] Compiling clap_derive v4.5.49 [INFO] [stderr] Compiling phf v0.13.1 [INFO] [stderr] Compiling tokio v1.48.0 [INFO] [stderr] Compiling compression-codecs v0.4.37 [INFO] [stderr] Compiling cssparser v0.36.0 [INFO] [stderr] Compiling lofty v0.22.4 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling derive_more v2.1.1 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling markup5ever v0.36.1 [INFO] [stderr] Compiling axum-core v0.5.5 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling html5ever v0.36.1 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling darling_macro v0.21.3 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling thiserror v2.0.17 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling darling v0.21.3 [INFO] [stderr] Compiling dsl_auto_type v0.2.0 [INFO] [stderr] Compiling clap v4.5.53 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling scraper v0.25.0 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling chrono v0.4.42 [INFO] [stderr] Compiling quick-xml v0.38.4 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling tokio-util v0.7.17 [INFO] [stderr] Compiling tower v0.5.2 [INFO] [stderr] Compiling async-compression v0.4.41 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling diesel v2.3.5 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling hyper-util v0.1.19 [INFO] [stderr] Compiling rustls-webpki v0.103.9 [INFO] [stderr] Compiling axum v0.8.8 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling rustls-platform-verifier v0.6.2 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling reqwest v0.13.1 [INFO] [stderr] Compiling suboxide v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 13s [INFO] running `Command { std: "docker" "inspect" "90dcb663ffad55969014eeb0e1d5ec41efe9665239c7655251ada5e919859732", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "90dcb663ffad55969014eeb0e1d5ec41efe9665239c7655251ada5e919859732", kill_on_drop: false }` [INFO] [stdout] 90dcb663ffad55969014eeb0e1d5ec41efe9665239c7655251ada5e919859732 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 322e178922a5d776c38aa8c0f6243dbc031d186c6e19da2246ca3cb5d36a0ad9 [INFO] running `Command { std: "docker" "start" "-a" "322e178922a5d776c38aa8c0f6243dbc031d186c6e19da2246ca3cb5d36a0ad9", kill_on_drop: false }` [INFO] [stderr] Compiling suboxide v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 24.54s [INFO] running `Command { std: "docker" "inspect" "322e178922a5d776c38aa8c0f6243dbc031d186c6e19da2246ca3cb5d36a0ad9", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "322e178922a5d776c38aa8c0f6243dbc031d186c6e19da2246ca3cb5d36a0ad9", kill_on_drop: false }` [INFO] [stdout] 322e178922a5d776c38aa8c0f6243dbc031d186c6e19da2246ca3cb5d36a0ad9 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 4e7820b5bad4d725daea209022c56926f3da8b69a3652eb4feb7993602964720 [INFO] running `Command { std: "docker" "start" "-a" "4e7820b5bad4d725daea209022c56926f3da8b69a3652eb4feb7993602964720", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.47s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/suboxide-65f465b26e9f0943) [INFO] [stdout] [INFO] [stdout] running 80 tests [INFO] [stdout] test api::auth::tests::invalid_hex_password_returns_none ... ok [INFO] [stdout] test api::error::tests::api_error_codes_match_subsonic_contract ... ok [INFO] [stdout] test api::auth::tests::params_with_fallback_fills_missing_fields ... ok [INFO] [stdout] test api::error::tests::api_error_messages_include_variant_context ... ok [INFO] [stdout] test api::auth::tests::test_hex_encoded_password ... ok [INFO] [stdout] test api::auth::tests::params_with_fallback_preserves_query_auth_fields_and_fills_missing_form_fields ... ok [INFO] [stdout] test api::handlers::browsing::indexes::tests::artist_index_key_groups_non_alphabetic_and_empty_names_under_hash ... ok [INFO] [stdout] test api::handlers::browsing::indexes::tests::artist_index_key_prefers_sort_name_and_uppercases_first_letter ... ok [INFO] [stdout] test api::handlers::browsing::lists::tests::defaults_missing_album_list_type_to_alphabetical_by_name ... ok [INFO] [stdout] test api::handlers::browsing::lists::tests::preserves_supported_album_list_types ... ok [INFO] [stdout] test api::handlers::browsing::lists::tests::similar_songs_seed_requires_exactly_one_seed ... ok [INFO] [stdout] test api::handlers::browsing::lists::tests::similar_songs_seed_preserves_selected_seed_id ... ok [INFO] [stdout] test api::handlers::browsing::lists::tests::supports_all_album_list_alias ... ok [INFO] [stdout] test api::handlers::browsing::search::tests::search_limits_trim_wrapping_quotes_and_outer_whitespace ... ok [INFO] [stdout] test api::handlers::browsing::search::tests::search_limits_clamp_counts_and_offsets_deterministically ... ok [INFO] [stdout] test api::handlers::media::tests::byte_range_parser_accepts_open_and_closed_ranges ... ok [INFO] [stdout] test api::handlers::media::tests::byte_range_parser_rejects_invalid_or_unsatisfiable_ranges ... ok [INFO] [stdout] test api::handlers::media::tests::safe_cover_art_id_rejects_paths_traversal_dots_and_extensions ... ok [INFO] [stdout] test api::handlers::media::tests::sanitized_filename_removes_content_disposition_breakout_characters ... ok [INFO] [stdout] test api::handlers::media::tests::cover_art_content_type_matches_supported_extensions ... ok [INFO] [stdout] test api::handlers::remote::tests::map_command_preserves_payload_source_and_timestamp ... ok [INFO] [stdout] test api::handlers::remote::tests::map_state_preserves_json_device_and_timestamp ... ok [INFO] [stdout] test api::handlers::media::tests::safe_cover_art_id_allows_content_hash_like_values ... ok [INFO] [stdout] test api::response::tests::format_from_param_accepts_only_json_like_formats ... ok [INFO] [stdout] test api::response::tests::json_named_nests_payload_and_transforms_subsonic_attribute_keys ... ok [INFO] [stdout] test api::response::tests::json_error_contains_failed_status_code_and_message ... ok [INFO] [stdout] test app::tests::cors_origins_from_str_trims_and_ignores_empty_segments ... ok [INFO] [stdout] test api::response::tests::transform_json_keys_rejects_invalid_json ... ok [INFO] [stdout] test app::tests::cors_origins_from_str_rejects_invalid_header_values ... ok [INFO] [stdout] test crypto::password::tests::invalid_hash_error_includes_parse_context ... ok [INFO] [stdout] test crypto::password::tests::test_invalid_hash_format ... ok [INFO] [stdout] test db::connection::tests::invalid_pool_configuration_returns_typed_error ... ok [INFO] [stdout] test api::response::tests::transform_json_keys_recurses_through_objects_and_arrays ... ok [INFO] [stdout] test db::repo::error::tests::music_repo_error_without_source_is_deterministic ... ok [INFO] [stdout] test api::response::tests::supported_extensions_are_stable_and_sorted_by_contract ... ok [INFO] [stdout] test api::response::tests::json_empty_contains_success_envelope_metadata ... ok [INFO] [stdout] test lastfm::client::tests::new_returns_disabled_when_credentials_are_empty ... ok [INFO] [stdout] test models::music::directory_tests::child_response_from_album_as_dir_pins_album_metadata ... ok [INFO] [stdout] test api::handlers::remote::tests::map_session_includes_pairing_code_only_when_requested_and_marks_connected ... ok [INFO] [stdout] test db::connection::tests::test_default_config ... ok [INFO] [stdout] test models::music::directory_tests::child_response_from_artist_as_dir_pins_directory_fields ... ok [INFO] [stdout] test models::music::directory_tests::directory_response_from_album_uses_artist_parent_and_play_count ... ok [INFO] [stdout] test models::music::directory_tests::directory_response_from_music_folder_uses_folder_as_root ... ok [INFO] [stdout] test models::music::lyric_tests::lyric_line_constructors_preserve_sync_state ... ok [INFO] [stdout] test db::repo::error::tests::user_repo_error_preserves_kind_message_and_source ... ok [INFO] [stdout] test models::user::tests::verify_token_accepts_expected_md5_password_plus_salt_case_insensitively ... ok [INFO] [stdout] test models::user::tests::verify_token_rejects_wrong_token_salt_and_missing_plaintext_password ... ok [INFO] [stdout] test models::user::tests::verify_password_returns_err_for_malformed_hash ... ok [INFO] [stdout] test paths::tests::cover_art_dir_from_data_dir_uses_stable_covers_subdirectory ... ok [INFO] [stdout] test models::music::lyric_tests::structured_lyrics_builders_preserve_lang_sync_lines_and_metadata ... ok [INFO] [stdout] test scanner::engine::tests::file_modified_at_preserves_valid_seconds ... ok [INFO] [stdout] test scanner::engine::tests::file_modified_at_saturates_u64_overflow_to_i64_max ... ok [INFO] [stdout] test models::music::lyric_tests::unsynced_structured_lyrics_omit_line_start_times ... ok [INFO] [stdout] test models::music::tests::saturating_i64_to_i32_passes_through_in_range ... ok [INFO] [stdout] test scanner::engine::tests::image_mime_from_ext_defaults_unknown_and_jpeg_to_jpeg ... ok [INFO] [stdout] test scanner::engine::tests::image_mime_from_ext_maps_supported_cover_extensions ... ok [INFO] [stdout] test scanner::engine::tests::split_discovered_files_keeps_all_in_full_mode ... ok [INFO] [stdout] test scanner::engine::tests::split_discovered_files_skips_unchanged_in_incremental_mode ... ok [INFO] [stdout] test scanner::lyrics::tests::parse_lrc_expands_multiple_timestamps_and_sorts_output ... ok [INFO] [stdout] test scanner::lyrics::tests::test_looks_like_lrc ... ok [INFO] [stdout] test scanner::lyrics::tests::test_parse_lrc ... ok [INFO] [stdout] test scanner::lyrics::tests::test_parse_lrc_timestamp ... ok [INFO] [stdout] test scanner::state::tests::scan_phase_strings_are_stable_api_values ... ok [INFO] [stdout] test scanner::state::tests::scan_state_guard_resets_and_finishes_on_drop ... ok [INFO] [stdout] test scanner::lyrics::tests::parse_lrc_ignores_metadata_and_invalid_timestamp_lines ... ok [INFO] [stdout] test scanner::state::tests::scan_state_guard_acquisition_resets_previous_progress ... ok [INFO] [stdout] test scanner::state::tests::scan_state_handle_guard_can_move_to_background_thread ... ok [INFO] [stdout] test scanner::lyrics::tests::parse_unsynced_trims_and_drops_empty_lines ... ok [INFO] [stdout] test models::music::lyric_tests::lyrics_list_response_preserves_empty_and_non_empty_payloads ... ok [INFO] [stdout] test models::music::tests::saturating_i64_to_i32_clamps_negative_overflow ... ok [INFO] [stdout] test scanner::state::tests::scan_state_tracks_progress_until_guard_drop ... ok [INFO] [stdout] test api::response::tests::supported_extensions_do_not_advertise_form_post ... ok [INFO] [stdout] test api::auth::tests::test_api_key_detection ... ok [INFO] [stdout] test db::connection::tests::test_in_memory_pool ... ok [INFO] [stdout] test models::music::tests::saturating_i64_to_i32_clamps_positive_overflow ... ok [INFO] [stdout] test lastfm::client::tests::client_clone_shares_same_inner_state ... ok [INFO] [stdout] test crypto::password::tests::test_hash_password ... ok [INFO] [stdout] test crypto::password::tests::test_different_passwords_different_hashes ... ok [INFO] [stdout] test crypto::password::tests::test_verify_correct_password ... ok [INFO] [stdout] test crypto::password::tests::test_verify_wrong_password ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 80 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 3.93s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/suboxide-2aa22e1ecd6dd882) [INFO] [stdout] [INFO] [stdout] running 5 tests [INFO] [stdout] test tests::format_elapsed_renders_mm_ss ... ok [INFO] [stdout] test tests::format_scan_progress_includes_elapsed_time ... ok [INFO] [stdout] test tests::progress_bar_fills_proportionally_and_clamps_overflow ... ok [INFO] [stdout] test tests::progress_bar_handles_zero_total_and_width ... ok [INFO] [stdout] test tests::spinner_frame_cycles_deterministically ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 5 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.03s [INFO] [stdout] [INFO] [stderr] Doc-tests suboxide [INFO] [stdout] [INFO] [stdout] running 5 tests [INFO] [stdout] test src/api/auth.rs - api::auth::SubsonicAuth (line 180) ... ignored [INFO] [stdout] test src/api/router.rs - api::router::SubsonicRouterExt::subsonic_route (line 20) ... ignored [INFO] [stdout] test src/api/router.rs - api::router::SubsonicRouterExt::subsonic_route (line 27) ... ignored [INFO] [stdout] test src/crypto/password.rs - crypto::password::hash_password (line 84) ... ok [INFO] [stdout] test src/crypto/password.rs - crypto::password::verify_password (line 116) ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 2 passed; 0 failed; 3 ignored; 0 measured; 0 filtered out; finished in 3.31s [INFO] [stdout] [INFO] [stdout] all doctests ran in 5.45s; merged doctests compilation took 1.75s [INFO] running `Command { std: "docker" "inspect" "4e7820b5bad4d725daea209022c56926f3da8b69a3652eb4feb7993602964720", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4e7820b5bad4d725daea209022c56926f3da8b69a3652eb4feb7993602964720", kill_on_drop: false }` [INFO] [stdout] 4e7820b5bad4d725daea209022c56926f3da8b69a3652eb4feb7993602964720