[INFO] fetching crate podserv-b 0.1.2...
[INFO] testing podserv-b-0.1.2 against 1.95.0 for beta-1.96-2
[INFO] extracting crate podserv-b 0.1.2 into /workspace/builds/worker-5-tc1/source
[INFO] started tweaking crates.io crate podserv-b 0.1.2
[INFO] finished tweaking crates.io crate podserv-b 0.1.2
[INFO] tweaked toml for crates.io crate podserv-b 0.1.2 written to /workspace/builds/worker-5-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate podserv-b 0.1.2 on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate podserv-b 0.1.2 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" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded bytestring v1.5.0
[INFO] [stderr]   Downloaded impl-more v0.1.9
[INFO] [stderr]   Downloaded v_htmlescape v0.15.8
[INFO] [stderr]   Downloaded actix-files v0.6.10
[INFO] [stderr]   Downloaded actix-governor v0.10.0
[INFO] [stderr]   Downloaded actix-service v2.0.3
[INFO] [stderr]   Downloaded id3 v1.16.4
[INFO] [stderr]   Downloaded governor v0.10.4
[INFO] [stderr]   Downloaded actix-http v3.12.0
[INFO] [stderr]   Downloaded actix-web v4.13.0
[INFO] [stderr]   Downloaded actix-server v2.6.0
[INFO] [stderr]   Downloaded http-range v0.1.5
[INFO] [stderr]   Downloaded actix-rt v2.11.0
[INFO] [stderr]   Downloaded actix-router v0.5.4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 1f56510e0a1959cedbe0532092e17ecf5bdaf92242322f434ad829540120335f
[INFO] running `Command { std: "docker" "start" "-a" "1f56510e0a1959cedbe0532092e17ecf5bdaf92242322f434ad829540120335f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "1f56510e0a1959cedbe0532092e17ecf5bdaf92242322f434ad829540120335f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1f56510e0a1959cedbe0532092e17ecf5bdaf92242322f434ad829540120335f", kill_on_drop: false }`
[INFO] [stdout] 1f56510e0a1959cedbe0532092e17ecf5bdaf92242322f434ad829540120335f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+1.95.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a1066d4bd9c828379357ce717ff598e24d10485341f2bced719b991a74f128b8
[INFO] running `Command { std: "docker" "start" "-a" "a1066d4bd9c828379357ce717ff598e24d10485341f2bced719b991a74f128b8", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.182
[INFO] [stderr]    Compiling futures-channel v0.3.32
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling zstd-safe v7.2.4
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling local-waker v0.1.4
[INFO] [stderr]    Compiling alloc-no-stdlib v2.0.4
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling regex-lite v0.1.9
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling num-conv v0.2.0
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling alloc-stdlib v0.2.2
[INFO] [stderr]    Compiling actix-utils v3.0.1
[INFO] [stderr]    Compiling bytestring v1.5.0
[INFO] [stderr]    Compiling brotli-decompressor v5.0.0
[INFO] [stderr]    Compiling time-macros v0.2.27
[INFO] [stderr]    Compiling cookie v0.16.2
[INFO] [stderr]    Compiling actix-service v2.0.3
[INFO] [stderr]    Compiling convert_case v0.10.0
[INFO] [stderr]    Compiling local-channel v0.1.5
[INFO] [stderr]    Compiling portable-atomic v1.13.1
[INFO] [stderr]    Compiling language-tags v0.3.2
[INFO] [stderr]    Compiling derive_more-impl v2.1.1
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling raw-cpuid v11.6.0
[INFO] [stderr]    Compiling actix-macros v0.2.4
[INFO] [stderr]    Compiling actix-router v0.5.4
[INFO] [stderr]    Compiling impl-more v0.1.9
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling v_htmlescape v0.15.8
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling time v0.3.47
[INFO] [stderr]    Compiling brotli v8.0.2
[INFO] [stderr]    Compiling spinning_top v0.3.0
[INFO] [stderr]    Compiling web-time v1.1.0
[INFO] [stderr]    Compiling nonzero_ext v0.3.0
[INFO] [stderr]    Compiling clap_builder v4.5.60
[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 parking_lot v0.12.5
[INFO] [stderr]    Compiling cc v1.2.56
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling socket2 v0.6.2
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling rand_core v0.9.5
[INFO] [stderr]    Compiling actix-web-codegen v4.3.0
[INFO] [stderr]    Compiling dashmap v6.1.0
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling quanta v0.12.6
[INFO] [stderr]    Compiling http-range v0.1.5
[INFO] [stderr]    Compiling id3 v1.16.4
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling futures-executor v0.3.32
[INFO] [stderr]    Compiling futures v0.3.32
[INFO] [stderr]    Compiling zstd-sys v2.0.16+zstd.1.5.7
[INFO] [stderr]    Compiling derive_more v2.1.1
[INFO] [stderr]    Compiling governor v0.10.4
[INFO] [stderr]    Compiling clap v4.5.60
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling actix-rt v2.11.0
[INFO] [stderr]    Compiling zstd v0.13.3
[INFO] [stderr]    Compiling actix-server v2.6.0
[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 02s
[INFO] running `Command { std: "docker" "inspect" "a1066d4bd9c828379357ce717ff598e24d10485341f2bced719b991a74f128b8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a1066d4bd9c828379357ce717ff598e24d10485341f2bced719b991a74f128b8", kill_on_drop: false }`
[INFO] [stdout] a1066d4bd9c828379357ce717ff598e24d10485341f2bced719b991a74f128b8
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+1.95.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0006a5abe74a09fb2f159a65096bf69de24465df0c280b001419bb6bcbc7b230
[INFO] running `Command { std: "docker" "start" "-a" "0006a5abe74a09fb2f159a65096bf69de24465df0c280b001419bb6bcbc7b230", 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 7.24s
[INFO] running `Command { std: "docker" "inspect" "0006a5abe74a09fb2f159a65096bf69de24465df0c280b001419bb6bcbc7b230", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0006a5abe74a09fb2f159a65096bf69de24465df0c280b001419bb6bcbc7b230", kill_on_drop: false }`
[INFO] [stdout] 0006a5abe74a09fb2f159a65096bf69de24465df0c280b001419bb6bcbc7b230
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+1.95.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] a0c71a561de387854d430fe39b846f1480bb9c0021e4803d5e79cdb1291df16f
[INFO] running `Command { std: "docker" "start" "-a" "a0c71a561de387854d430fe39b846f1480bb9c0021e4803d5e79cdb1291df16f", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.38s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/podserv_b-b818f1f09dff6975)
[INFO] [stdout] 
[INFO] [stdout] running 205 tests
[INFO] [stdout] test config::tests::defaults_when_no_fields ... ok
[INFO] [stdout] test config::tests::author_defaults_to_empty ... ok
[INFO] [stdout] test config::tests::base_url_overrides_website ... ok
[INFO] [stdout] test config::tests::base_url_defaults_to_website ... ok
[INFO] [stdout] test config::tests::author_override ... ok
[INFO] [stdout] test config::tests::explicit_defaults_to_false ... ok
[INFO] [stdout] test config::tests::language_defaults_to_en ... ok
[INFO] [stdout] test config::tests::explicit_override ... ok
[INFO] [stdout] test config::tests::language_override ... ok
[INFO] [stdout] test config::tests::load_nonexistent_path_gives_default ... ok
[INFO] [stdout] test config::tests::invalid_toml_gives_default ... ok
[INFO] [stdout] test config::tests::load_invalid_file_gives_default ... ok
[INFO] [stdout] test config::tests::overrides_all_fields ... ok
[INFO] [stdout] test config::tests::load_valid_file ... ok
[INFO] [stdout] test config::tests::overrides_title ... ok
[INFO] [stdout] test config::tests::overrides_description ... ok
[INFO] [stdout] test counts::tests::load_valid_file_restores_counts ... ok
[INFO] [stdout] test config::tests::overrides_website ... ok
[INFO] [stdout] test media::tests::date_to_unix_secs_leap_day_invalid_non_leap ... ok
[INFO] [stdout] test media::tests::date_to_unix_secs_day_after_epoch_is_valid ... ok
[INFO] [stdout] test counts::tests::load_invalid_json_gives_empty ... ok
[INFO] [stdout] test media::tests::date_to_unix_secs_before_1970_returns_none ... ok
[INFO] [stdout] test media::tests::date_to_unix_secs_day_32_returns_none ... ok
[INFO] [stdout] test counts::tests::load_missing_file_gives_empty ... ok
[INFO] [stdout] test media::tests::date_to_unix_secs_leap_day_valid ... ok
[INFO] [stdout] test media::tests::date_to_unix_secs_month_13_returns_none ... ok
[INFO] [stdout] test media::tests::date_to_unix_secs_zero_day_returns_none ... ok
[INFO] [stdout] test media::tests::date_to_unix_secs_epoch_returns_none ... ok
[INFO] [stdout] test media::tests::date_to_unix_secs_zero_month_returns_none ... ok
[INFO] [stdout] test media::tests::date_to_unix_secs_known_value ... ok
[INFO] [stdout] test media::tests::is_leap_year_400_year_is_leap ... ok
[INFO] [stdout] test media::tests::is_leap_year_century_not_leap ... ok
[INFO] [stdout] test media::tests::is_leap_year_divisible_by_4 ... ok
[INFO] [stdout] test media::tests::is_leap_year_non_leap ... ok
[INFO] [stdout] test counts::tests::snapshot_returns_all_entries ... ok
[INFO] [stdout] test media::tests::parse_date_compact_yyyymmdd_embedded_in_longer_number_returns_none ... ok
[INFO] [stdout] test media::tests::parse_date_compact_yyyymmdd_at_end_of_string ... ok
[INFO] [stdout] test media::tests::parse_date_compact_yyyymmdd_with_boundary ... ok
[INFO] [stdout] test media::tests::parse_date_dot_separated_returns_none ... ok
[INFO] [stdout] test media::tests::parse_date_invalid_day_returns_none ... ok
[INFO] [stdout] test media::tests::parse_date_iso_hyphen_prefix ... ok
[INFO] [stdout] test media::tests::parse_date_iso_hyphen_suffix ... ok
[INFO] [stdout] test media::tests::parse_date_no_date_returns_none ... ok
[INFO] [stdout] test media::tests::parse_date_single_zero_returns_none ... ok
[INFO] [stdout] test media::tests::parse_date_underscore_separator ... ok
[INFO] [stdout] test counts::tests::persist_failure_does_not_panic ... ok
[INFO] [stdout] test counts::tests::increment_independent_keys ... ok
[INFO] [stdout] test counts::tests::increment_accumulates ... ok
[INFO] [stdout] test media::tests::scan_mp3s_empty_dir_returns_empty ... ok
[INFO] [stdout] test media::tests::scan_mp3s_file_to_meta_parses_date_from_name ... ok
[INFO] [stdout] test media::tests::scan_mp3s_full_id3_tags ... ok
[INFO] [stdout] test counts::tests::increment_starts_at_one ... ok
[INFO] [stdout] test media::tests::scan_mp3s_file_to_meta_no_date_falls_back_to_mtime ... ok
[INFO] [stdout] test media::tests::scan_mp3s_missing_dir_returns_empty ... ok
[INFO] [stdout] test media::tests::scan_mp3s_non_image_mime_type_excluded ... ok
[INFO] [stdout] test media::tests::scan_mp3s_pub_date_is_set ... ok
[INFO] [stdout] test media::tests::scan_mp3s_case_insensitive_extension ... ok
[INFO] [stdout] test media::tests::scan_mp3s_no_id3_falls_back_to_filename ... ok
[INFO] [stdout] test counts::tests::persist_and_reload ... ok
[INFO] [stdout] test media::tests::parse_date_invalid_month_returns_none ... ok
[INFO] [stdout] test media::tests::scan_mp3s_missing_title_falls_back_to_filename ... ok
[INFO] [stdout] test media::tests::scan_mp3s_file_to_meta_false_does_not_parse_filename ... ok
[INFO] [stdout] test media::tests::scan_mp3s_detects_cover_art ... ok
[INFO] [stdout] test media::tests::scan_mp3s_rel_path_includes_subdir ... ok
[INFO] [stdout] test media::tests::scan_mp3s_missing_optional_fields_use_defaults ... ok
[INFO] [stdout] test media::tests::scan_mp3s_size_bytes_nonzero ... ok
[INFO] [stdout] test media::tests::scan_mp3s_skips_no_extension ... ok
[INFO] [stdout] test media::tests::scan_mp3s_skips_non_mp3_extension ... ok
[INFO] [stdout] test media::tests::scan_sections_empty_subdirs_omitted ... ok
[INFO] [stdout] test media::tests::scan_mp3s_sorted_by_filename ... ok
[INFO] [stdout] test render::tests::escape_all_special_chars ... ok
[INFO] [stdout] test render::tests::escape_empty ... ok
[INFO] [stdout] test render::tests::escape_ampersand ... ok
[INFO] [stdout] test render::tests::escape_gt ... ok
[INFO] [stdout] test media::tests::scan_sections_missing_dir_returns_empty ... ok
[INFO] [stdout] test media::tests::scan_sections_flat_structure_heading_is_podcasts ... ok
[INFO] [stdout] test media::tests::sorted_subdirs_missing_dir_returns_empty ... ok
[INFO] [stdout] test media::tests::sorted_subdirs_empty_dir ... ok
[INFO] [stdout] test media::tests::scan_sections_root_mp3s_alongside_subdirs ... ok
[INFO] [stdout] test media::tests::scan_sections_sorted_alphabetically ... ok
[INFO] [stdout] test media::tests::scan_sections_two_level_subdir_uses_slash_heading ... ok
[INFO] [stdout] test media::tests::scan_sections_subdir_uses_dir_name_as_heading ... ok
[INFO] [stdout] test render::tests::escape_lt ... ok
[INFO] [stdout] test media::tests::sorted_subdirs_returns_only_dirs_sorted ... ok
[INFO] [stdout] test media::tests::scan_sections_empty_dir_no_sections ... ok
[INFO] [stdout] test render::tests::escape_no_special_chars ... ok
[INFO] [stdout] test render::tests::escape_quote ... ok
[INFO] [stdout] test render::tests::render_art_img_absent_when_no_art ... ok
[INFO] [stdout] test render::tests::render_art_url_encoded ... ok
[INFO] [stdout] test render::tests::render_art_img_present_when_has_art ... ok
[INFO] [stdout] test render::tests::render_artists_in_js ... ok
[INFO] [stdout] test render::tests::render_download_url_encoded ... ok
[INFO] [stdout] test render::tests::render_download_url_with_subdir ... ok
[INFO] [stdout] test render::tests::render_empty_duration_hidden ... ok
[INFO] [stdout] test render::tests::render_favicon_absent_when_no_sections ... ok
[INFO] [stdout] test render::tests::render_favicon_mime_is_html_escaped ... ok
[INFO] [stdout] test render::tests::render_favicon_uses_first_alphabetical_episode_with_art ... ok
[INFO] [stdout] test render::tests::render_files_in_js ... ok
[INFO] [stdout] test render::tests::render_favicon_absent_when_no_episode_has_art ... ok
[INFO] [stdout] test render::tests::render_footer_contains_rss_link ... ok
[INFO] [stdout] test render::tests::render_footer_contains_default_website ... ok
[INFO] [stdout] test render::tests::render_footer_contains_powered_by_link ... ok
[INFO] [stdout] test render::tests::render_has_art_false_in_js ... ok
[INFO] [stdout] test render::tests::render_footer_website_href_html_escaped ... ok
[INFO] [stdout] test render::tests::render_header_contains_description ... ok
[INFO] [stdout] test render::tests::render_duration_shown ... ok
[INFO] [stdout] test render::tests::render_duration_html_escaped ... ok
[INFO] [stdout] test render::tests::render_has_art_true_in_js ... ok
[INFO] [stdout] test render::tests::render_download_button_present ... ok
[INFO] [stdout] test render::tests::render_meta_html_escaped ... ok
[INFO] [stdout] test render::tests::render_page_listens_fetch_updates_ep_meta ... ok
[INFO] [stdout] test render::tests::render_one_episode_singular ... ok
[INFO] [stdout] test render::tests::render_multiple_episodes_plural ... ok
[INFO] [stdout] test render::tests::render_header_contains_title ... ok
[INFO] [stdout] test render::tests::render_footer_contains_website ... ok
[INFO] [stdout] test render::tests::render_header_uses_default_title_when_unset ... ok
[INFO] [stdout] test render::tests::render_full_meta_joined ... ok
[INFO] [stdout] test render::tests::render_page_contains_listens_fetch ... ok
[INFO] [stdout] test render::tests::render_partial_meta_filters_empty_fields ... ok
[INFO] [stdout] test render::tests::render_player_bar_has_art_element ... ok
[INFO] [stdout] test render::tests::render_play_indices_span_sections ... ok
[INFO] [stdout] test render::tests::render_player_bar_has_info_element ... ok
[INFO] [stdout] test render::tests::render_titles_in_js ... ok
[INFO] [stdout] test render::tests::render_section_heading_appears ... ok
[INFO] [stdout] test render::tests::render_zero_sections_produces_valid_html ... ok
[INFO] [stdout] test render::tests::url_encode_preserves_slash ... ok
[INFO] [stdout] test render::tests::render_title_html_escaped ... ok
[INFO] [stdout] test render::tests::url_encode_slash_with_spaces ... 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_epoch ... ok
[INFO] [stdout] test rss::tests::format_pub_date_leap_day ... ok
[INFO] [stdout] test rss::tests::format_pub_date_known_timestamp ... ok
[INFO] [stdout] test render::tests::url_encode_safe_chars_unchanged ... ok
[INFO] [stdout] test rss::tests::render_rss_author_omitted_when_empty ... ok
[INFO] [stdout] test rss::tests::render_rss_author_present_when_set ... ok
[INFO] [stdout] test rss::tests::render_rss_base_url_falls_back_to_website ... ok
[INFO] [stdout] test rss::tests::render_rss_channel_title ... ok
[INFO] [stdout] test rss::tests::render_rss_channel_image_absent_when_no_art ... ok
[INFO] [stdout] test rss::tests::render_rss_channel_description ... ok
[INFO] [stdout] test rss::tests::render_rss_enclosure_url_and_type ... ok
[INFO] [stdout] test rss::tests::render_rss_enclosure_length ... ok
[INFO] [stdout] test rss::tests::render_rss_explicit_true ... ok
[INFO] [stdout] test rss::tests::render_rss_channel_description_special_chars_escaped ... ok
[INFO] [stdout] test rss::tests::render_rss_has_xml_header ... ok
[INFO] [stdout] test rss::tests::render_rss_item_image_absent_when_no_art ... ok
[INFO] [stdout] test rss::tests::render_rss_explicit_false_by_default ... ok
[INFO] [stdout] test rss::tests::render_rss_itunes_season_numbering ... ok
[INFO] [stdout] test rss::tests::render_rss_language_override ... ok
[INFO] [stdout] test rss::tests::render_rss_channel_image_uses_first_art ... ok
[INFO] [stdout] test rss::tests::render_rss_language_default ... ok
[INFO] [stdout] test rss::tests::render_rss_item_image_present_when_art ... ok
[INFO] [stdout] test rss::tests::render_rss_pubdate_omitted_when_none ... ok
[INFO] [stdout] test rss::tests::render_rss_pubdate_present_when_set ... ok
[INFO] [stdout] test rss::tests::xml_escape_ampersand ... ok
[INFO] [stdout] test rss::tests::render_rss_special_chars_escaped_in_title ... ok
[INFO] [stdout] test rss::tests::render_rss_itunes_episode_numbering ... ok
[INFO] [stdout] test rss::tests::render_rss_url_encoded_paths ... ok
[INFO] [stdout] test rss::tests::render_rss_unknown_artist_suppressed_from_itunes_author ... ok
[INFO] [stdout] test rss::tests::render_rss_has_rss_element_with_itunes_ns ... ok
[INFO] [stdout] test rss::tests::render_rss_base_url_override ... ok
[INFO] [stdout] test tests::build_art_map_includes_only_art_episodes ... ok
[INFO] [stdout] test tests::cli_custom_args ... ok
[INFO] [stdout] test rss::tests::xml_escape_gt ... 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::cli_defaults ... ok
[INFO] [stdout] test tests::cli_env_var_fallback ... ok
[INFO] [stdout] test tests::etag_is_quoted ... ok
[INFO] [stdout] test tests::cli_file_to_meta_flag ... ok
[INFO] [stdout] test rss::tests::xml_escape_clean_string_unchanged ... ok
[INFO] [stdout] test tests::cli_short_aliases ... ok
[INFO] [stdout] test tests::etag_different_inputs_differ ... 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::listens_reflects_incremented_counts ... ok
[INFO] [stdout] test tests::art_returns_correct_content_type ... 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 rss::tests::xml_escape_double_quote ... ok
[INFO] [stdout] test tests::art_returns_cache_control_header ... ok
[INFO] [stdout] test tests::real_ip_extractor_uses_x_real_ip_when_peer_is_ipv6_localhost ... ok
[INFO] [stdout] test tests::real_ip_extractor_falls_back_to_peer_when_no_header ... ok
[INFO] [stdout] test tests::listens_returns_200_with_json_content_type ... ok
[INFO] [stdout] test tests::art_returns_image_bytes ... ok
[INFO] [stdout] test tests::listens_returns_empty_object_when_no_plays ... ok
[INFO] [stdout] test tests::real_ip_extractor_ignores_x_real_ip_for_non_localhost_peer ... ok
[INFO] [stdout] test tests::full_app_wiring_serves_index ... ok
[INFO] [stdout] test tests::art_returns_404_for_missing_file ... ok
[INFO] [stdout] test tests::art_rejects_path_traversal ... ok
[INFO] [stdout] test tests::real_ip_extractor_uses_x_real_ip_when_peer_is_localhost ... ok
[INFO] [stdout] test tests::rate_limiter_returns_429_after_burst_exhausted ... ok
[INFO] [stdout] test tests::resolve_listens_path_defaults_to_var_lib ... ok
[INFO] [stdout] test tests::rss_returns_200_with_xml_content_type ... ok
[INFO] [stdout] test tests::resolve_listens_path_uses_explicit_when_set ... ok
[INFO] [stdout] test tests::rss_returns_304_on_matching_etag ... ok
[INFO] [stdout] test tests::rss_returns_cache_control_no_cache ... ok
[INFO] [stdout] test tests::serve_media_returns_400_on_path_traversal ... ok
[INFO] [stdout] test tests::serve_media_returns_404_for_missing_file ... ok
[INFO] [stdout] test tests::serve_media_returns_200_for_existing_file ... ok
[INFO] [stdout] test tests::serve_media_increments_count_on_no_range_header ... ok
[INFO] [stdout] test tests::serve_media_increments_count_on_range_from_zero ... ok
[INFO] [stdout] test tests::serve_media_no_increment_on_mid_stream_range_request ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 205 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.11s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "a0c71a561de387854d430fe39b846f1480bb9c0021e4803d5e79cdb1291df16f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a0c71a561de387854d430fe39b846f1480bb9c0021e4803d5e79cdb1291df16f", kill_on_drop: false }`
[INFO] [stdout] a0c71a561de387854d430fe39b846f1480bb9c0021e4803d5e79cdb1291df16f
