[INFO] cloning repository https://github.com/desertthunder/personal-activity-index [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/desertthunder/personal-activity-index" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdesertthunder%2Fpersonal-activity-index", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdesertthunder%2Fpersonal-activity-index'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 05bd80872eb1a103e9e3059dd06d7dfd1ed0b563 [INFO] testing desertthunder/personal-activity-index against master#0d162b25edd5bf0dba9a22e83b614f1113e90474 for pr-150681 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdesertthunder%2Fpersonal-activity-index" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/desertthunder/personal-activity-index [INFO] finished tweaking git repo https://github.com/desertthunder/personal-activity-index [INFO] tweaked toml for git repo https://github.com/desertthunder/personal-activity-index written to /workspace/builds/worker-2-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/desertthunder/personal-activity-index on toolchain 0d162b25edd5bf0dba9a22e83b614f1113e90474 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/desertthunder/personal-activity-index 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" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Updating crates.io index [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded diligent-date-parser v0.1.5 [INFO] [stderr] Downloaded worker-macros v0.7.0 [INFO] [stderr] Downloaded roff v0.2.2 [INFO] [stderr] Downloaded clap_mangen v0.2.31 [INFO] [stderr] Downloaded worker-sys v0.7.0 [INFO] [stderr] Downloaded rss v2.0.12 [INFO] [stderr] Downloaded mediatype v0.19.20 [INFO] [stderr] Downloaded atom_syndication v0.12.7 [INFO] [stderr] Downloaded rusqlite v0.37.0 [INFO] [stderr] Downloaded worker v0.7.0 [INFO] [stderr] Downloaded feed-rs v2.3.1 [INFO] [stderr] Downloaded libsqlite3-sys v0.35.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 18ed98a9a8ad36a0d829b9d9a8625bf287e572689f7850d88df3c39cd6d6991c [INFO] running `Command { std: "docker" "start" "-a" "18ed98a9a8ad36a0d829b9d9a8625bf287e572689f7850d88df3c39cd6d6991c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "18ed98a9a8ad36a0d829b9d9a8625bf287e572689f7850d88df3c39cd6d6991c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "18ed98a9a8ad36a0d829b9d9a8625bf287e572689f7850d88df3c39cd6d6991c", kill_on_drop: false }` [INFO] [stdout] 18ed98a9a8ad36a0d829b9d9a8625bf287e572689f7850d88df3c39cd6d6991c [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 0f6623950c00e314c3ea121ba91e40041fba19e27c79e0e2f779e4040397fa9d [INFO] running `Command { std: "docker" "start" "-a" "0f6623950c00e314c3ea121ba91e40041fba19e27c79e0e2f779e4040397fa9d", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.177 [INFO] [stderr] Compiling proc-macro2 v1.0.103 [INFO] [stderr] Compiling http v1.3.1 [INFO] [stderr] Compiling tracing-core v0.1.34 [INFO] [stderr] Compiling log v0.4.28 [INFO] [stderr] Compiling icu_properties_data v2.1.1 [INFO] [stderr] Compiling equivalent v1.0.2 [INFO] [stderr] Compiling hashbrown v0.16.1 [INFO] [stderr] Compiling openssl-sys v0.9.111 [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling futures-channel v0.3.31 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling wasm-bindgen-shared v0.2.105 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling sync_wrapper v1.0.2 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling encoding_rs v0.8.35 [INFO] [stderr] Compiling openssl-probe v0.1.6 [INFO] [stderr] Compiling bumpalo v3.19.0 [INFO] [stderr] Compiling ipnet v2.11.0 [INFO] [stderr] Compiling wasm-bindgen v0.2.105 [INFO] [stderr] Compiling quote v1.0.42 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling regex-syntax v0.8.8 [INFO] [stderr] Compiling iri-string v0.7.9 [INFO] [stderr] Compiling winnow v0.7.13 [INFO] [stderr] Compiling syn v2.0.111 [INFO] [stderr] Compiling zeroize v1.8.2 [INFO] [stderr] Compiling futures-task v0.3.31 [INFO] [stderr] Compiling tracing v0.1.41 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling rustls-pki-types v1.13.0 [INFO] [stderr] Compiling toml_writer v1.0.4 [INFO] [stderr] Compiling socket2 v0.6.1 [INFO] [stderr] Compiling mio v1.1.0 [INFO] [stderr] Compiling signal-hook-registry v1.4.7 [INFO] [stderr] Compiling indexmap v2.12.1 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling quick-xml v0.37.5 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling uuid v1.18.1 [INFO] [stderr] Compiling thiserror v2.0.17 [INFO] [stderr] Compiling serde_json v1.0.145 [INFO] [stderr] Compiling clap_builder v4.5.53 [INFO] [stderr] Compiling toml_datetime v0.7.3 [INFO] [stderr] Compiling serde_spanned v1.0.3 [INFO] [stderr] Compiling libsqlite3-sys v0.35.0 [INFO] [stderr] Compiling regex-automata v0.4.13 [INFO] [stderr] Compiling never v0.1.0 [INFO] [stderr] Compiling hashbrown v0.15.5 [INFO] [stderr] Compiling owo-colors v4.2.3 [INFO] [stderr] Compiling roff v0.2.2 [INFO] [stderr] Compiling toml_parser v1.0.4 [INFO] [stderr] Compiling axum-core v0.5.5 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling matchit v0.7.3 [INFO] [stderr] Compiling dirs v6.0.0 [INFO] [stderr] Compiling toml v0.9.8 [INFO] [stderr] Compiling hashlink v0.10.0 [INFO] [stderr] Compiling regex v1.12.2 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling wasm-bindgen-macro-support v0.2.105 [INFO] [stderr] Compiling darling_core v0.20.11 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling serde_derive v1.0.228 [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 openssl-macros v0.1.1 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling thiserror-impl v2.0.17 [INFO] [stderr] Compiling clap_derive v4.5.49 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling pin-project-internal v1.1.10 [INFO] [stderr] Compiling tokio v1.48.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 pin-project v1.1.10 [INFO] [stderr] Compiling darling_macro v0.20.11 [INFO] [stderr] Compiling darling v0.20.11 [INFO] [stderr] Compiling derive_builder_core v0.20.2 [INFO] [stderr] Compiling wasm-bindgen-macro v0.2.105 [INFO] [stderr] Compiling clap v4.5.53 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling clap_mangen v0.2.31 [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 chrono v0.4.42 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling mediatype v0.19.20 [INFO] [stderr] Compiling derive_builder_macro v0.20.2 [INFO] [stderr] Compiling derive_builder v0.20.2 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling js-sys v0.3.82 [INFO] [stderr] Compiling icu_properties v2.1.1 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling diligent-date-parser v0.1.5 [INFO] [stderr] Compiling atom_syndication v0.12.7 [INFO] [stderr] Compiling rss v2.0.12 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling url v2.5.7 [INFO] [stderr] Compiling feed-rs v2.3.1 [INFO] [stderr] Compiling tokio-util v0.7.17 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling tower v0.5.2 [INFO] [stderr] Compiling h2 v0.4.12 [INFO] [stderr] Compiling tower-http v0.6.6 [INFO] [stderr] Compiling web-sys v0.3.82 [INFO] [stderr] Compiling wasm-bindgen-futures v0.4.55 [INFO] [stderr] Compiling serde-wasm-bindgen v0.6.5 [INFO] [stderr] Compiling rusqlite v0.37.0 [INFO] [stderr] Compiling worker-sys v0.7.0 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling wasm-streams v0.4.2 [INFO] [stderr] Compiling worker-macros v0.7.0 [INFO] [stderr] Compiling worker v0.7.0 [INFO] [stderr] Compiling hyper-util v0.1.18 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling reqwest v0.12.24 [INFO] [stderr] Compiling pai-core v0.1.0 (/opt/rustwide/workdir/core) [INFO] [stderr] Compiling axum v0.8.7 [INFO] [stderr] Compiling pai v0.1.0 (/opt/rustwide/workdir/cli) [INFO] [stderr] Compiling pai-worker v0.1.0 (/opt/rustwide/workdir/worker) [INFO] [stderr] Compiling pai-server v0.1.0 (/opt/rustwide/workdir/server) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 37s [INFO] running `Command { std: "docker" "inspect" "0f6623950c00e314c3ea121ba91e40041fba19e27c79e0e2f779e4040397fa9d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "0f6623950c00e314c3ea121ba91e40041fba19e27c79e0e2f779e4040397fa9d", kill_on_drop: false }` [INFO] [stdout] 0f6623950c00e314c3ea121ba91e40041fba19e27c79e0e2f779e4040397fa9d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] a2d1b0ed81ad9a198055c431953582ed77946f01c200441f55c2277d47f31b80 [INFO] running `Command { std: "docker" "start" "-a" "a2d1b0ed81ad9a198055c431953582ed77946f01c200441f55c2277d47f31b80", kill_on_drop: false }` [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling tower-http v0.6.6 [INFO] [stderr] Compiling rusqlite v0.37.0 [INFO] [stderr] Compiling tempfile v3.23.0 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling reqwest v0.12.24 [INFO] [stderr] Compiling pai-core v0.1.0 (/opt/rustwide/workdir/core) [INFO] [stderr] Compiling pai-server v0.1.0 (/opt/rustwide/workdir/server) [INFO] [stderr] Compiling pai-worker v0.1.0 (/opt/rustwide/workdir/worker) [INFO] [stderr] Compiling pai v0.1.0 (/opt/rustwide/workdir/cli) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 25.46s [INFO] running `Command { std: "docker" "inspect" "a2d1b0ed81ad9a198055c431953582ed77946f01c200441f55c2277d47f31b80", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "a2d1b0ed81ad9a198055c431953582ed77946f01c200441f55c2277d47f31b80", kill_on_drop: false }` [INFO] [stdout] a2d1b0ed81ad9a198055c431953582ed77946f01c200441f55c2277d47f31b80 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] abb9a2ed7d053cac65b15bdb929ea362cea855a334f94afc21559bcf16bc6da8 [INFO] running `Command { std: "docker" "start" "-a" "abb9a2ed7d053cac65b15bdb929ea362cea855a334f94afc21559bcf16bc6da8", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.29s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/pai-cc12985eb68b1ff7) [INFO] [stdout] [INFO] [stdout] running 14 tests [INFO] [stdout] test paths::tests::resolve_config_dir_falls_back ... ok [INFO] [stdout] test paths::tests::resolve_db_path_falls_back ... ok [INFO] [stdout] test paths::tests::resolve_config_dir_with_explicit ... ok [INFO] [stdout] test tests::ensure_positive_limit_rejects_zero ... ok [INFO] [stdout] test tests::export_format_parsing ... ok [INFO] [stdout] test tests::manpage_contains_name_section ... ok [INFO] [stdout] test tests::json_export_serializes_items ... ok [INFO] [stdout] test tests::ndjson_export_serializes_items ... ok [INFO] [stdout] test tests::table_writer_emits_rows ... ok [INFO] [stdout] test tests::truncate_column_adds_ellipsis ... ok [INFO] [stdout] test tests::normalize_since_accepts_iso8601 ... ok [INFO] [stdout] test tests::normalize_since_accepts_relative_days ... ok [INFO] [stdout] test tests::rss_export_contains_items ... ok [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/pai_core-28d11820c4aa9930) [INFO] [stdout] test paths::tests::resolve_db_path_with_explicit ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 14 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.12s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 43 tests [INFO] [stdout] test fetchers::bluesky::tests::at_uri_to_url_invalid ... ok [INFO] [stdout] test fetchers::bearblog::tests::parse_empty_rss ... ok [INFO] [stdout] test fetchers::bearblog::tests::parse_invalid_rss ... ok [INFO] [stdout] test fetchers::bluesky::tests::at_uri_to_url_valid ... ok [INFO] [stdout] test fetchers::bluesky::tests::create_title_long_text ... ok [INFO] [stdout] test fetchers::bluesky::tests::create_title_short_text ... ok [INFO] [stdout] test fetchers::bluesky::tests::extract_text_from_record ... ok [INFO] [stdout] test fetchers::bluesky::tests::extract_text_missing ... ok [INFO] [stdout] test fetchers::bluesky::tests::is_original_post_true ... ok [INFO] [stdout] test fetchers::leaflet::tests::parse_invalid_rss ... ok [INFO] [stdout] test fetchers::bluesky::tests::is_original_post_false_repost ... ok [INFO] [stdout] test fetchers::leaflet::tests::parse_empty_rss ... ok [INFO] [stdout] test fetchers::substack::tests::extract_source_id_http ... ok [INFO] [stdout] test fetchers::substack::tests::parse_empty_rss ... ok [INFO] [stdout] test fetchers::substack::tests::parse_invalid_rss ... ok [INFO] [stdout] test tests::config_default_enabled_false ... ok [INFO] [stdout] test tests::config_parse_invalid_toml ... ok [INFO] [stdout] test tests::config_parse_all_sources ... ok [INFO] [stdout] test tests::config_parse_substack ... ok [INFO] [stdout] test tests::config_parse_bluesky ... ok [INFO] [stdout] test tests::cors_config_dev_key_none ... ok [INFO] [stdout] test tests::config_parse_cors ... ok [INFO] [stdout] test tests::cors_config_localhost_requires_exact_match ... ok [INFO] [stdout] test tests::cors_config_exact_match ... ok [INFO] [stdout] test tests::config_parse_leaflet_multiple ... ok [INFO] [stdout] test tests::cors_config_same_root_domain ... ok [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/pai_server-3fe821c591a0752c) [INFO] [stdout] test fetchers::substack::tests::extract_source_id_https ... ok [INFO] [stdout] test tests::extract_domain_http ... ok [INFO] [stdout] test tests::cors_config_dev_key_valid ... ok [INFO] [stdout] test tests::extract_domain_https ... ok [INFO] [stdout] test tests::extract_root_domain_multi_level ... ok [INFO] [stdout] test tests::extract_root_domain_single_part ... ok [INFO] [stdout] test tests::extract_root_domain_two_parts ... ok [INFO] [stdout] test tests::config_parse_missing_required_field ... ok [INFO] [stdout] test tests::config_parse_empty ... ok [INFO] [stdout] test tests::error_unknown_source_kind ... ok [INFO] [stdout] test tests::list_filter_default ... ok [INFO] [stdout] test tests::cors_config_empty_origins_denies_all ... ok [INFO] [stdout] test fetchers::leaflet::tests::parse_valid_rss ... ok [INFO] [stdout] test fetchers::bearblog::tests::parse_valid_rss ... ok [INFO] [stdout] test fetchers::substack::tests::parse_valid_rss ... ok [INFO] [stdout] test tests::source_kind_display ... ok [INFO] [stdout] test tests::source_kind_parse ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 43 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 16 tests [INFO] [stdout] test server::tests::api_error_into_response_sets_status ... ok [INFO] [stdout] test server::tests::feed_query_respects_parameters ... ok [INFO] [stdout] test storage::sqlite::tests::count_items_returns_total ... ok [INFO] [stdout] test server::tests::feed_query_rejects_zero_limit ... ok [INFO] [stdout] test server::tests::feed_query_defaults ... ok [INFO] [stdout] test storage::sqlite::tests::filter_by_query ... ok [INFO] [stdout] test storage::sqlite::tests::get_stats_returns_counts_by_source ... ok [INFO] [stdout] test storage::sqlite::tests::insert_and_retrieve_item ... ok [INFO] [stdout] test storage::sqlite::tests::filter_by_source_kind ... ok [INFO] [stdout] test storage::sqlite::tests::get_item_returns_none_for_missing ... ok [INFO] [stdout] test storage::sqlite::tests::new_database_initializes_schema ... ok [INFO] [stdout] test storage::sqlite::tests::filter_with_limit ... ok [INFO] [stdout] test storage::sqlite::tests::insert_replaces_existing_item ... ok [INFO] [stdout] test storage::sqlite::tests::filter_by_source_id ... ok [INFO] [stdout] test storage::sqlite::tests::get_item_returns_record ... ok [INFO] [stdout] test server::tests::status_snapshot_reports_counts ... ok [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/pai_worker-7d92662f0227763a) [INFO] [stdout] [INFO] [stdout] test result: ok. 16 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.16s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 23 tests [INFO] [stdout] test tests::test_api_docs_json_is_valid ... ok [INFO] [stdout] test tests::test_api_docs_has_all_endpoints ... ok [INFO] [stdout] test tests::test_bearblog_config_parsing_multiple ... ok [INFO] [stdout] test tests::test_bearblog_feed_url_construction ... ok [INFO] [stdout] test tests::test_api_docs_feed_endpoint_parameters ... ok [INFO] [stdout] test tests::test_bluesky_api_url_construction ... ok [INFO] [stdout] test tests::test_bearblog_config_parsing ... ok [INFO] [stdout] test tests::test_bluesky_title_truncation_boundary ... ok [INFO] [stdout] test tests::test_bluesky_post_id_extraction ... ok [INFO] [stdout] test tests::test_bluesky_title_truncation_short ... ok [INFO] [stdout] test tests::test_bluesky_title_truncation_long ... ok [INFO] [stdout] test tests::test_api_docs_has_source_descriptions ... ok [INFO] [stdout] test tests::test_leaflet_config_parsing_multiple ... ok [INFO] [stdout] test tests::test_leaflet_feed_url_construction ... ok [INFO] [stdout] test tests::test_leaflet_config_parsing_invalid ... ok [INFO] [stdout] test tests::test_normalize_source_id_https ... ok [INFO] [stdout] test tests::test_normalize_source_id_no_protocol ... ok [INFO] [stdout] test tests::test_normalize_source_id_http ... ok [INFO] [stdout] test tests::test_normalize_source_id_trailing_slash ... ok [INFO] [stdout] test tests::test_bluesky_url_construction ... ok [INFO] [stdout] test tests::test_substack_feed_url_construction ... ok [INFO] [stdout] test tests::test_api_docs_url_generation ... ok [INFO] [stdout] test tests::test_leaflet_config_parsing ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 23 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Doc-tests pai_core [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] Doc-tests pai_server [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" "abb9a2ed7d053cac65b15bdb929ea362cea855a334f94afc21559bcf16bc6da8", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "abb9a2ed7d053cac65b15bdb929ea362cea855a334f94afc21559bcf16bc6da8", kill_on_drop: false }` [INFO] [stdout] abb9a2ed7d053cac65b15bdb929ea362cea855a334f94afc21559bcf16bc6da8