[INFO] fetching crate gen-bsky 0.1.17... [INFO] testing gen-bsky-0.1.17 against master#562dee4820c458d823175268e41601d4c060588a for pr-154210-1 [INFO] extracting crate gen-bsky 0.1.17 into /workspace/builds/worker-6-tc1/source [INFO] started tweaking crates.io crate gen-bsky 0.1.17 [INFO] finished tweaking crates.io crate gen-bsky 0.1.17 [INFO] tweaked toml for crates.io crate gen-bsky 0.1.17 written to /workspace/builds/worker-6-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate gen-bsky 0.1.17 on toolchain 562dee4820c458d823175268e41601d4c060588a [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate gen-bsky 0.1.17 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" "+562dee4820c458d823175268e41601d4c060588a" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded toml v1.1.0+spec-1.1.0 [INFO] [stderr] Downloaded serde_spanned v1.1.0 [INFO] [stderr] Downloaded zmij v1.0.17 [INFO] [stderr] Downloaded toml_datetime v1.1.0+spec-1.1.0 [INFO] [stderr] Downloaded toml_writer v1.1.0+spec-1.1.0 [INFO] [stderr] Downloaded base-x v0.2.11 [INFO] [stderr] Downloaded multibase v0.9.2 [INFO] [stderr] Downloaded atrium-common v0.1.2 [INFO] [stderr] Downloaded event-listener-strategy v0.5.4 [INFO] [stderr] Downloaded include_dir_macros v0.7.4 [INFO] [stderr] Downloaded proc-macro-error2 v2.0.1 [INFO] [stderr] Downloaded dashmap v6.1.0 [INFO] [stderr] Downloaded async-lock v3.4.1 [INFO] [stderr] Downloaded bsky-sdk v0.1.23 [INFO] [stderr] Downloaded openssl-sys v0.9.111 [INFO] [stderr] Downloaded async-compression v0.4.36 [INFO] [stderr] Downloaded tower v0.5.2 [INFO] [stderr] Downloaded atrium-api v0.25.7 [INFO] [stderr] Downloaded iri-string v0.7.9 [INFO] [stderr] Downloaded reqwest v0.12.28 [INFO] [stderr] Downloaded psl v2.1.168 [INFO] [stderr] Downloaded winnow v1.0.0 [INFO] [stderr] Downloaded flate2 v1.1.5 [INFO] [stderr] Downloaded moka v0.12.11 [INFO] [stderr] Downloaded jiff-static v0.2.23 [INFO] [stderr] Downloaded core2 v0.4.0 [INFO] [stderr] Downloaded multihash v0.19.3 [INFO] [stderr] Downloaded openssl v0.10.75 [INFO] [stderr] Downloaded rustls-pki-types v1.13.1 [INFO] [stderr] Downloaded portable-atomic-util v0.2.4 [INFO] [stderr] Downloaded base62 v2.2.4 [INFO] [stderr] Downloaded concurrent-queue v2.5.0 [INFO] [stderr] Downloaded event-listener v5.4.1 [INFO] [stderr] Downloaded const-str v0.4.3 [INFO] [stderr] Downloaded ipld-core v0.4.2 [INFO] [stderr] Downloaded langtag v0.3.4 [INFO] [stderr] Downloaded native-tls v0.2.14 [INFO] [stderr] Downloaded compression-codecs v0.4.35 [INFO] [stderr] Downloaded anstream v1.0.0 [INFO] [stderr] Downloaded env_logger v0.11.10 [INFO] [stderr] Downloaded serde_html_form v0.2.8 [INFO] [stderr] Downloaded anstyle-parse v1.0.0 [INFO] [stderr] Downloaded link-bridge v0.2.4 [INFO] [stderr] Downloaded include_dir v0.7.4 [INFO] [stderr] Downloaded proc-macro-error-attr2 v2.0.0 [INFO] [stderr] Downloaded atrium-xrpc-client v0.5.14 [INFO] [stderr] Downloaded parking v2.2.1 [INFO] [stderr] Downloaded match-lookup v0.1.1 [INFO] [stderr] Downloaded base256emoji v1.0.2 [INFO] [stderr] Downloaded jiff v0.2.23 [INFO] [stderr] Downloaded data-encoding-macro-internal v0.1.16 [INFO] [stderr] Downloaded data-encoding-macro v0.1.18 [INFO] [stderr] Downloaded cid v0.11.1 [INFO] [stderr] Downloaded libc v0.2.182 [INFO] [stderr] Downloaded atrium-xrpc v0.12.3 [INFO] [stderr] Downloaded hyper-tls v0.6.0 [INFO] [stderr] Downloaded trait-variant v0.1.2 [INFO] [stderr] Downloaded unsigned-varint v0.8.0 [INFO] [stderr] Downloaded compression-core v0.4.31 [INFO] [stderr] Downloaded psl-types v2.0.11 [INFO] [stderr] Downloaded env_filter v1.0.0 [INFO] [stderr] Downloaded getrandom v0.4.1 [INFO] [stderr] Downloaded toml_parser v1.1.0+spec-1.1.0 [INFO] [stderr] Downloaded aquamarine v0.6.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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" "+562dee4820c458d823175268e41601d4c060588a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] a7c83c8b45c4c59d0489eb93d05623ba323ec9deb243f96cb8d925d133ac53ab [INFO] running `Command { std: "docker" "start" "-a" "a7c83c8b45c4c59d0489eb93d05623ba323ec9deb243f96cb8d925d133ac53ab", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "a7c83c8b45c4c59d0489eb93d05623ba323ec9deb243f96cb8d925d133ac53ab", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "a7c83c8b45c4c59d0489eb93d05623ba323ec9deb243f96cb8d925d133ac53ab", kill_on_drop: false }` [INFO] [stdout] a7c83c8b45c4c59d0489eb93d05623ba323ec9deb243f96cb8d925d133ac53ab [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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" "+562dee4820c458d823175268e41601d4c060588a" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] faa9e95db7b69db5d9fde4b9f5580929d39fd9c727c6337d9217f567dd6f5de4 [INFO] running `Command { std: "docker" "start" "-a" "faa9e95db7b69db5d9fde4b9f5580929d39fd9c727c6337d9217f567dd6f5de4", kill_on_drop: false }` [INFO] [stderr] Compiling unicode-ident v1.0.22 [INFO] [stderr] Compiling libc v0.2.182 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling pin-project-lite v0.2.16 [INFO] [stderr] Compiling futures-core v0.3.31 [INFO] [stderr] Compiling memchr v2.7.6 [INFO] [stderr] Compiling stable_deref_trait v1.2.1 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling itoa v1.0.15 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling once_cell v1.21.4 [INFO] [stderr] Compiling crossbeam-utils v0.8.21 [INFO] [stderr] Compiling shlex v1.3.0 [INFO] [stderr] Compiling find-msvc-tools v0.1.5 [INFO] [stderr] Compiling pin-utils v0.1.0 [INFO] [stderr] Compiling futures-task v0.3.31 [INFO] [stderr] Compiling proc-macro2 v1.0.106 [INFO] [stderr] Compiling http v1.4.0 [INFO] [stderr] Compiling percent-encoding v2.3.2 [INFO] [stderr] Compiling slab v0.4.11 [INFO] [stderr] Compiling litemap v0.8.1 [INFO] [stderr] Compiling writeable v0.6.2 [INFO] [stderr] Compiling crc32fast v1.5.0 [INFO] [stderr] Compiling icu_properties_data v2.1.2 [INFO] [stderr] Compiling cc v1.2.49 [INFO] [stderr] Compiling icu_normalizer_data v2.1.1 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling form_urlencoded v1.2.2 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling foreign-types-shared v0.1.1 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling simd-adler32 v0.3.8 [INFO] [stderr] Compiling httparse v1.10.1 [INFO] [stderr] Compiling zmij v1.0.17 [INFO] [stderr] Compiling adler2 v2.0.1 [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling equivalent v1.0.2 [INFO] [stderr] Compiling foreign-types v0.3.2 [INFO] [stderr] Compiling getrandom v0.4.1 [INFO] [stderr] Compiling data-encoding v2.9.0 [INFO] [stderr] Compiling tower-service v0.3.3 [INFO] [stderr] Compiling miniz_oxide v0.8.9 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling parking v2.2.1 [INFO] [stderr] Compiling try-lock v0.2.5 [INFO] [stderr] Compiling concurrent-queue v2.5.0 [INFO] [stderr] Compiling ryu v1.0.20 [INFO] [stderr] Compiling scopeguard v1.2.0 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling lock_api v0.4.14 [INFO] [stderr] Compiling want v0.3.1 [INFO] [stderr] Compiling quote v1.0.45 [INFO] [stderr] Compiling event-listener v5.4.1 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling futures-channel v0.3.31 [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling compression-core v0.4.31 [INFO] [stderr] Compiling portable-atomic v1.11.1 [INFO] [stderr] Compiling flate2 v1.1.5 [INFO] [stderr] Compiling hashbrown v0.16.1 [INFO] [stderr] Compiling openssl-probe v0.1.6 [INFO] [stderr] Compiling const-str v0.4.3 [INFO] [stderr] Compiling atomic-waker v1.1.2 [INFO] [stderr] Compiling event-listener-strategy v0.5.4 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling core2 v0.4.0 [INFO] [stderr] Compiling compression-codecs v0.4.35 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling sync_wrapper v1.0.2 [INFO] [stderr] Compiling tower-layer v0.3.3 [INFO] [stderr] Compiling utf8_iter v1.0.4 [INFO] [stderr] Compiling base64 v0.22.1 [INFO] [stderr] Compiling futures-sink v0.3.31 [INFO] [stderr] Compiling moka v0.12.11 [INFO] [stderr] Compiling ipnet v2.11.0 [INFO] [stderr] Compiling regex-syntax v0.8.8 [INFO] [stderr] Compiling base-x v0.2.11 [INFO] [stderr] Compiling indexmap v2.12.1 [INFO] [stderr] Compiling unsigned-varint v0.8.0 [INFO] [stderr] Compiling async-lock v3.4.1 [INFO] [stderr] Compiling crossbeam-epoch v0.9.18 [INFO] [stderr] Compiling crossbeam-channel v0.5.15 [INFO] [stderr] Compiling zeroize v1.8.2 [INFO] [stderr] Compiling hashbrown v0.14.5 [INFO] [stderr] Compiling iri-string v0.7.9 [INFO] [stderr] Compiling iana-time-zone v0.1.64 [INFO] [stderr] Compiling mio v1.1.1 [INFO] [stderr] Compiling socket2 v0.6.1 [INFO] [stderr] Compiling openssl-sys v0.9.111 [INFO] [stderr] Compiling tagptr v0.2.0 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling uuid v1.22.0 [INFO] [stderr] Compiling rustls-pki-types v1.13.1 [INFO] [stderr] Compiling anyhow v1.0.100 [INFO] [stderr] Compiling include_dir_macros v0.7.4 [INFO] [stderr] Compiling proc-macro-error-attr2 v2.0.0 [INFO] [stderr] Compiling tokio v1.50.0 [INFO] [stderr] Compiling dashmap v6.1.0 [INFO] [stderr] Compiling winnow v1.0.0 [INFO] [stderr] Compiling either v1.15.0 [INFO] [stderr] Compiling psl-types v2.0.11 [INFO] [stderr] Compiling serde_html_form v0.2.8 [INFO] [stderr] Compiling serde_bytes v0.11.19 [INFO] [stderr] Compiling proc-macro-error2 v2.0.1 [INFO] [stderr] Compiling psl v2.1.168 [INFO] [stderr] Compiling itertools v0.10.5 [INFO] [stderr] Compiling toml_datetime v1.1.0+spec-1.1.0 [INFO] [stderr] Compiling serde_spanned v1.1.0 [INFO] [stderr] Compiling include_dir v0.7.4 [INFO] [stderr] Compiling unicode-segmentation v1.12.0 [INFO] [stderr] Compiling base62 v2.2.4 [INFO] [stderr] Compiling regex-automata v0.4.13 [INFO] [stderr] Compiling toml_parser v1.1.0+spec-1.1.0 [INFO] [stderr] Compiling toml_writer v1.1.0+spec-1.1.0 [INFO] [stderr] Compiling same-file v1.0.6 [INFO] [stderr] Compiling walkdir v2.5.0 [INFO] [stderr] Compiling toml v1.1.0+spec-1.1.0 [INFO] [stderr] Compiling match-lookup v0.1.1 [INFO] [stderr] Compiling base256emoji v1.0.2 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling synstructure v0.13.2 [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.31 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling data-encoding-macro-internal v0.1.16 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling trait-variant v0.1.2 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling aquamarine v0.6.0 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling data-encoding-macro v0.1.18 [INFO] [stderr] Compiling multibase v0.9.2 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling async-compression v0.4.36 [INFO] [stderr] Compiling tokio-util v0.7.17 [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 icu_provider v2.1.1 [INFO] [stderr] Compiling multihash v0.19.3 [INFO] [stderr] Compiling atrium-xrpc v0.12.3 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling chrono v0.4.44 [INFO] [stderr] Compiling langtag v0.3.4 [INFO] [stderr] Compiling cid v0.11.1 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling ipld-core v0.4.2 [INFO] [stderr] Compiling hyper-util v0.1.19 [INFO] [stderr] Compiling tower v0.5.2 [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 tower-http v0.6.8 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling link-bridge v0.2.4 [INFO] [stderr] Compiling atrium-common v0.1.2 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling atrium-api v0.25.7 [INFO] [stderr] Compiling atrium-xrpc-client v0.5.14 [INFO] [stderr] Compiling bsky-sdk v0.1.23 [INFO] [stderr] Compiling gen-bsky v0.1.17 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 43s [INFO] running `Command { std: "docker" "inspect" "faa9e95db7b69db5d9fde4b9f5580929d39fd9c727c6337d9217f567dd6f5de4", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "faa9e95db7b69db5d9fde4b9f5580929d39fd9c727c6337d9217f567dd6f5de4", kill_on_drop: false }` [INFO] [stdout] faa9e95db7b69db5d9fde4b9f5580929d39fd9c727c6337d9217f567dd6f5de4 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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" "+562dee4820c458d823175268e41601d4c060588a" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] f9f2b17aef1d29f80ed62c5175a5d5d001f1c0cfe9ed726585503e7d9f15234d [INFO] running `Command { std: "docker" "start" "-a" "f9f2b17aef1d29f80ed62c5175a5d5d001f1c0cfe9ed726585503e7d9f15234d", kill_on_drop: false }` [INFO] [stderr] Compiling bitflags v2.10.0 [INFO] [stderr] Compiling log v0.4.29 [INFO] [stderr] Compiling tokio-macros v2.6.0 [INFO] [stderr] Compiling utf8parse v0.2.2 [INFO] [stderr] Compiling rustix v1.1.4 [INFO] [stderr] Compiling anstyle-query v1.1.5 [INFO] [stderr] Compiling linux-raw-sys v0.12.1 [INFO] [stderr] Compiling is_terminal_polyfill v1.70.2 [INFO] [stderr] Compiling anstyle v1.0.13 [INFO] [stderr] Compiling colorchoice v1.0.4 [INFO] [stderr] Compiling fastrand v2.3.0 [INFO] [stderr] Compiling jiff v0.2.23 [INFO] [stderr] Compiling anstyle-parse v1.0.0 [INFO] [stderr] Compiling env_filter v1.0.0 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling anstream v1.0.0 [INFO] [stderr] Compiling tokio v1.50.0 [INFO] [stderr] Compiling tempfile v3.27.0 [INFO] [stderr] Compiling env_logger v0.11.10 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling async-compression v0.4.36 [INFO] [stderr] Compiling tower v0.5.2 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling tokio-util v0.7.17 [INFO] [stderr] Compiling atrium-common v0.1.2 [INFO] [stderr] Compiling atrium-api v0.25.7 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling hyper-util v0.1.19 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling atrium-xrpc-client v0.5.14 [INFO] [stderr] Compiling bsky-sdk v0.1.23 [INFO] [stderr] Compiling gen-bsky v0.1.17 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 1m 02s [INFO] running `Command { std: "docker" "inspect" "f9f2b17aef1d29f80ed62c5175a5d5d001f1c0cfe9ed726585503e7d9f15234d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f9f2b17aef1d29f80ed62c5175a5d5d001f1c0cfe9ed726585503e7d9f15234d", kill_on_drop: false }` [INFO] [stdout] f9f2b17aef1d29f80ed62c5175a5d5d001f1c0cfe9ed726585503e7d9f15234d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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" "+562dee4820c458d823175268e41601d4c060588a" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 8ecda707e57fa46a63bd73b9c5ec76aa9250098bd902fa793ef00079c557e6d0 [INFO] running `Command { std: "docker" "start" "-a" "8ecda707e57fa46a63bd73b9c5ec76aa9250098bd902fa793ef00079c557e6d0", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.37s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/gen_bsky-f7169d2fd560b905) [INFO] [stdout] [INFO] [stdout] running 345 tests [INFO] [stdout] test capitalise::test::test_all_numbers ... ok [INFO] [stdout] test capitalise::test::test_accented_lowercase ... ok [INFO] [stdout] test capitalise::test::test_all_punctuation ... ok [INFO] [stdout] test capitalise::test::test_arabic ... ok [INFO] [stdout] test capitalise::test::test_arabic_with_latin ... ok [INFO] [stdout] test capitalise::test::test_cedilla ... ok [INFO] [stdout] test capitalise::test::test_chinese ... ok [INFO] [stdout] test capitalise::test::test_control_characters ... ok [INFO] [stdout] test capitalise::test::test_already_capitalised ... ok [INFO] [stdout] test capitalise::test::test_accented_uppercase ... ok [INFO] [stdout] test capitalise::test::test_combining_characters ... ok [INFO] [stdout] test capitalise::test::test_cyrillic_lowercase ... ok [INFO] [stdout] test capitalise::test::test_cyrillic_uppercase ... ok [INFO] [stdout] test capitalise::test::test_cyrillic_mixed ... ok [INFO] [stdout] test capitalise::test::test_documentation_examples ... ok [INFO] [stdout] test capitalise::test::test_emoji_mixed ... ok [INFO] [stdout] test capitalise::test::test_german_eszett ... ok [INFO] [stdout] test capitalise::test::test_german_eszett_in_word ... ok [INFO] [stdout] test capitalise::test::test_greek_lowercase ... ok [INFO] [stdout] test capitalise::test::test_greek_uppercase ... ok [INFO] [stdout] test capitalise::test::test_greek_mixed ... ok [INFO] [stdout] test capitalise::test::test_hyphen_first ... ok [INFO] [stdout] test capitalise::test::test_leading_whitespace ... ok [INFO] [stdout] test capitalise::test::test_japanese_katakana ... ok [INFO] [stdout] test capitalise::test::test_lowercase_word ... ok [INFO] [stdout] test capitalise::test::test_mathematical_symbol ... ok [INFO] [stdout] test capitalise::test::test_mixed_case_word ... ok [INFO] [stdout] test capitalise::test::test_mixed_punctuation_and_letters ... ok [INFO] [stdout] test capitalise::test::test_japanese_hiragana ... ok [INFO] [stdout] test capitalise::test::test_multi_byte_char_first ... ok [INFO] [stdout] test capitalise::test::test_sentence ... ok [INFO] [stdout] test capitalise::test::test_empty_string ... ok [INFO] [stdout] test capitalise::test::test_single_byte_char ... ok [INFO] [stdout] test capitalise::test::test_latin_cyrillic_mix ... ok [INFO] [stdout] test capitalise::test::test_multiple_calls_same_result ... ok [INFO] [stdout] test capitalise::test::test_no_allocation_for_empty ... ok [INFO] [stdout] test capitalise::test::test_newline_first ... ok [INFO] [stdout] test capitalise::test::test_number_letter_mix ... ok [INFO] [stdout] test capitalise::test::test_number_first ... ok [INFO] [stdout] test capitalise::test::test_single_lowercase_char ... ok [INFO] [stdout] test capitalise::test::test_only_whitespace ... ok [INFO] [stdout] test capitalise::test::test_space_first ... ok [INFO] [stdout] test capitalise::test::test_original_string_unchanged ... ok [INFO] [stdout] test capitalise::test::test_punctuation_first ... ok [INFO] [stdout] test capitalise::test::test_string_from_format ... ok [INFO] [stdout] test capitalise::test::test_single_uppercase_char ... ok [INFO] [stdout] test capitalise::test::test_string_from_string_type ... ok [INFO] [stdout] test capitalise::test::test_string_literal ... ok [INFO] [stdout] test capitalise::test::test_surrogate_pairs ... ok [INFO] [stdout] test capitalise::test::test_symbol_first ... ok [INFO] [stdout] test capitalise::test::test_long_unicode_string ... ok [INFO] [stdout] test capitalise::test::test_symbol_letter_mix ... ok [INFO] [stdout] test capitalise::test::test_tab_first ... ok [INFO] [stdout] test capitalise::test::test_tilde ... ok [INFO] [stdout] test capitalise::test::test_trailing_whitespace ... ok [INFO] [stdout] test capitalise::test::test_trait_multiple_implementations_consistent ... ok [INFO] [stdout] test capitalise::test::test_turkish_dotted_i ... ok [INFO] [stdout] test capitalise::test::test_underscore_first ... ok [INFO] [stdout] test capitalise::test::test_umlaut ... ok [INFO] [stdout] test capitalise::test::test_uppercase_word ... ok [INFO] [stdout] test capitalise::test::test_very_long_string ... ok [INFO] [stdout] test capitalise::test::test_zero_width_characters ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_clone ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_debug_formatting ... ok [INFO] [stdout] test capitalise::test::test_emoji_first ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_default_creation ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_description_with_empty_string ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_description_with_none_value ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_description_with_some_value ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_deserialize_from_json_string ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_deserialize_partial_json ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_hashtags_with_none_tags ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_hashtags_with_tags ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_serialize_deserialize ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_serialize_deserialize_with_nulls ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_tags_independence ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_tags_with_empty_vec ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_tags_with_none_value ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_tags_with_some_value ... ok [INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_with_unicode_content ... ok [INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_bluesky_accessor ... ok [INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_clone ... ok [INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_debug_implementation ... ok [INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_default_extra ... ok [INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_empty_toml_deserialization ... ok [INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_extra_with_bluesky ... ok [INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_has_config ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_accented_characters ... ok [INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_partial_bluesky_config ... ok [INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_toml_integration ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_already_capitalized ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_blog_post_tags ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_chinese_characters ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_apostrophes ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_cyrillic ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_camel_case_input ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_different_string_sources ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_documentation_existing_hashtags_example ... ok [INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_serialization_deserialization ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_documentation_basic_example ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_empty_words_in_tag ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_existing_hashtag_multi_word ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_greek_letters ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_existing_hashtag_single_word ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_hashtag_with_only_whitespace ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_idempotent_behaviour ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_hyphens_and_underscores ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_empty_vector ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_japanese_characters ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_all_special_characters ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_emoji_in_tags ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_all_uppercase ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_leading_and_trailing_whitespace ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_maximum_realistic_hashtag ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_mixed_case ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_mixed_empty_and_valid ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_mixed_existing_and_new ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_mixed_scripts ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_mixed_valid_and_invalid_input ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_documentation_mixed_format_example ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_multiple_multi_words ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_multiple_single_words ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_multiple_hash_symbols ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_multiple_spaces_between_words ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_empty_string ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_mixed_whitespace_types ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_leading_whitespace ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_large_number_of_tags ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_only_hashtag_symbol ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_numbers_in_tags ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_only_whitespace ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_numbers_only ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_order_preservation ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_only_newlines ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_only_tabs ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_ownership_transfer ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_punctuation_in_words ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_single_character ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_single_number ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_single_symbol ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_single_word ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_social_media_tags ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_technical_documentation_tags ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_three_words ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_trailing_whitespace ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_two_words ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_default_constructor ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_vector_capacity_efficiency ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_deserialize_taxonomies_basic ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_deserialize_taxonomies_empty ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_deserialize_taxonomies_with_spaces ... ok [INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_very_long_tag ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_deserialize_taxonomies_with_special_chars ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_deserialize_taxonomies_with_unicode ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_front_matter_integration ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_hashtags_empty ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_hashtags_empty_strings ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_hashtags_existing_hashtags ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_hashtags_mixed ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_hashtags_unicode ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_hashtags_special_chars ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_hashtags_basic ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_hashtags_whitespace ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_hashtags_with_spaces ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_new_constructor ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_ownership_semantics ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_serialize_taxonomies ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_repeated_tag_access ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_tags_empty ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_tags_basic ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_serialize_empty_taxonomies ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_tags_with_spaces ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_tags_with_unicode ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_tags_with_special_chars ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_date_from_toml_basic ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_date_comparison ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_date_from_toml_with_time ... ok [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_taxonomies_roundtrip ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_date_with_microseconds ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_date_from_toml_with_timezone ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_from_toml_basic ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_from_toml_bluesky_set_incorrectly ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_from_toml_invalid ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_from_toml_missing_tags ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_from_toml_with_extra ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_from_toml_with_extra_bluesky ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_from_toml_with_bluesky ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_front_matter_empty_toml ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_invalid_date_format ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_most_recent_date_both_dates_updated_newer ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmp2PqkV3" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmp2rIpl3" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmp2PqkV3/content/posts/` [INFO] [stdout] test draft::blog_post::front_matter::tests::test_hashtags_formatting ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_most_recent_date_both_dates_date_newer ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpEjX6Vs" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpdVy3bg" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::tests] Blog post content: "+++\ntitle = \"Test Blog Post\"\ndate = 2024-01-15\ndescription = \"A test blog post for unit testing\"\ndraft = false\n[taxonomies]\ntags = [\"rust\", \"testing\"]\n+++\n\nThis is the blog post content." [INFO] [stdout] test draft::blog_post::front_matter::tests::test_most_recent_date_only_date ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpoIwary" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpdVy3bg/content/blog/long-post.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpqWJtqu" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::tests] Path to blog_file: `"/tmp/.tmp2rIpl3/content/blog/test-post.md"` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpcOddL1" } [INFO] [stdout] test draft::blog_post::front_matter::tests::test_taxonomies_empty_tags ... ok [INFO] [stdout] test draft::blog_post::front_matter::tests::test_most_recent_date_only_updated ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::tests] Minimum date: Datetime { [INFO] [stderr] date: Some( [INFO] [stderr] Date { [INFO] [stderr] year: 2024, [INFO] [stderr] month: 1, [INFO] [stderr] day: 1, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] time: Some( [INFO] [stderr] Time { [INFO] [stderr] hour: 0, [INFO] [stderr] minute: 0, [INFO] [stderr] second: Some( [INFO] [stderr] 0, [INFO] [stderr] ), [INFO] [stderr] nanosecond: None, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] offset: Some( [INFO] [stderr] Z, [INFO] [stderr] ), [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmp2rIpl3/content/blog/test-post.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpVg9AoJ" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpcOddL1/content/blog/draft-post.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmptoC8H9" } [INFO] [stderr] [2026-04-10T07:33:43Z WARN gen_bsky::draft::blog_post::front_matter] blog marked as draft and not allowed [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::tests] Result of new post generation:/nErr( [INFO] [stderr] DraftNotAllowed, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpVg9AoJ/content/blog/bluesky-test.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::tests] Content of blog file: `+++ [INFO] [stderr] title = "Test Blog Post" [INFO] [stderr] date = 2024-01-15 [INFO] [stderr] description = "A test blog post for unit testing" [INFO] [stderr] draft = false [INFO] [stderr] [taxonomies] [INFO] [stderr] tags = ["rust", "testing"] [INFO] [stderr] +++ [INFO] [stderr] [INFO] [stderr] This is the blog post content.` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpi60B97" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpEjX6Vs/content/blog/test-post.md` [INFO] [stdout] test draft::blog_post::front_matter::tests::test_most_recent_date_no_dates ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpi60B97/content/blog/accessor-test.md` [INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_large_tag_vector ... ok [INFO] [stdout] test draft::blog_post::tests::test_error_display_formatting ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_builder_state_after_success ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_absolute_paths ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_duplicate_paths ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_mixed_types_in_sequence ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_empty_path ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_method_chaining ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpqWJtqu/content/blog/multi-test.md` [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_preserves_order ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmptoC8H9/content/blog/unicode-test.md` [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_multiple_paths ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpoxpPRO" } [INFO] [stdout] test draft::blog_post::tests::test_blog_post_draft_not_allowed_error ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_relative_paths ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_with_path_ref ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_with_string ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_with_string_literal ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpoIwary/content/blog/format-test.md` [INFO] [stdout] test draft::blog_post::tests::test_blog_post_new_with_directory_path ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_returns_mutable_reference ... ok [INFO] [stdout] test draft::draft_builder::tests::test_blog_post_list_empty_display ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpoxpPRO/content/blog/referrer-test.md` [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_with_pathbuf ... ok [INFO] [stderr] [2026-04-10T07:33:43Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stdout] test draft::draft_builder::tests::test_error_message_consistency ... ok [INFO] [stderr] path: "/tmp/.tmpqWJtqu/content/blog/multi-test.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Blog Post", [INFO] [stderr] description: "A test blog post for unit testing", [INFO] [stderr] date: Some( [INFO] [stderr] Datetime { [INFO] [stderr] date: Some( [INFO] [stderr] Date { [INFO] [stderr] year: 2024, [INFO] [stderr] month: 1, [INFO] [stderr] day: 15, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] time: None, [INFO] [stderr] offset: None, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: Some( [INFO] [stderr] Taxonomies { [INFO] [stderr] tags: [ [INFO] [stderr] "rust", [INFO] [stderr] "testing", [INFO] [stderr] ], [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/multi-test", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/multi-test/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mth.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stdout] test draft::draft_builder::tests::test_equality_for_simple_variants ... ok [INFO] [stdout] test draft::draft_builder::tests::test_error_trait_implementation ... ok [INFO] [stdout] test draft::blog_post::tests::test_blog_post_accessors ... ok [INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_special_characters ... ok [INFO] [stdout] test draft::draft_builder::tests::test_debug_implementation ... ok [INFO] [stdout] test draft::draft_builder::tests::test_file_extension_invalid_various_combinations ... ok [INFO] [stdout] test draft::draft_builder::tests::test_future_capacity_too_large_debug ... ok [INFO] [stderr] [2026-04-10T07:33:43Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "/tmp/.tmpVg9AoJ/content/blog/bluesky-test.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Blog Post", [INFO] [stderr] description: "A test blog post for unit testing", [INFO] [stderr] date: Some( [INFO] [stderr] Datetime { [INFO] [stderr] date: Some( [INFO] [stderr] Date { [INFO] [stderr] year: 2024, [INFO] [stderr] month: 1, [INFO] [stderr] day: 15, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] time: None, [INFO] [stderr] offset: None, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: Some( [INFO] [stderr] Taxonomies { [INFO] [stderr] tags: [ [INFO] [stderr] "rust", [INFO] [stderr] "testing", [INFO] [stderr] ], [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/bluesky-test", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/bluesky-test/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mx5.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] } [INFO] [stdout] test draft::draft_builder::tests::test_error_trait_with_source ... ok [INFO] [stdout] test draft::draft_builder::tests::test_from_trait_implementations ... ok [INFO] [stdout] test draft::draft_builder::tests::test_future_capacity_too_large_display ... ok [INFO] [stdout] test draft::draft_builder::tests::test_io_error_display ... ok [INFO] [stdout] test draft::draft_builder::tests::test_file_extension_invalid_display ... ok [INFO] [stdout] test draft::draft_builder::tests::test_io_error_from_conversion ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpVg9AoJ/content/blog/bluesky-test.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/bluesky-test [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 41 characters and 41 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpkwS3QV" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpkwS3QV/content/blog/old-post.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmptoC8H9/content/blog/unicode-test.md` [INFO] [stderr] [2026-04-10T07:33:43Z WARN gen_bsky::draft::blog_post::front_matter] blog post too old to process [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::tests] BlogPost::new result: Ok(BlogPost { path: "/tmp/.tmp2rIpl3/content/blog/test-post.md", frontmatter: FrontMatter { title: "Test Blog Post", description: "A test blog post for unit testing", date: Some(Datetime { date: Some(Date { year: 2024, month: 1, day: 15 }), time: None, offset: None }), updated: None, draft: false, taxonomies: Some(Taxonomies { tags: ["rust", "testing"] }), extra: None, bluesky: None }, post_link: Url { scheme: "https", cannot_be_a_base: false, username: "", password: None, host: Some(Domain("www.example.com")), port: None, path: "/blog/test-post", query: None, fragment: None }, redirector: Redirector { long_path: UrlPath("/blog/test-post/"), short_file_name: "VGN4ms3.html", path: "s" }, post_short_link: None, bluesky_count: 0 }) [INFO] [stdout] test draft::draft_builder::tests::test_non_exhaustive_attribute ... ok [INFO] [stdout] test draft::draft_builder::tests::test_io_error_various_kinds ... ok [INFO] [stdout] test draft::draft_builder::tests::test_qualified_blog_post_list_empty_display ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "/tmp/.tmpEjX6Vs/content/blog/test-post.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Blog Post", [INFO] [stderr] description: "A test blog post for unit testing", [INFO] [stderr] date: Some( [INFO] [stderr] Datetime { [INFO] [stderr] date: Some( [INFO] [stderr] Date { [INFO] [stderr] year: 2024, [INFO] [stderr] month: 1, [INFO] [stderr] day: 15, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] time: None, [INFO] [stderr] offset: None, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: Some( [INFO] [stderr] Taxonomies { [INFO] [stderr] tags: [ [INFO] [stderr] "rust", [INFO] [stderr] "testing", [INFO] [stderr] ], [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/test-post", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/test-post/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4ms3.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpEjX6Vs/content/blog/test-post.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/test-post [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 38 characters and 38 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stdout] test draft::draft_builder::tests::test_toml_datetime_parse_error_display ... ok [INFO] [stdout] test draft::draft_builder::tests::test_path_not_found_display ... ok [INFO] [stdout] test draft::blog_post::tests::test_blog_post_too_old_error ... ok [INFO] [stdout] test draft::draft_builder::tests::test_url_parse_error_display ... ok [INFO] [stdout] test draft::draft_builder::tests::test_url_parse_error_from_conversion ... ok [INFO] [stdout] test draft::draft_builder::tests::test_path_not_found_with_various_paths ... ok [INFO] [stdout] test draft::blog_post::tests::test_blog_post_new_success ... ok [INFO] [stdout] test draft::draft_builder::tests::test_with_allow_draft_idempotent ... ok [INFO] [stdout] test draft::draft_builder::tests::test_with_allow_draft_method_chaining ... ok [INFO] [stdout] test draft::draft_builder::tests::test_toml_datetime_parse_error_from_conversion ... ok [INFO] [stdout] test draft::draft_builder::tests::test_with_allow_draft_returns_mutable_reference ... ok [INFO] [stdout] test draft::draft_builder::tests::test_with_allow_draft_multiple_calls ... ok [INFO] [stdout] test draft::draft_builder::tests::test_with_allow_draft_sets_false ... ok [INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_empty_string ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::tests] Post result: Ok( [INFO] [stderr] BlogPost { [INFO] [stderr] path: "/tmp/.tmpdVy3bg/content/blog/long-post.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Very Long Title That Will Cause Character Limit Issues", [INFO] [stderr] description: "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA", [INFO] [stderr] date: Some( [INFO] [stderr] Datetime { [INFO] [stderr] date: Some( [INFO] [stderr] Date { [INFO] [stderr] year: 2024, [INFO] [stderr] month: 1, [INFO] [stderr] day: 15, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] time: Some( [INFO] [stderr] Time { [INFO] [stderr] hour: 10, [INFO] [stderr] minute: 30, [INFO] [stderr] second: Some( [INFO] [stderr] 0, [INFO] [stderr] ), [INFO] [stderr] nanosecond: None, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] offset: Some( [INFO] [stderr] Z, [INFO] [stderr] ), [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/long-post", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/long-post/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mrm.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpdVy3bg/content/blog/long-post.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/long-post [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 38 characters and 38 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 54 characters and 54 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/unicode-test [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpoIwary/content/blog/format-test.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/format-test [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpqWJtqu/content/blog/multi-test.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/multi-test [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 39 characters and 39 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 33 characters and 33 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 33 characters and 33 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmprqtjI0/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmprqtjI0/content/blog/regular-post.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmprqtjI0/content/blog/_index.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Skipping file starting with '_': /tmp/.tmprqtjI0/content/blog/_index.md [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 33 characters and 33 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 250 characters and 250 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmprqtjI0/content/blog/_draft.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpoxpPRO/static/VGN4mye.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 250 characters and 250 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::tests] Result: Err(PostTooManyCharacters("Very Long Title That Will Cause Character Limit Issues", 347)) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 40 characters and 40 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/VGN4mye.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_error_types ... ok [INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_method_chaining_success ... ok [INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_returns_mutable_reference ... ok [INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_updates_field ... ok [INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_multiple_successful_calls ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Skipping file starting with '_': /tmp/.tmprqtjI0/content/blog/_draft.md [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmprqtjI0/content/blog/regular-post.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::tests] The short link is: `"https://www.example.com/VGN4mye.html"` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 41 characters and 41 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 19 characters and 13 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 43 characters and 37 graphemes [INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_valid_date ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 43 characters and 37 graphemes [INFO] [stdout] test draft::tests::test_builder_creates_new_instance_each_time ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stdout] test draft::tests::test_builder_functional_style ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stdout] test draft::draft_builder::tests::test_excludes_files_starting_with_underscore ... ok [INFO] [stderr] [2026-04-10T07:33:43Z WARN gen_bsky::draft::draft_builder] No blog posts found [INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_different_valid_formats ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes [INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_invalid_format ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes [INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_error_preserves_state ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 33 characters and 33 graphemes [INFO] [stdout] test draft::draft_builder::tests::test_with_allow_draft_sets_true ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes [INFO] [stdout] test draft::blog_post::tests::test_write_referrer_file_to ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes [INFO] [stdout] test draft::blog_post::tests::test_post_text_too_many_characters ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::tests] Generated post text: [INFO] [stdout] test draft::tests::test_builder_path_ownership ... ok [INFO] [stderr] "Test Blog Post\n\nA test blog post for unit testing #Rust #Testing\n\nhttps://www.example.com/blog/format-test" [INFO] [stdout] test draft::tests::test_builder_with_complex_url ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpJ6hFhq" } [INFO] [stdout] test draft::blog_post::tests::test_unicode_grapheme_handling ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpJ6hFhq`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stdout] test draft::tests::test_builder_with_absolute_root_path ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpJ6hFhq/content/blog` [INFO] [stdout] test draft::tests::test_builder_with_http_url ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpcXGfdB" } [INFO] [stdout] test draft::tests::test_builder_with_https_url ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Random name for test directory: `VGN4mTx` [INFO] [stdout] test draft::tests::test_builder_url_ownership ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpGKtGEI" } [INFO] [stdout] test draft::tests::test_builder_with_valid_url_and_root_path ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpJ6hFhq`, name: `post_2.md`, frontmatter: "Title: Test Post Two will Fail" [INFO] [stdout] test draft::tests::test_builder_with_windows_style_path ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpJ6hFhq`, name: `post_3.md`, frontmatter: FrontMatter { title: "Test Post Three will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stdout] test draft::tests::test_builder_with_relative_root_path ... ok [INFO] [stdout] test draft::tests::test_builder_with_empty_path ... ok [INFO] [stdout] test draft::blog_post::tests::test_build_post_text_format ... ok [INFO] [stdout] test draft::draft_builder::tests::test_with_min_date_for_valid_date ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpETalVk" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpQd2NTn" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpiJ6QY5" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpvNS5bN" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpQd2NTn`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpcXGfdB`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpcXGfdB/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpJ6hFhq/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpJ6hFhq/content/blog/post_2.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpJ6hFhq/content/blog/post_3.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpQd2NTn/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpiJ6QY5`, name: `test-post.md`, frontmatter: FrontMatter { title: "Test Post", description: "Description of test post", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stdout] test draft::tests::test_builder_with_url_containing_path ... ok [INFO] [stdout] test draft::tests::test_builder_with_url_containing_port ... ok [INFO] [stdout] test draft::tests::test_builder_with_valid_url_and_no_root ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpiJ6QY5/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmp31YpXW" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpJ823yC" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmp68pYiR" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z WARN gen_bsky::draft::draft_builder] No blog posts found [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpiJ6QY5/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpiJ6QY5/content/blog/test-post.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpiJ6QY5/content/blog/test-post.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpGKtGEI`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpGKtGEI/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stdout] test draft::tests::test_write_referrers_handles_empty_blog_posts ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpGKtGEI/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpcXGfdB/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpcXGfdB/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpGKtGEI/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpGKtGEI/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpETalVk`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpvNS5bN`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpvNS5bN/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpETalVk/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpvNS5bN`, name: `post_2.md`, frontmatter: "Title: Test Post Two will Fail" [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "content/blog/post_1.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Post One will Pass", [INFO] [stderr] description: "This post will pass", [INFO] [stderr] date: None, [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/post_1", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/post_1/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mmm.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1 [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpQd2NTn`, name: `post_2.md`, frontmatter: FrontMatter { title: "Test Post two will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpDpNhra" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpDpNhra`, name: `test-post.md`, frontmatter: FrontMatter { title: "Test Post", description: "Description of test post", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpJ6hFhq/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpJ6hFhq/content/blog/post_2.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z WARN gen_bsky::draft::draft_builder] `content/blog/post_2.md` excluded because `toml deserialization error says: Error { message: "key with no value, expected `=`", input: Some("Title: Test Post Two will Fail+++\n"), keys: [], span: Some(7..7) }` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpJ6hFhq/content/blog/post_3.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpJ6hFhq/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "content/blog/post_3.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Post Three will Pass", [INFO] [stderr] description: "This post will pass", [INFO] [stderr] date: None, [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/post_3", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/post_3/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mmy.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpDpNhra/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmptE19WA" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpvNS5bN`, name: `post_3.md`, frontmatter: FrontMatter { title: "Test Post Three will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpvNS5bN/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpvNS5bN/content/blog/post_2.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpvNS5bN/content/blog/post_3.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpvNS5bN/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpvNS5bN/content/blog/post_2.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmp31YpXW`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmp31YpXW/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpQd2NTn/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpcXGfdB/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "content/blog/test-post.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Post", [INFO] [stderr] description: "Description of test post", [INFO] [stderr] date: None, [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/test-post", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/test-post/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4msK.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/test-post.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/test-post [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 38 characters and 38 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "content/blog/post_1.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Post One will Pass", [INFO] [stderr] description: "This post will pass", [INFO] [stderr] date: None, [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/post_1", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/post_1/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mn2.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1 [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpqZtemM" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmp31YpXW/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmp31YpXW/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmp31YpXW/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpJ823yC`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpJ823yC/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpDpNhra/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpDpNhra/content/blog/test-post.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_3.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpQd2NTn/content/blog/post_2.md") [INFO] [stderr] [2026-04-10T07:33:43Z WARN gen_bsky::draft::draft_builder] No blog posts found [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpETalVk/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpqZtemM`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpqZtemM/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpDpNhra/content/blog/test-post.md` [INFO] [stderr] [2026-04-10T07:33:43Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "content/blog/test-post.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Post", [INFO] [stderr] description: "Description of test post", [INFO] [stderr] date: None, [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/test-post", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/test-post/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4msl.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stdout] test draft::tests::test_write_bluesky_posts_empty_blog_posts ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpETalVk/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_3 [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmp31YpXW/static/s/VGN4mn3.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpQd2NTn/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpQd2NTn/content/blog/post_2.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/s/VGN4mn3.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z WARN gen_bsky::draft::draft_builder] `content/blog/post_2.md` excluded because `toml deserialization error says: Error { message: "key with no value, expected `=`", input: Some("Title: Test Post Two will Fail+++\n"), keys: [], span: Some(7..7) }` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpvNS5bN/content/blog/post_3.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpqZtemM/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpJ823yC`, name: `post_2.md`, frontmatter: "Title: Test Post Two will Fail" [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpETalVk/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/test-post.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/test-post [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 38 characters and 38 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 9 characters and 9 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 24 characters and 24 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 24 characters and 24 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpvNS5bN/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpUnJMhE" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpUnJMhE`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpUnJMhE/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpJ823yC`, name: `post_3.md`, frontmatter: FrontMatter { title: "Test Post Three will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpqZtemM/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpqZtemM/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpQd2NTn/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 9 characters and 9 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpETalVk/static/s/VGN4mnD.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/s/VGN4mnD.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpJ823yC/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpUnJMhE`, name: `post_2.md`, frontmatter: FrontMatter { title: "Test Post Two will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpvNS5bN/static/s/VGN4mnD.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/s/VGN4mnD.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpJ823yC/content/blog/post_2.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpJ823yC/content/blog/post_3.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpJ823yC/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpJ823yC/content/blog/post_2.md` [INFO] [stderr] [2026-04-10T07:33:43Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stdout] test draft::tests::test_write_referrers_creates_directory_if_not_exists ... ok [INFO] [stderr] path: "content/blog/post_2.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Post two will Pass", [INFO] [stderr] description: "This post will pass", [INFO] [stderr] date: None, [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/post_2", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/post_2/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mnD.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpUnJMhE`, name: `post_3.md`, frontmatter: FrontMatter { title: "Test Post Three will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z WARN gen_bsky::draft::draft_builder] `content/blog/post_2.md` excluded because `toml deserialization error says: Error { message: "key with no value, expected `=`", input: Some("Title: Test Post Two will Fail+++\n"), keys: [], span: Some(7..7) }` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpETalVk/relative/path/VGN4mnD.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 24 characters and 24 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 24 characters and 24 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpUnJMhE/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 25 characters and 25 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpt2vqSY" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpqZtemM/static/s/VGN4mnK.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/s/VGN4mnK.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpvNS5bN/static/s/VGN4mnE.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_2.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/s/VGN4mnE.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpUnJMhE/content/blog/post_2.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpUnJMhE/content/blog/post_3.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpUnJMhE/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpUnJMhE/content/blog/post_2.md` [INFO] [stdout] test draft::tests::test_write_referrers_continues_on_individual_errors ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpUnJMhE/content/blog/post_3.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpUnJMhE/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpYuD45M" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpYuD45M`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpYuD45M/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpJ823yC/content/blog/post_3.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpYuD45M/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpJ823yC/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_2 [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpYuD45M/content/blog/post_1.md") [INFO] [stdout] test draft::tests::test_write_referrers_directory_creation_failure ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpt2vqSY`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/relative/path/VGN4mnD.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpt2vqSY/content/blog` [INFO] [stdout] test draft::tests::test_write_referrers_absolute_vs_relative_path_handling ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpUnJMhE/static/s/VGN4mna.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpt2vqSY/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpt2vqSY/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/s/VGN4mna.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpt2vqSY/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpYuD45M/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpynWshf" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpynWshf`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpynWshf/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpt2vqSY/static/s/VGN4mnh.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/s/VGN4mnh.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpynWshf/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpynWshf/content/blog/post_1.md") [INFO] [stdout] test draft::tests::test_write_referrers_returns_self_reference ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpynWshf/content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpelyAEV" } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpYuD45M/static/s/VGN4mnk.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpelyAEV`, name: `post_1.md`, frontmatter: FrontMatter { title: "Test Post One will Pass", description: "This post will pass", date: None, updated: None, draft: false, taxonomies: None, extra: None, bluesky: None } [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/s/VGN4mnk.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpelyAEV/content/blog` [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty. [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_clone ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpelyAEV/content/blog") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpelyAEV/content/blog/post_1.md") [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpelyAEV/content/blog/post_1.md` [INFO] [stdout] test draft::tests::test_write_referrers_uses_existing_directory ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_debug ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpynWshf/custom/referrers/VGN4mnr.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/custom/referrers/VGN4mnr.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpqZtemM/another/path/VGN4mnK.html [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_file_path_accessor ... ok [INFO] [stdout] test draft::tests::test_write_referrers_with_custom_path ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/another/path/VGN4mnK.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpUnJMhE/static/s/VGN4mnb.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/s/VGN4mnb.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_new_initial_state ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_new ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpelyAEV/deeply/nested/custom/path/VGN4mnt.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/deeply/nested/custom/path/VGN4mnt.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpUnJMhE/static/s/VGN4mna.html [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::draft::blog_post] Saved short post link Some( [INFO] [stderr] Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/s/VGN4mna.html", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] ) [INFO] [stdout] test draft::tests::test_write_referrers_method_chaining ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_set_state ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_post_accessor ... ok [INFO] [stdout] test draft::tests::test_write_referrers_with_nested_custom_path ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_set_state_non_linear_transitions ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_new_with_different_content ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_state_accessor ... ok [INFO] [stdout] test draft::tests::test_write_referrers_processes_all_blog_posts ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_state_debug ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_state_clone ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_set_state_same_state ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_state_equality ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_state_filtering ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_with_empty_text ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_with_long_path ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_with_unicode_content ... ok [INFO] [stdout] test post::bsky_post::tests::test_bsky_post_with_relative_path ... ok [INFO] [stdout] test post::bsky_post::tests::test_state_changes_performance ... ok [INFO] [stdout] test post::tests::test_count_deleted_none ... ok [INFO] [stdout] test post::bsky_post::tests::test_multiple_posts_state_filtering ... ok [INFO] [stdout] test post::bsky_post::tests::test_state_transition_workflow ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::post] Deleting related file: "/tmp/.tmpkyeOE4/test1.post" [INFO] [stdout] test post::tests::test_delete_posted_posts_file_not_found ... ok [INFO] [stdout] test post::tests::test_count_deleted_with_deleted_posts ... ok [INFO] [stderr] [2026-04-10T07:33:43Z DEBUG gen_bsky::post] Deleting related file: "/tmp/.tmpaPFsV7/test2.post" [INFO] [stderr] [2026-04-10T07:33:43Z INFO gen_bsky::post] Successfully deleted `/tmp/.tmpaPFsV7/test2.post` bluesky post file [INFO] [stdout] test post::tests::test_fluent_interface ... ok [INFO] [stdout] test post::bsky_post::tests::test_many_posts_creation ... ok [INFO] [stdout] test post::tests::test_error_display ... ok [INFO] [stdout] test post::tests::test_delete_posted_posts_no_posted ... ok [INFO] [stdout] test post::tests::test_large_number_of_posts ... ok [INFO] [stdout] test post::tests::test_delete_posted_posts_with_posted ... ok [INFO] [stdout] test post::tests::test_load_empty_directory ... ok [INFO] [stdout] test post::tests::test_load_accumulative ... ok [INFO] [stdout] test post::tests::test_load_invalid_json ... ok [INFO] [stdout] test post::tests::test_load_no_post_files ... ok [INFO] [stdout] test post::tests::test_load_success ... ok [INFO] [stdout] test post::tests::test_post_clone ... ok [INFO] [stdout] test post::tests::test_post_debug ... ok [INFO] [stdout] test post::tests::test_post_default ... ok [INFO] [stdout] test post::tests::test_post_new_both_empty ... ok [INFO] [stdout] test post::tests::test_load_nonexistent_directory ... ok [INFO] [stdout] test post::tests::test_post_new_success ... ok [INFO] [stdout] test post::tests::test_post_new_empty_identifier ... ok [INFO] [stdout] test post::tests::test_post_new_empty_password ... ok [INFO] [stdout] test post::tests::test_post_new_whitespace_identifier ... ok [INFO] [stdout] test draft::tests::test_write_bluesky_posts_with_default_store ... FAILED [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpGKtGEI/bluesky/HwDlHw.post` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `multi-test.md` as `PCL1PC` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpqWJtqu/posts/PCL1PC.post` [INFO] [stdout] test draft::blog_post::tests::test_get_bluesky_record_success ... ok [INFO] [stdout] test draft::tests::test_write_bluesky_posts_existing_directory ... ok [INFO] [stderr] [2026-04-10T07:33:44Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "/tmp/.tmpqWJtqu/content/blog/multi-test.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Blog Post", [INFO] [stderr] description: "A test blog post for unit testing", [INFO] [stderr] date: Some( [INFO] [stderr] Datetime { [INFO] [stderr] date: Some( [INFO] [stderr] Date { [INFO] [stderr] year: 2024, [INFO] [stderr] month: 1, [INFO] [stderr] day: 15, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] time: None, [INFO] [stderr] offset: None, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: Some( [INFO] [stderr] Taxonomies { [INFO] [stderr] tags: [ [INFO] [stderr] "rust", [INFO] [stderr] "testing", [INFO] [stderr] ], [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/multi-test", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/multi-test/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mth.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 1, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpqWJtqu/content/blog/multi-test.md` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/multi-test [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post link: 39 characters and 39 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 33 characters and 33 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpcXGfdB/bluesky/HwDlHw.post` [INFO] [stderr] [2026-04-10T07:33:44Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "content/blog/post_1.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Post One will Pass", [INFO] [stderr] description: "This post will pass", [INFO] [stderr] date: None, [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/post_1", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/post_1/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mn2.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 1, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1 [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_3.md` as `HyDnHy` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpJ6hFhq/bluesky/HyDnHy.post` [INFO] [stderr] [2026-04-10T07:33:44Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "content/blog/post_1.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Post One will Pass", [INFO] [stderr] description: "This post will pass", [INFO] [stderr] date: None, [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/post_1", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/post_1/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mmw.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1 [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_2.md` as `HxDmHx` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpQd2NTn/bluesky/HxDmHx.post` [INFO] [stderr] [2026-04-10T07:33:44Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "content/blog/post_1.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Post One will Pass", [INFO] [stderr] description: "This post will pass", [INFO] [stderr] date: None, [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/post_1", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/post_1/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mnJ.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 0, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `test-post.md` as `NZJONZ` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpiJ6QY5/deeply/nested/bluesky/directory/NZJONZ.post` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1 [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stdout] test draft::tests::test_write_bluesky_posts_creates_nested_directories ... ok [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG reqwest::connect] starting new connection: https://bsky.social/ [INFO] [stdout] test post::tests::test_post_to_bluesky_testing_mode ... ok [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `test-post.md` as `NZJONZ` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpDpNhra/custom/bluesky/path/NZJONZ.post` [INFO] [stdout] test draft::tests::test_write_bluesky_posts_with_custom_store ... ok [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `multi-test.md` as `PCL1PC` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpqWJtqu/posts/PCL1PC.post` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `bluesky-test.md` as `ScORSc` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpVg9AoJ/posts/ScORSc.post` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::tests] Record data: `{"createdAt":"2026-04-10T07:33:44.370407Z","facets":[{"features":[{"$type":"app.bsky.richtext.facet#link","uri":"https://www.example.com/blog/bluesky-test"}],"index":{"byteEnd":107,"byteStart":66}},{"features":[{"$type":"app.bsky.richtext.facet#tag","tag":"Rust"}],"index":{"byteEnd":55,"byteStart":50}},{"features":[{"$type":"app.bsky.richtext.facet#tag","tag":"Testing"}],"index":{"byteEnd":64,"byteStart":56}}],"text":"Test Blog Post\n\nA test blog post for unit testing #Rust #Testing\n\nhttps://www.example.com/blog/bluesky-test"}` [INFO] [stdout] test draft::blog_post::tests::test_write_bluesky_record_to ... ok [INFO] [stderr] [2026-04-10T07:33:44Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "/tmp/.tmpqWJtqu/content/blog/multi-test.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Blog Post", [INFO] [stderr] description: "A test blog post for unit testing", [INFO] [stderr] date: Some( [INFO] [stderr] Datetime { [INFO] [stderr] date: Some( [INFO] [stderr] Date { [INFO] [stderr] year: 2024, [INFO] [stderr] month: 1, [INFO] [stderr] day: 15, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] time: None, [INFO] [stderr] offset: None, [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: Some( [INFO] [stderr] Taxonomies { [INFO] [stderr] tags: [ [INFO] [stderr] "rust", [INFO] [stderr] "testing", [INFO] [stderr] ], [INFO] [stderr] }, [INFO] [stderr] ), [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/multi-test", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/multi-test/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mth.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 2, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpqWJtqu/content/blog/multi-test.md` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/multi-test [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post link: 39 characters and 39 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 33 characters and 33 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpJ6hFhq/bluesky/HwDlHw.post` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpcXGfdB/override/bsky/HwDlHw.post` [INFO] [stdout] test draft::tests::test_write_bluesky_posts_continues_on_individual_failures ... ok [INFO] [stdout] test draft::tests::test_write_bluesky_posts_path_resolution ... ok [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpQd2NTn/bluesky/HwDlHw.post` [INFO] [stderr] [2026-04-10T07:33:44Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "content/blog/post_2.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Post two will Pass", [INFO] [stderr] description: "This post will pass", [INFO] [stderr] date: None, [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/post_2", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/post_2/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mnD.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 1, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_2.md` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_2 [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `multi-test.md` as `PCL1PC` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpqWJtqu/posts/PCL1PC.post` [INFO] [stdout] test draft::blog_post::tests::test_write_bluesky_record_multiple_times ... ok [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_2.md` as `HxDmHx` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpQd2NTn/bluesky/HxDmHx.post` [INFO] [stderr] [2026-04-10T07:33:44Z INFO gen_bsky::draft::blog_post] Blog post: BlogPost { [INFO] [stderr] path: "content/blog/post_1.md", [INFO] [stderr] frontmatter: FrontMatter { [INFO] [stderr] title: "Test Post One will Pass", [INFO] [stderr] description: "This post will pass", [INFO] [stderr] date: None, [INFO] [stderr] updated: None, [INFO] [stderr] draft: false, [INFO] [stderr] taxonomies: None, [INFO] [stderr] extra: None, [INFO] [stderr] bluesky: None, [INFO] [stderr] }, [INFO] [stderr] post_link: Url { [INFO] [stderr] scheme: "https", [INFO] [stderr] cannot_be_a_base: false, [INFO] [stderr] username: "", [INFO] [stderr] password: None, [INFO] [stderr] host: Some( [INFO] [stderr] Domain( [INFO] [stderr] "www.example.com", [INFO] [stderr] ), [INFO] [stderr] ), [INFO] [stderr] port: None, [INFO] [stderr] path: "/blog/post_1", [INFO] [stderr] query: None, [INFO] [stderr] fragment: None, [INFO] [stderr] }, [INFO] [stderr] redirector: Redirector { [INFO] [stderr] long_path: UrlPath( [INFO] [stderr] "/blog/post_1/", [INFO] [stderr] ), [INFO] [stderr] short_file_name: "VGN4mnJ.html", [INFO] [stderr] path: "s", [INFO] [stderr] }, [INFO] [stderr] post_short_link: None, [INFO] [stderr] bluesky_count: 1, [INFO] [stderr] } [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1 [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw` [INFO] [stderr] [2026-04-10T07:33:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpQd2NTn/bluesky/HwDlHw.post` [INFO] [stdout] test draft::tests::test_write_bluesky_posts_multiple_calls ... ok [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- draft::tests::test_write_bluesky_posts_with_default_store stdout ---- [INFO] [stdout] [INFO] [stdout] thread 'draft::tests::test_write_bluesky_posts_with_default_store' (304) panicked at src/draft.rs:1186:35: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" } [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x5c35bdad742a - std[31e582c13f4e914f]::backtrace_rs::backtrace::libunwind::trace [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x5c35bdad742a - std[31e582c13f4e914f]::backtrace_rs::backtrace::trace_unsynchronized:: [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x5c35bdad742a - std[31e582c13f4e914f]::sys::backtrace::_print_fmt [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/sys/backtrace.rs:74:9 [INFO] [stdout] 3: 0x5c35bdad742a - <::print::DisplayBacktrace as core[fa0eadad68403074]::fmt::Display>::fmt [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/sys/backtrace.rs:44:26 [INFO] [stdout] 4: 0x5c35bdaf003a - ::fmt [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/core/src/fmt/rt.rs:152:76 [INFO] [stdout] 5: 0x5c35bdaf003a - core[fa0eadad68403074]::fmt::write [INFO] [stdout] 6: 0x5c35bdaddad2 - std[31e582c13f4e914f]::io::default_write_fmt::> [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x5c35bdaddad2 - as std[31e582c13f4e914f]::io::Write>::write_fmt [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/io/mod.rs:1994:13 [INFO] [stdout] 8: 0x5c35bdab2e4f - ::print [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/sys/backtrace.rs:47:9 [INFO] [stdout] 9: 0x5c35bdab2e4f - std[31e582c13f4e914f]::panicking::default_hook::{closure#0} [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/panicking.rs:292:27 [INFO] [stdout] 10: 0x5c35bdace259 - std[31e582c13f4e914f]::panicking::default_hook [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/panicking.rs:316:9 [INFO] [stdout] 11: 0x5c35bd013ecc - core[fa0eadad68403074]::ops::function::Fn<(&'a std[31e582c13f4e914f]::panic::PanicHookInfo<'b>,), Output = ()> + core[fa0eadad68403074]::marker::Sync + core[fa0eadad68403074]::marker::Send> as core[fa0eadad68403074]::ops::function::Fn<(&std[31e582c13f4e914f]::panic::PanicHookInfo,)>>::call [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/alloc/src/boxed.rs:2254:9 [INFO] [stdout] 12: 0x5c35bd013ecc - test[7530e63dc052480e]::test_main_with_exit_callback::::{closure#0} [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x5c35bdace4d2 - core[fa0eadad68403074]::ops::function::Fn<(&'a std[31e582c13f4e914f]::panic::PanicHookInfo<'b>,), Output = ()> + core[fa0eadad68403074]::marker::Sync + core[fa0eadad68403074]::marker::Send> as core[fa0eadad68403074]::ops::function::Fn<(&std[31e582c13f4e914f]::panic::PanicHookInfo,)>>::call [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/alloc/src/boxed.rs:2254:9 [INFO] [stdout] 14: 0x5c35bdace4d2 - std[31e582c13f4e914f]::panicking::panic_with_hook [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/panicking.rs:833:13 [INFO] [stdout] 15: 0x5c35bdab2f08 - std[31e582c13f4e914f]::panicking::panic_handler::{closure#0} [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/panicking.rs:698:13 [INFO] [stdout] 16: 0x5c35bdaa7c49 - std[31e582c13f4e914f]::sys::backtrace::__rust_end_short_backtrace:: [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/sys/backtrace.rs:182:18 [INFO] [stdout] 17: 0x5c35bdab3f9d - __rustc[fc8e3a9f23f26cb]::rust_begin_unwind [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/panicking.rs:689:5 [INFO] [stdout] 18: 0x5c35bdaf08ac - core[fa0eadad68403074]::panicking::panic_fmt [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x5c35bdaf05f2 - core[fa0eadad68403074]::result::unwrap_failed [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/core/src/result.rs:1867:5 [INFO] [stdout] 20: 0x5c35bcea357d - >::unwrap [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x5c35bcea357d - gen_bsky[becc8aeb392b8690]::draft::tests::test_write_bluesky_posts_with_default_store::{closure#0} [INFO] [stdout] at /opt/rustwide/workdir/src/draft.rs:1186:35 [INFO] [stdout] 22: 0x5c35bcec7f82 - > as core[fa0eadad68403074]::future::future::Future>::poll [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/core/src/future/future.rs:133:9 [INFO] [stdout] 23: 0x5c35bcec80bd - >> as core[fa0eadad68403074]::future::future::Future>::poll [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/core/src/future/future.rs:133:9 [INFO] [stdout] 24: 0x5c35bce4eb3d - ::block_on::>>>::{closure#0}::{closure#0}::{closure#0} [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/scheduler/current_thread/mod.rs:769:70 [INFO] [stdout] 25: 0x5c35bce4e97b - tokio[68f532f1824b0dd2]::task::coop::with_budget::, ::block_on>>>::{closure#0}::{closure#0}::{closure#0}> [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/task/coop/mod.rs:167:5 [INFO] [stdout] 26: 0x5c35bce4e97b - tokio[68f532f1824b0dd2]::task::coop::budget::, ::block_on>>>::{closure#0}::{closure#0}::{closure#0}> [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/task/coop/mod.rs:133:5 [INFO] [stdout] 27: 0x5c35bce4e97b - ::block_on::>>>::{closure#0}::{closure#0} [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/scheduler/current_thread/mod.rs:769:25 [INFO] [stdout] 28: 0x5c35bce27c30 - ::enter::, ::block_on>>>::{closure#0}::{closure#0}> [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/scheduler/current_thread/mod.rs:446:19 [INFO] [stdout] 29: 0x5c35bce4aced - ::block_on::>>>::{closure#0} [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/scheduler/current_thread/mod.rs:768:44 [INFO] [stdout] 30: 0x5c35bce48874 - ::enter::<::block_on>>>::{closure#0}, core[fa0eadad68403074]::option::Option<()>>::{closure#0} [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/scheduler/current_thread/mod.rs:856:68 [INFO] [stdout] 31: 0x5c35bcf94bdb - >::set::<::enter<::block_on>>>::{closure#0}, core[fa0eadad68403074]::option::Option<()>>::{closure#0}, (alloc[49b8922c36ca62de]::boxed::Box, core[fa0eadad68403074]::option::Option<()>)> [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/context/scoped.rs:40:9 [INFO] [stdout] 32: 0x5c35bcdda1e9 - tokio[68f532f1824b0dd2]::runtime::context::set_scheduler::<(alloc[49b8922c36ca62de]::boxed::Box, core[fa0eadad68403074]::option::Option<()>), ::enter<::block_on>>>::{closure#0}, core[fa0eadad68403074]::option::Option<()>>::{closure#0}>::{closure#0} [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/context.rs:176:38 [INFO] [stdout] 33: 0x5c35bcfc9492 - >::try_with::, core[fa0eadad68403074]::option::Option<()>), ::enter<::block_on>>>::{closure#0}, core[fa0eadad68403074]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[49b8922c36ca62de]::boxed::Box, core[fa0eadad68403074]::option::Option<()>)> [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/thread/local.rs:462:12 [INFO] [stdout] 34: 0x5c35bcfc8b5e - >::with::, core[fa0eadad68403074]::option::Option<()>), ::enter<::block_on>>>::{closure#0}, core[fa0eadad68403074]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[49b8922c36ca62de]::boxed::Box, core[fa0eadad68403074]::option::Option<()>)> [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/thread/local.rs:426:20 [INFO] [stdout] 35: 0x5c35bcdb04bd - tokio[68f532f1824b0dd2]::runtime::context::set_scheduler::<(alloc[49b8922c36ca62de]::boxed::Box, core[fa0eadad68403074]::option::Option<()>), ::enter<::block_on>>>::{closure#0}, core[fa0eadad68403074]::option::Option<()>>::{closure#0}> [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/context.rs:176:17 [INFO] [stdout] 36: 0x5c35bce2c110 - ::enter::<::block_on>>>::{closure#0}, core[fa0eadad68403074]::option::Option<()>> [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/scheduler/current_thread/mod.rs:856:27 [INFO] [stdout] 37: 0x5c35bce2c526 - ::block_on::>>> [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/scheduler/current_thread/mod.rs:756:24 [INFO] [stdout] 38: 0x5c35bce47c10 - ::block_on::>>::{closure#0} [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/scheduler/current_thread/mod.rs:200:33 [INFO] [stdout] 39: 0x5c35bcf5d3c3 - tokio[68f532f1824b0dd2]::runtime::context::runtime::enter_runtime::<::block_on>>::{closure#0}, ()> [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/context/runtime.rs:65:16 [INFO] [stdout] 40: 0x5c35bce268e1 - ::block_on::>> [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/scheduler/current_thread/mod.rs:188:9 [INFO] [stdout] 41: 0x5c35bcf2bc04 - ::block_on_inner::>> [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/runtime.rs:371:52 [INFO] [stdout] 42: 0x5c35bcf2c03f - ::block_on::>> [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.50.0/src/runtime/runtime.rs:345:18 [INFO] [stdout] 43: 0x5c35bcebf1cf - gen_bsky[becc8aeb392b8690]::draft::tests::test_write_bluesky_posts_with_default_store [INFO] [stdout] at /opt/rustwide/workdir/src/draft.rs:1226:46 [INFO] [stdout] 44: 0x5c35bce9d517 - gen_bsky[becc8aeb392b8690]::draft::tests::test_write_bluesky_posts_with_default_store::{closure#0} [INFO] [stdout] at /opt/rustwide/workdir/src/draft.rs:1181:59 [INFO] [stdout] 45: 0x5c35bcd712a6 - >::call_once [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 46: 0x5c35bd007fab - core[fa0eadad68403074]::result::Result<(), alloc[49b8922c36ca62de]::string::String> as core[fa0eadad68403074]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 47: 0x5c35bd007fab - test[7530e63dc052480e]::__rust_begin_short_backtrace::, fn() -> core[fa0eadad68403074]::result::Result<(), alloc[49b8922c36ca62de]::string::String>> [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/test/src/lib.rs:663:18 [INFO] [stdout] 48: 0x5c35bd01499b - test[7530e63dc052480e]::run_test_in_process::{closure#0} [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/test/src/lib.rs:686:74 [INFO] [stdout] 49: 0x5c35bd01499b - as core[fa0eadad68403074]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/core/src/panic/unwind_safe.rs:275:9 [INFO] [stdout] 50: 0x5c35bd01499b - std[31e582c13f4e914f]::panicking::catch_unwind::do_call::, core[fa0eadad68403074]::result::Result<(), alloc[49b8922c36ca62de]::string::String>> [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/panicking.rs:581:40 [INFO] [stdout] 51: 0x5c35bd01499b - std[31e582c13f4e914f]::panicking::catch_unwind::, core[fa0eadad68403074]::panic::unwind_safe::AssertUnwindSafe> [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/panicking.rs:544:19 [INFO] [stdout] 52: 0x5c35bd01499b - std[31e582c13f4e914f]::panic::catch_unwind::, core[fa0eadad68403074]::result::Result<(), alloc[49b8922c36ca62de]::string::String>> [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/panic.rs:359:14 [INFO] [stdout] 53: 0x5c35bd01499b - test[7530e63dc052480e]::run_test_in_process [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/test/src/lib.rs:686:27 [INFO] [stdout] 54: 0x5c35bd01499b - test[7530e63dc052480e]::run_test::{closure#0} [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/test/src/lib.rs:607:43 [INFO] [stdout] 55: 0x5c35bd00edf4 - test[7530e63dc052480e]::run_test::{closure#1} [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/test/src/lib.rs:637:41 [INFO] [stdout] 56: 0x5c35bd00edf4 - std[31e582c13f4e914f]::sys::backtrace::__rust_begin_short_backtrace:: [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/sys/backtrace.rs:166:18 [INFO] [stdout] 57: 0x5c35bd0175a2 - std[31e582c13f4e914f]::thread::lifecycle::spawn_unchecked::::{closure#1}::{closure#0} [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/thread/lifecycle.rs:91:13 [INFO] [stdout] 58: 0x5c35bd0175a2 - ::{closure#1}::{closure#0}> as core[fa0eadad68403074]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/core/src/panic/unwind_safe.rs:275:9 [INFO] [stdout] 59: 0x5c35bd0175a2 - std[31e582c13f4e914f]::panicking::catch_unwind::do_call::::{closure#1}::{closure#0}>, ()> [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/panicking.rs:581:40 [INFO] [stdout] 60: 0x5c35bd0175a2 - std[31e582c13f4e914f]::panicking::catch_unwind::<(), core[fa0eadad68403074]::panic::unwind_safe::AssertUnwindSafe::{closure#1}::{closure#0}>> [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/panicking.rs:544:19 [INFO] [stdout] 61: 0x5c35bd0175a2 - std[31e582c13f4e914f]::panic::catch_unwind::::{closure#1}::{closure#0}>, ()> [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/panic.rs:359:14 [INFO] [stdout] 62: 0x5c35bd0175a2 - std[31e582c13f4e914f]::thread::lifecycle::spawn_unchecked::::{closure#1} [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/thread/lifecycle.rs:89:26 [INFO] [stdout] 63: 0x5c35bd0175a2 - ::{closure#1} as core[fa0eadad68403074]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0} [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 64: 0x5c35bdad67df - + core[fa0eadad68403074]::marker::Send> as core[fa0eadad68403074]::ops::function::FnOnce<()>>::call_once [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/alloc/src/boxed.rs:2240:9 [INFO] [stdout] 65: 0x5c35bdad67df - ::new::thread_start [INFO] [stdout] at /rustc/562dee4820c458d823175268e41601d4c060588a/library/std/src/sys/thread/unix.rs:118:17 [INFO] [stdout] 66: 0x793956d58aa4 - [INFO] [stdout] 67: 0x793956de5a64 - clone [INFO] [stdout] 68: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] draft::tests::test_write_bluesky_posts_with_default_store [INFO] [stdout] [INFO] [stdout] test result: FAILED. 344 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.79s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] running `Command { std: "docker" "inspect" "8ecda707e57fa46a63bd73b9c5ec76aa9250098bd902fa793ef00079c557e6d0", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8ecda707e57fa46a63bd73b9c5ec76aa9250098bd902fa793ef00079c557e6d0", kill_on_drop: false }` [INFO] [stdout] 8ecda707e57fa46a63bd73b9c5ec76aa9250098bd902fa793ef00079c557e6d0