[INFO] cloning repository https://github.com/l5yth/podserv-b [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/l5yth/podserv-b" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fl5yth%2Fpodserv-b", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fl5yth%2Fpodserv-b'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 58d6a043345ea65e2252aef3c2b87f225eab4417 [INFO] testing l5yth/podserv-b against try#8da20828b6ea601dfd8e2448cb50ace88876bd78 for pr-150933 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fl5yth%2Fpodserv-b" "/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/l5yth/podserv-b [INFO] finished tweaking git repo https://github.com/l5yth/podserv-b [INFO] tweaked toml for git repo https://github.com/l5yth/podserv-b written to /workspace/builds/worker-3-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/l5yth/podserv-b on toolchain 8da20828b6ea601dfd8e2448cb50ace88876bd78 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/l5yth/podserv-b 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" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] dff329263a26663dcae5a9d1b1a955566b39f79cc19f3575c938c4c0568afaca [INFO] running `Command { std: "docker" "start" "-a" "dff329263a26663dcae5a9d1b1a955566b39f79cc19f3575c938c4c0568afaca", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "dff329263a26663dcae5a9d1b1a955566b39f79cc19f3575c938c4c0568afaca", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "dff329263a26663dcae5a9d1b1a955566b39f79cc19f3575c938c4c0568afaca", kill_on_drop: false }` [INFO] [stdout] dff329263a26663dcae5a9d1b1a955566b39f79cc19f3575c938c4c0568afaca [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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] fdec27cc10bc1c2b6acfccce2c1238964000225b0778195a36ea3d60db652fcd [INFO] running `Command { std: "docker" "start" "-a" "fdec27cc10bc1c2b6acfccce2c1238964000225b0778195a36ea3d60db652fcd", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.106 [INFO] [stderr] Compiling unicode-ident v1.0.24 [INFO] [stderr] Compiling pin-project-lite v0.2.17 [INFO] [stderr] Compiling memchr v2.8.0 [INFO] [stderr] Compiling bytes v1.11.1 [INFO] [stderr] Compiling find-msvc-tools v0.1.9 [INFO] [stderr] Compiling futures-channel v0.3.32 [INFO] [stderr] Compiling futures-io v0.3.32 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Compiling errno v0.3.14 [INFO] [stderr] Compiling mio v1.1.1 [INFO] [stderr] Compiling socket2 v0.6.2 [INFO] [stderr] Compiling futures-task v0.3.32 [INFO] [stderr] Compiling bitflags v2.11.0 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling indexmap v2.13.0 [INFO] [stderr] Compiling local-waker v0.1.4 [INFO] [stderr] Compiling unicode-segmentation v1.12.0 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling signal-hook-registry v1.4.8 [INFO] [stderr] Compiling alloc-no-stdlib v2.0.4 [INFO] [stderr] Compiling rand_core v0.9.5 [INFO] [stderr] Compiling zstd-safe v7.2.4 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Compiling simd-adler32 v0.3.8 [INFO] [stderr] Compiling alloc-stdlib v0.2.2 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling rand_chacha v0.9.0 [INFO] [stderr] Compiling convert_case v0.10.0 [INFO] [stderr] Compiling unicode-xid v0.2.6 [INFO] [stderr] Compiling zmij v1.0.21 [INFO] [stderr] Compiling regex-syntax v0.8.10 [INFO] [stderr] Compiling time-core v0.1.8 [INFO] [stderr] Compiling http v0.2.12 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling num-conv v0.2.0 [INFO] [stderr] Compiling regex-lite v0.1.9 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling time-macros v0.2.27 [INFO] [stderr] Compiling bytestring v1.5.0 [INFO] [stderr] Compiling deranged v0.5.8 [INFO] [stderr] Compiling flate2 v1.1.9 [INFO] [stderr] Compiling quote v1.0.44 [INFO] [stderr] Compiling rand v0.9.2 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling brotli-decompressor v5.0.0 [INFO] [stderr] Compiling actix-utils v3.0.1 [INFO] [stderr] Compiling actix-service v2.0.3 [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling cookie v0.16.2 [INFO] [stderr] Compiling sha1 v0.10.6 [INFO] [stderr] Compiling crossbeam-utils v0.8.21 [INFO] [stderr] Compiling local-channel v0.1.5 [INFO] [stderr] Compiling actix-router v0.5.4 [INFO] [stderr] Compiling socket2 v0.5.10 [INFO] [stderr] Compiling encoding_rs v0.8.35 [INFO] [stderr] Compiling ryu v1.0.23 [INFO] [stderr] Compiling language-tags v0.3.2 [INFO] [stderr] Compiling foldhash v0.1.5 [INFO] [stderr] Compiling portable-atomic v1.13.1 [INFO] [stderr] Compiling time v0.3.47 [INFO] [stderr] Compiling unicase v2.9.0 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling raw-cpuid v11.6.0 [INFO] [stderr] Compiling impl-more v0.1.9 [INFO] [stderr] Compiling v_htmlescape v0.15.8 [INFO] [stderr] Compiling brotli v8.0.2 [INFO] [stderr] Compiling mime_guess v2.0.5 [INFO] [stderr] Compiling hashbrown v0.14.5 [INFO] [stderr] Compiling spinning_top v0.3.0 [INFO] [stderr] Compiling futures-timer v3.0.3 [INFO] [stderr] Compiling zstd-sys v2.0.16+zstd.1.5.7 [INFO] [stderr] Compiling nonzero_ext v0.3.0 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling toml_write v0.1.2 [INFO] [stderr] Compiling dashmap v6.1.0 [INFO] [stderr] Compiling clap_lex v1.0.0 [INFO] [stderr] Compiling winnow v0.7.14 [INFO] [stderr] Compiling clap_builder v4.5.60 [INFO] [stderr] Compiling http-range v0.1.5 [INFO] [stderr] Compiling id3 v1.16.4 [INFO] [stderr] Compiling quanta v0.12.6 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling synstructure v0.13.2 [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 serde_derive v1.0.228 [INFO] [stderr] Compiling futures-macro v0.3.32 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling derive_more-impl v2.1.1 [INFO] [stderr] Compiling actix-macros v0.2.4 [INFO] [stderr] Compiling actix-web-codegen v4.3.0 [INFO] [stderr] Compiling clap_derive v4.5.55 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling tokio v1.49.0 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling clap v4.5.60 [INFO] [stderr] Compiling zstd v0.13.3 [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 derive_more v2.1.1 [INFO] [stderr] Compiling futures-executor v0.3.32 [INFO] [stderr] Compiling governor v0.10.4 [INFO] [stderr] Compiling futures v0.3.32 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling serde_spanned v0.6.9 [INFO] [stderr] Compiling toml_datetime v0.6.11 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling toml_edit v0.22.27 [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.18 [INFO] [stderr] Compiling actix-rt v2.11.0 [INFO] [stderr] Compiling actix-server v2.6.0 [INFO] [stderr] Compiling toml v0.8.23 [INFO] [stderr] Compiling actix-codec v0.5.2 [INFO] [stderr] Compiling h2 v0.3.27 [INFO] [stderr] Compiling actix-http v3.12.0 [INFO] [stderr] Compiling actix-web v4.13.0 [INFO] [stderr] Compiling actix-governor v0.10.0 [INFO] [stderr] Compiling actix-files v0.6.10 [INFO] [stderr] Compiling podserv-b v0.1.2 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 19s [INFO] running `Command { std: "docker" "inspect" "fdec27cc10bc1c2b6acfccce2c1238964000225b0778195a36ea3d60db652fcd", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "fdec27cc10bc1c2b6acfccce2c1238964000225b0778195a36ea3d60db652fcd", kill_on_drop: false }` [INFO] [stdout] fdec27cc10bc1c2b6acfccce2c1238964000225b0778195a36ea3d60db652fcd [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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 8ca86821e92f2fef04cbe356167e6ace489e6b292666393896a4bd9ff2fd5004 [INFO] running `Command { std: "docker" "start" "-a" "8ca86821e92f2fef04cbe356167e6ace489e6b292666393896a4bd9ff2fd5004", kill_on_drop: false }` [INFO] [stderr] Compiling podserv-b v0.1.2 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 5.17s [INFO] running `Command { std: "docker" "inspect" "8ca86821e92f2fef04cbe356167e6ace489e6b292666393896a4bd9ff2fd5004", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8ca86821e92f2fef04cbe356167e6ace489e6b292666393896a4bd9ff2fd5004", kill_on_drop: false }` [INFO] [stdout] 8ca86821e92f2fef04cbe356167e6ace489e6b292666393896a4bd9ff2fd5004 [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:cfa559dde23f44738f9990739aaa3487d8df3af37eb5df0572f7cf76004a604a" "/opt/rustwide/cargo-home/bin/cargo" "+8da20828b6ea601dfd8e2448cb50ace88876bd78" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 7c288a8dbc6479fe6905ec4f31be8eb82b7d3fdd235944d695d2b43864d6955e [INFO] running `Command { std: "docker" "start" "-a" "7c288a8dbc6479fe6905ec4f31be8eb82b7d3fdd235944d695d2b43864d6955e", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.24s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/podserv_b-6e2392fbb8c1c4fb) [INFO] [stdout] [INFO] [stdout] running 153 tests [INFO] [stdout] test config::tests::author_override ... ok [INFO] [stdout] test config::tests::base_url_defaults_to_website ... ok [INFO] [stdout] test config::tests::defaults_when_no_fields ... ok [INFO] [stdout] test config::tests::base_url_overrides_website ... ok [INFO] [stdout] test config::tests::explicit_override ... ok [INFO] [stdout] test config::tests::author_defaults_to_empty ... ok [INFO] [stdout] test config::tests::invalid_toml_gives_default ... ok [INFO] [stdout] test config::tests::language_defaults_to_en ... ok [INFO] [stdout] test config::tests::language_override ... ok [INFO] [stdout] test config::tests::overrides_all_fields ... ok [INFO] [stdout] test config::tests::overrides_website ... ok [INFO] [stdout] test config::tests::overrides_title ... ok [INFO] [stdout] test config::tests::load_invalid_file_gives_default ... ok [INFO] [stdout] test config::tests::load_valid_file ... ok [INFO] [stdout] test config::tests::load_nonexistent_path_gives_default ... ok [INFO] [stdout] test media::tests::scan_mp3s_case_insensitive_extension ... ok [INFO] [stdout] test media::tests::scan_mp3s_empty_dir_returns_empty ... ok [INFO] [stdout] test config::tests::overrides_description ... ok [INFO] [stdout] test config::tests::explicit_defaults_to_false ... ok [INFO] [stdout] test media::tests::scan_mp3s_detects_cover_art ... ok [INFO] [stdout] test media::tests::scan_mp3s_full_id3_tags ... ok [INFO] [stdout] test media::tests::scan_mp3s_missing_dir_returns_empty ... ok [INFO] [stdout] test media::tests::scan_mp3s_no_id3_falls_back_to_filename ... ok [INFO] [stdout] test media::tests::scan_mp3s_missing_optional_fields_use_defaults ... ok [INFO] [stdout] test media::tests::scan_mp3s_pub_date_is_set ... ok [INFO] [stdout] test media::tests::scan_mp3s_size_bytes_nonzero ... ok [INFO] [stdout] test media::tests::scan_mp3s_rel_path_includes_subdir ... ok [INFO] [stdout] test media::tests::scan_mp3s_non_image_mime_type_excluded ... ok [INFO] [stdout] test media::tests::scan_mp3s_skips_no_extension ... ok [INFO] [stdout] test media::tests::scan_sections_empty_subdirs_omitted ... ok [INFO] [stdout] test media::tests::scan_sections_flat_structure_heading_is_podcasts ... ok [INFO] [stdout] test media::tests::scan_sections_two_level_subdir_uses_slash_heading ... ok [INFO] [stdout] test media::tests::scan_sections_missing_dir_returns_empty ... ok [INFO] [stdout] test media::tests::sorted_subdirs_missing_dir_returns_empty ... ok [INFO] [stdout] test media::tests::scan_sections_subdir_uses_dir_name_as_heading ... ok [INFO] [stdout] test render::tests::escape_quote ... ok [INFO] [stdout] test media::tests::scan_sections_sorted_alphabetically ... ok [INFO] [stdout] test media::tests::sorted_subdirs_returns_only_dirs_sorted ... ok [INFO] [stdout] test render::tests::escape_ampersand ... ok [INFO] [stdout] test media::tests::sorted_subdirs_empty_dir ... ok [INFO] [stdout] test render::tests::escape_all_special_chars ... ok [INFO] [stdout] test render::tests::render_artists_in_js ... ok [INFO] [stdout] test render::tests::escape_empty ... ok [INFO] [stdout] test render::tests::render_download_button_present ... ok [INFO] [stdout] test render::tests::render_download_url_with_subdir ... ok [INFO] [stdout] test render::tests::render_art_img_present_when_has_art ... ok [INFO] [stdout] test media::tests::scan_sections_empty_dir_no_sections ... ok [INFO] [stdout] test render::tests::escape_gt ... ok [INFO] [stdout] test render::tests::render_duration_shown ... ok [INFO] [stdout] test media::tests::scan_mp3s_sorted_by_filename ... ok [INFO] [stdout] test media::tests::scan_mp3s_skips_non_mp3_extension ... ok [INFO] [stdout] test render::tests::escape_lt ... ok [INFO] [stdout] test render::tests::render_duration_html_escaped ... ok [INFO] [stdout] test render::tests::render_art_img_absent_when_no_art ... ok [INFO] [stdout] test render::tests::render_files_in_js ... ok [INFO] [stdout] test render::tests::render_favicon_uses_first_alphabetical_episode_with_art ... ok [INFO] [stdout] test render::tests::render_download_url_encoded ... ok [INFO] [stdout] test render::tests::render_footer_contains_default_website ... ok [INFO] [stdout] test render::tests::escape_no_special_chars ... ok [INFO] [stdout] test render::tests::render_footer_contains_powered_by_link ... ok [INFO] [stdout] test render::tests::render_footer_contains_rss_link ... ok [INFO] [stdout] test media::tests::scan_sections_root_mp3s_alongside_subdirs ... ok [INFO] [stdout] test render::tests::render_favicon_mime_is_html_escaped ... ok [INFO] [stdout] test render::tests::render_art_url_encoded ... ok [INFO] [stdout] test render::tests::render_footer_website_href_html_escaped ... ok [INFO] [stdout] test render::tests::render_footer_contains_website ... ok [INFO] [stdout] test render::tests::render_meta_html_escaped ... ok [INFO] [stdout] test render::tests::render_has_art_false_in_js ... ok [INFO] [stdout] test render::tests::render_full_meta_joined ... ok [INFO] [stdout] test render::tests::render_header_uses_default_title_when_unset ... ok [INFO] [stdout] test render::tests::render_partial_meta_filters_empty_fields ... ok [INFO] [stdout] test render::tests::render_has_art_true_in_js ... ok [INFO] [stdout] test render::tests::render_favicon_absent_when_no_episode_has_art ... ok [INFO] [stdout] test render::tests::render_player_bar_has_art_element ... ok [INFO] [stdout] test render::tests::render_multiple_episodes_plural ... ok [INFO] [stdout] test render::tests::render_player_bar_has_info_element ... ok [INFO] [stdout] test render::tests::render_header_contains_description ... ok [INFO] [stdout] test render::tests::render_title_html_escaped ... ok [INFO] [stdout] test render::tests::render_titles_in_js ... ok [INFO] [stdout] test render::tests::render_empty_duration_hidden ... ok [INFO] [stdout] test render::tests::render_one_episode_singular ... ok [INFO] [stdout] test render::tests::render_play_indices_span_sections ... ok [INFO] [stdout] test render::tests::url_encode_safe_chars_unchanged ... ok [INFO] [stdout] test render::tests::render_section_heading_appears ... ok [INFO] [stdout] test render::tests::url_encode_slash_with_spaces ... ok [INFO] [stdout] test render::tests::url_encode_preserves_slash ... ok [INFO] [stdout] test rss::tests::format_pub_date_epoch ... ok [INFO] [stdout] test render::tests::render_zero_sections_produces_valid_html ... ok [INFO] [stdout] test render::tests::render_header_contains_title ... ok [INFO] [stdout] test render::tests::url_encode_plain_ascii_unchanged ... ok [INFO] [stdout] test render::tests::url_encode_space_encoded ... ok [INFO] [stdout] test rss::tests::format_pub_date_known_timestamp ... ok [INFO] [stdout] test rss::tests::format_pub_date_leap_day ... ok [INFO] [stdout] test rss::tests::render_rss_base_url_override ... ok [INFO] [stdout] test rss::tests::render_rss_base_url_falls_back_to_website ... ok [INFO] [stdout] test rss::tests::render_rss_channel_description ... ok [INFO] [stdout] test rss::tests::render_rss_author_present_when_set ... ok [INFO] [stdout] test rss::tests::render_rss_channel_title ... ok [INFO] [stdout] test rss::tests::render_rss_channel_image_uses_first_art ... ok [INFO] [stdout] test rss::tests::render_rss_channel_description_special_chars_escaped ... ok [INFO] [stdout] test rss::tests::render_rss_enclosure_url_and_type ... ok [INFO] [stdout] test rss::tests::render_rss_explicit_false_by_default ... ok [INFO] [stdout] test rss::tests::render_rss_channel_image_absent_when_no_art ... ok [INFO] [stdout] test rss::tests::render_rss_has_xml_header ... ok [INFO] [stdout] test rss::tests::render_rss_author_omitted_when_empty ... ok [INFO] [stdout] test rss::tests::render_rss_enclosure_length ... ok [INFO] [stdout] test rss::tests::render_rss_language_default ... ok [INFO] [stdout] test rss::tests::render_rss_language_override ... ok [INFO] [stdout] test render::tests::render_favicon_absent_when_no_sections ... ok [INFO] [stdout] test rss::tests::render_rss_pubdate_present_when_set ... ok [INFO] [stdout] test rss::tests::render_rss_pubdate_omitted_when_none ... ok [INFO] [stdout] test rss::tests::render_rss_special_chars_escaped_in_title ... ok [INFO] [stdout] test rss::tests::render_rss_unknown_artist_suppressed_from_itunes_author ... ok [INFO] [stdout] test rss::tests::render_rss_explicit_true ... ok [INFO] [stdout] test rss::tests::render_rss_has_rss_element_with_itunes_ns ... ok [INFO] [stdout] test rss::tests::render_rss_item_image_present_when_art ... ok [INFO] [stdout] test rss::tests::render_rss_url_encoded_paths ... ok [INFO] [stdout] test rss::tests::render_rss_itunes_episode_numbering ... ok [INFO] [stdout] test rss::tests::render_rss_itunes_season_numbering ... ok [INFO] [stdout] test rss::tests::xml_escape_ampersand ... ok [INFO] [stdout] test rss::tests::xml_escape_clean_string_unchanged ... ok [INFO] [stdout] test rss::tests::xml_escape_double_quote ... ok [INFO] [stdout] test rss::tests::xml_escape_gt ... ok [INFO] [stdout] test tests::build_art_map_empty_sections ... ok [INFO] [stdout] test tests::build_art_map_stores_mime_and_data ... ok [INFO] [stdout] test tests::build_art_map_includes_only_art_episodes ... ok [INFO] [stdout] test tests::cli_custom_args ... ok [INFO] [stdout] test tests::cli_env_var_fallback ... ok [INFO] [stdout] test tests::cli_defaults ... ok [INFO] [stdout] test tests::cli_short_aliases ... ok [INFO] [stdout] test tests::etag_different_inputs_differ ... ok [INFO] [stdout] test rss::tests::xml_escape_lt ... ok [INFO] [stdout] test rss::tests::xml_escape_single_quote ... ok [INFO] [stdout] test tests::etag_same_input_same_output ... ok [INFO] [stdout] test tests::real_ip_extractor_falls_back_to_peer_when_no_header ... ok [INFO] [stdout] test tests::real_ip_extractor_ignores_x_real_ip_for_non_localhost_peer ... ok [INFO] [stdout] test tests::etag_is_quoted ... ok [INFO] [stdout] test tests::real_ip_extractor_uses_x_real_ip_when_peer_is_ipv6_localhost ... ok [INFO] [stdout] test tests::index_returns_304_on_matching_etag ... ok [INFO] [stdout] test tests::index_returns_200_with_html_body ... ok [INFO] [stdout] test tests::index_returns_cache_control_header ... ok [INFO] [stdout] test tests::rss_returns_200_with_xml_content_type ... ok [INFO] [stdout] test tests::rss_returns_304_on_matching_etag ... ok [INFO] [stdout] test tests::art_returns_404_for_missing_file ... ok [INFO] [stdout] test tests::art_returns_image_bytes ... ok [INFO] [stdout] test tests::art_returns_correct_content_type ... ok [INFO] [stdout] test tests::art_rejects_path_traversal ... ok [INFO] [stdout] test tests::art_returns_cache_control_header ... ok [INFO] [stdout] test tests::rate_limiter_returns_429_after_burst_exhausted ... ok [INFO] [stdout] test tests::real_ip_extractor_uses_x_real_ip_when_peer_is_localhost ... ok [INFO] [stdout] test tests::rss_returns_cache_control_no_cache ... ok [INFO] [stdout] test rss::tests::render_rss_item_image_absent_when_no_art ... ok [INFO] [stdout] test media::tests::scan_mp3s_missing_title_falls_back_to_filename ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 153 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.12s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "7c288a8dbc6479fe6905ec4f31be8eb82b7d3fdd235944d695d2b43864d6955e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7c288a8dbc6479fe6905ec4f31be8eb82b7d3fdd235944d695d2b43864d6955e", kill_on_drop: false }` [INFO] [stdout] 7c288a8dbc6479fe6905ec4f31be8eb82b7d3fdd235944d695d2b43864d6955e