[INFO] fetching crate gen-bsky 0.1.0...
[INFO] testing gen-bsky-0.1.0 against try#db823df02fd0c2cf67b43025ac3fef3f2d743245 for pr-150681
[INFO] extracting crate gen-bsky 0.1.0 into /workspace/builds/worker-0-tc2/source
[INFO] started tweaking crates.io crate gen-bsky 0.1.0
[INFO] finished tweaking crates.io crate gen-bsky 0.1.0
[INFO] tweaked toml for crates.io crate gen-bsky 0.1.0 written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate gen-bsky 0.1.0 on toolchain db823df02fd0c2cf67b43025ac3fef3f2d743245
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate gen-bsky 0.1.0 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" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7e682807ee081d6e6a90f601ed5db894ab8e84e782090fc8b9a2083ee38376f2
[INFO] running `Command { std: "docker" "start" "-a" "7e682807ee081d6e6a90f601ed5db894ab8e84e782090fc8b9a2083ee38376f2", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7e682807ee081d6e6a90f601ed5db894ab8e84e782090fc8b9a2083ee38376f2", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7e682807ee081d6e6a90f601ed5db894ab8e84e782090fc8b9a2083ee38376f2", kill_on_drop: false }`
[INFO] [stdout] 7e682807ee081d6e6a90f601ed5db894ab8e84e782090fc8b9a2083ee38376f2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 501d08ee83b0b7700d3889b1382f00b362266c8e1a6af16672e4524a9766b104
[INFO] running `Command { std: "docker" "start" "-a" "501d08ee83b0b7700d3889b1382f00b362266c8e1a6af16672e4524a9766b104", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.101
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling memchr v2.7.5
[INFO] [stderr]    Compiling socket2 v0.6.0
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling http v1.3.1
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]    Compiling percent-encoding v2.3.1
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling form_urlencoded v1.2.1
[INFO] [stderr]    Compiling lock_api v0.4.13
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling bitflags v2.9.2
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling foreign-types-shared v0.1.1
[INFO] [stderr]    Compiling foreign-types v0.3.2
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]    Compiling try-lock v0.2.5
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling data-encoding v2.9.0
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling event-listener v5.4.1
[INFO] [stderr]    Compiling want v0.3.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling event-listener-strategy v0.5.4
[INFO] [stderr]    Compiling data-encoding-macro-internal v0.1.16
[INFO] [stderr]    Compiling core2 v0.4.0
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling indexmap v2.10.0
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling base-x v0.2.11
[INFO] [stderr]    Compiling data-encoding-macro v0.1.18
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling moka v0.12.10
[INFO] [stderr]    Compiling unsigned-varint v0.8.0
[INFO] [stderr]    Compiling multibase v0.9.1
[INFO] [stderr]    Compiling flate2 v1.1.2
[INFO] [stderr]    Compiling uuid v1.18.0
[INFO] [stderr]    Compiling async-lock v3.4.1
[INFO] [stderr]    Compiling parking_lot v0.12.4
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.18
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling iana-time-zone v0.1.63
[INFO] [stderr]    Compiling tagptr v0.2.0
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]    Compiling iri-string v0.7.8
[INFO] [stderr]    Compiling anyhow v1.0.99
[INFO] [stderr]    Compiling thiserror v2.0.16
[INFO] [stderr]    Compiling proc-macro-error-attr2 v2.0.0
[INFO] [stderr]    Compiling include_dir_macros v0.7.4
[INFO] [stderr]    Compiling winnow v0.7.12
[INFO] [stderr]    Compiling dashmap v6.1.0
[INFO] [stderr]    Compiling psl-types v2.0.11
[INFO] [stderr]    Compiling psl v2.1.133
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling tokio-util v0.7.16
[INFO] [stderr]    Compiling async-compression v0.4.27
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling include_dir v0.7.4
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling proc-macro-error2 v2.0.1
[INFO] [stderr]    Compiling toml_parser v1.0.2
[INFO] [stderr]    Compiling base62 v2.2.1
[INFO] [stderr]    Compiling toml_writer v1.0.2
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.8.0
[INFO] [stderr]    Compiling trait-variant v0.1.2
[INFO] [stderr]    Compiling thiserror-impl v2.0.16
[INFO] [stderr]    Compiling zerovec v0.11.4
[INFO] [stderr]    Compiling zerotrie v0.2.2
[INFO] [stderr]    Compiling aquamarine v0.6.0
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling tinystr v0.8.1
[INFO] [stderr]    Compiling potential_utf v0.1.2
[INFO] [stderr]    Compiling icu_collections v2.0.0
[INFO] [stderr]    Compiling icu_locale_core v2.0.0
[INFO] [stderr]    Compiling icu_provider v2.0.0
[INFO] [stderr]    Compiling hyper v1.6.0
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling icu_properties v2.0.1
[INFO] [stderr]    Compiling icu_normalizer v2.0.0
[INFO] [stderr]    Compiling tower-http v0.6.6
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling hyper-util v0.1.16
[INFO] [stderr]    Compiling atrium-common v0.1.2
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling serde_json v1.0.143
[INFO] [stderr]    Compiling multihash v0.19.3
[INFO] [stderr]    Compiling serde_bytes v0.11.17
[INFO] [stderr]    Compiling serde_html_form v0.2.7
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling chrono v0.4.41
[INFO] [stderr]    Compiling langtag v0.3.4
[INFO] [stderr]    Compiling cid v0.11.1
[INFO] [stderr]    Compiling toml_datetime v0.7.0
[INFO] [stderr]    Compiling ipld-core v0.4.2
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling serde_spanned v1.0.0
[INFO] [stderr]    Compiling toml v0.9.5
[INFO] [stderr]    Compiling reqwest v0.12.23
[INFO] [stderr]    Compiling atrium-xrpc v0.12.3
[INFO] [stderr]    Compiling atrium-api v0.25.5
[INFO] [stderr]    Compiling link-bridge v0.2.3
[INFO] [stderr]    Compiling atrium-xrpc-client v0.5.14
[INFO] [stderr]    Compiling bsky-sdk v0.1.21
[INFO] [stderr]    Compiling gen-bsky v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 29s
[INFO] running `Command { std: "docker" "inspect" "501d08ee83b0b7700d3889b1382f00b362266c8e1a6af16672e4524a9766b104", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "501d08ee83b0b7700d3889b1382f00b362266c8e1a6af16672e4524a9766b104", kill_on_drop: false }`
[INFO] [stdout] 501d08ee83b0b7700d3889b1382f00b362266c8e1a6af16672e4524a9766b104
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6d40ca6125e767df1c7d3816cf0e22dc30d4df2a20962bb024fa12fb2e890688
[INFO] running `Command { std: "docker" "start" "-a" "6d40ca6125e767df1c7d3816cf0e22dc30d4df2a20962bb024fa12fb2e890688", kill_on_drop: false }`
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling bitflags v2.9.2
[INFO] [stderr]    Compiling rustix v1.0.8
[INFO] [stderr]    Compiling anstyle-query v1.1.4
[INFO] [stderr]    Compiling is_terminal_polyfill v1.70.1
[INFO] [stderr]    Compiling env_filter v0.1.3
[INFO] [stderr]    Compiling jiff v0.2.15
[INFO] [stderr]    Compiling anstream v0.6.20
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling tempfile v3.20.0
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling hyper v1.6.0
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tokio-util v0.7.16
[INFO] [stderr]    Compiling async-compression v0.4.27
[INFO] [stderr]    Compiling atrium-common v0.1.2
[INFO] [stderr]    Compiling atrium-api v0.25.5
[INFO] [stderr]    Compiling tower-http v0.6.6
[INFO] [stderr]    Compiling hyper-util v0.1.16
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling reqwest v0.12.23
[INFO] [stderr]    Compiling atrium-xrpc-client v0.5.14
[INFO] [stderr]    Compiling bsky-sdk v0.1.21
[INFO] [stderr]    Compiling gen-bsky v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1m 21s
[INFO] running `Command { std: "docker" "inspect" "6d40ca6125e767df1c7d3816cf0e22dc30d4df2a20962bb024fa12fb2e890688", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6d40ca6125e767df1c7d3816cf0e22dc30d4df2a20962bb024fa12fb2e890688", kill_on_drop: false }`
[INFO] [stdout] 6d40ca6125e767df1c7d3816cf0e22dc30d4df2a20962bb024fa12fb2e890688
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 52a40a7395d0a8d0d7137ca4011e7a9d3c37a85ac42bf5c128dfbbfa0a33cd3e
[INFO] running `Command { std: "docker" "start" "-a" "52a40a7395d0a8d0d7137ca4011e7a9d3c37a85ac42bf5c128dfbbfa0a33cd3e", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.46s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/gen_bsky-38ad3cd27571ad53)
[INFO] [stdout] 
[INFO] [stdout] running 344 tests
[INFO] [stdout] test capitalise::test::test_accented_uppercase ... 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_already_capitalised ... 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_combining_characters ... ok
[INFO] [stdout] test capitalise::test::test_cyrillic_lowercase ... 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_first ... ok
[INFO] [stdout] test capitalise::test::test_emoji_mixed ... ok
[INFO] [stdout] test capitalise::test::test_empty_string ... 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_mixed ... ok
[INFO] [stdout] test capitalise::test::test_greek_uppercase ... ok
[INFO] [stdout] test capitalise::test::test_hyphen_first ... ok
[INFO] [stdout] test capitalise::test::test_japanese_hiragana ... ok
[INFO] [stdout] test capitalise::test::test_japanese_katakana ... ok
[INFO] [stdout] test capitalise::test::test_latin_cyrillic_mix ... ok
[INFO] [stdout] test capitalise::test::test_leading_whitespace ... ok
[INFO] [stdout] test capitalise::test::test_long_unicode_string ... 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_multi_byte_char_first ... ok
[INFO] [stdout] test capitalise::test::test_all_numbers ... ok
[INFO] [stdout] test capitalise::test::test_cyrillic_uppercase ... ok
[INFO] [stdout] test capitalise::test::test_number_letter_mix ... ok
[INFO] [stdout] test capitalise::test::test_only_whitespace ... ok
[INFO] [stdout] test capitalise::test::test_multiple_calls_same_result ... ok
[INFO] [stdout] test capitalise::test::test_punctuation_first ... ok
[INFO] [stdout] test capitalise::test::test_newline_first ... ok
[INFO] [stdout] test capitalise::test::test_no_allocation_for_empty ... ok
[INFO] [stdout] test capitalise::test::test_number_first ... ok
[INFO] [stdout] test capitalise::test::test_original_string_unchanged ... ok
[INFO] [stdout] test capitalise::test::test_single_byte_char ... ok
[INFO] [stdout] test capitalise::test::test_single_lowercase_char ... ok
[INFO] [stdout] test capitalise::test::test_space_first ... ok
[INFO] [stdout] test capitalise::test::test_string_from_format ... ok
[INFO] [stdout] test capitalise::test::test_symbol_first ... ok
[INFO] [stdout] test capitalise::test::test_string_literal ... ok
[INFO] [stdout] test capitalise::test::test_single_uppercase_char ... ok
[INFO] [stdout] test capitalise::test::test_sentence ... ok
[INFO] [stdout] test capitalise::test::test_string_from_string_type ... ok
[INFO] [stdout] test capitalise::test::test_symbol_letter_mix ... ok
[INFO] [stdout] test capitalise::test::test_surrogate_pairs ... 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_turkish_dotted_i ... ok
[INFO] [stdout] test capitalise::test::test_umlaut ... ok
[INFO] [stdout] test capitalise::test::test_uppercase_word ... ok
[INFO] [stdout] test capitalise::test::test_zero_width_characters ... ok
[INFO] [stdout] test capitalise::test::test_trait_multiple_implementations_consistent ... ok
[INFO] [stdout] test capitalise::test::test_very_long_string ... ok
[INFO] [stdout] test draft::blog_post::front_matter::bluesky::tests::test_debug_formatting ... ok
[INFO] [stdout] test capitalise::test::test_underscore_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_clone ... 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_empty_string ... 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_with_nulls ... 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_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_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_debug_implementation ... 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_default_extra ... 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::extra::tests::test_empty_toml_deserialization ... ok
[INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_has_config ... ok
[INFO] [stdout] test draft::blog_post::front_matter::extra::tests::test_partial_bluesky_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_clone ... 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_blog_post_tags ... 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_camel_case_input ... 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_different_string_sources ... 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_documentation_basic_example ... 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_documentation_existing_hashtags_example ... 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_emoji_in_tags ... 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_existing_hashtag_single_word ... ok
[INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_greek_letters ... 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_hashtag_with_only_whitespace ... ok
[INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_empty_string ... 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_japanese_characters ... 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_maximum_realistic_hashtag ... 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_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_mixed_whitespace_types ... 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_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_spaces_between_words ... 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_numbers_only ... 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_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_only_whitespace ... ok
[INFO] [stdout] test capitalise::test::test_control_characters ... 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_empty_vector ... 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_mixed_case ... 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_all_uppercase ... 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_punctuation_in_words ... 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_single_character ... 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_two_words ... 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_single_symbol ... 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_trailing_whitespace ... 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_with_special_chars ... 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::taxonomies::tests::test_deserialize_taxonomies_with_unicode ... 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_deserialize_taxonomies_empty ... 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_strings ... 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_special_chars ... 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_unicode ... 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_with_spaces ... 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_repeated_tag_access ... 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_empty ... 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_tags_basic ... 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::tags::tests::test_vector_capacity_efficiency ... 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_comparison ... ok
[INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_default_constructor ... ok
[INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_new_constructor ... ok
[INFO] [stdout] test draft::blog_post::front_matter::tests::test_date_from_toml_basic ... ok
[INFO] [stdout] test draft::blog_post::front_matter::taxonomies::tests::test_large_tag_vector ... ok
[INFO] [stdout] test draft::blog_post::front_matter::tags::tests::test_very_long_tag ... 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_date_with_microseconds ... 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_invalid ... 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_basic ... 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_date_from_toml_with_time ... 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_hashtags_formatting ... ok
[INFO] [stdout] test draft::blog_post::front_matter::tests::test_most_recent_date_both_dates_date_newer ... ok
[INFO] [stdout] test draft::blog_post::front_matter::tests::test_most_recent_date_no_dates ... ok
[INFO] [stdout] test draft::blog_post::front_matter::tests::test_most_recent_date_both_dates_updated_newer ... 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_only_date ... ok
[INFO] [stdout] test draft::blog_post::front_matter::tests::test_taxonomies_empty_tags ... ok
[INFO] [stdout] test draft::blog_post::tests::test_error_display_formatting ... ok
[INFO] [stdout] test draft::blog_post::front_matter::tests::test_most_recent_date_only_updated ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpL5lt2F" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpL5lt2F/content/blog/accessor-test.md` 
[INFO] [stdout] test draft::blog_post::tests::test_blog_post_accessors ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpJu3jZ6" }
[INFO] [stdout] test draft::blog_post::tests::test_blog_post_new_with_directory_path ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpl7rjLk" }
[INFO] [stdout] test draft::blog_post::tests::test_blog_post_too_old_error ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z 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::tests::test_blog_post_new_success ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpl7rjLk/content/posts/` 
[INFO] [stdout] test draft::blog_post::tests::test_blog_post_draft_not_allowed_error ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::tests] Path to blog_file: `"/tmp/.tmpJu3jZ6/content/blog/test-post.md"`
[INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_absolute_paths ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::tests] Minimum date: Datetime {
[INFO] [stdout] test draft::blog_post::tests::test_build_post_text_format ... ok
[INFO] [stderr]         date: Some(
[INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_duplicate_paths ... ok
[INFO] [stderr]             Date {
[INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_empty_path ... ok
[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: 0,
[INFO] [stderr]                 nanosecond: 0,
[INFO] [stderr]             },
[INFO] [stderr]         ),
[INFO] [stderr]         offset: Some(
[INFO] [stderr]             Z,
[INFO] [stderr]         ),
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpJu3jZ6/content/blog/test-post.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpzx6qC1" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpzx6qC1/content/blog/old-post.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z WARN  gen_bsky::draft::blog_post::front_matter] blog post too old to process
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::tests] BlogPost::new result: Ok(BlogPost { path: "/tmp/.tmpJu3jZ6/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: "V7dTax7.html", path: "s" }, post_short_link: None, bluesky_count: 0 })
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmp7UhDvs" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmp7UhDvs/content/blog/draft-post.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z WARN  gen_bsky::draft::blog_post::front_matter] blog marked as draft and not allowed
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::tests] Result of new post generation:/nErr(
[INFO] [stderr]         DraftNotAllowed,
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmp1zqlp8" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpABPoQv" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmp1zqlp8/content/blog/unicode-test.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpR8TxXR" }
[INFO] [stderr] [2026-01-07T16:32:42Z 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-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpTbtxt5" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpn19CUv" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpR8TxXR/content/blog/format-test.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpTbtxt5/content/blog/long-post.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpn19CUv/content/blog/bluesky-test.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpR8TxXR/content/blog/format-test.md`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/format-test
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 40 characters and 40 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::tests] Post result: Ok(
[INFO] [stderr]         BlogPost {
[INFO] [stderr]             path: "/tmp/.tmpTbtxt5/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: 0,
[INFO] [stderr]                                 nanosecond: 0,
[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: "V7dTawt.html",
[INFO] [stderr]                 path: "s",
[INFO] [stderr]             },
[INFO] [stderr]             post_short_link: None,
[INFO] [stderr]             bluesky_count: 0,
[INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_method_chaining ... ok
[INFO] [stderr]         },
[INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_mixed_types_in_sequence ... ok
[INFO] [stderr]     )
[INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_multiple_paths ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpAnY82v" }
[INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_preserves_order ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z 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_add_path_or_file_relative_paths ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes
[INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_returns_mutable_reference ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes
[INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_special_characters ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpAnY82v/content/blog/test-post.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z INFO  gen_bsky::draft::blog_post] Blog post: BlogPost {
[INFO] [stderr]         path: "/tmp/.tmpn19CUv/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] [stdout] test draft::draft_builder::tests::test_add_path_or_file_with_path_ref ... ok
[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: "V7dTb2D.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 0,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::tests] Generated post text:
[INFO] [stderr]     "Test Blog Post\n\nA test blog post for unit testing #Rust #Testing\n\nhttps://www.example.com/blog/format-test"
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpABPoQv/content/blog/multi-test.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z INFO  gen_bsky::draft::blog_post] Blog post: BlogPost {
[INFO] [stderr]         path: "/tmp/.tmpAnY82v/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] [stdout] test draft::draft_builder::tests::test_add_path_or_file_with_pathbuf ... ok
[INFO] [stderr]             short_file_name: "V7dTaxB.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 0,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpn19CUv/content/blog/bluesky-test.md`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/bluesky-test
[INFO] [stderr] [2026-01-07T16:32:42Z INFO  gen_bsky::draft::blog_post] Blog post: BlogPost {
[INFO] [stderr]         path: "/tmp/.tmpABPoQv/content/blog/multi-test.md",
[INFO] [stderr]         frontmatter: FrontMatter {
[INFO] [stderr]             title: "Test Blog Post",
[INFO] [stdout] test draft::draft_builder::tests::test_add_path_or_file_with_string ... ok
[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] [stdout] test draft::draft_builder::tests::test_add_path_or_file_with_string_literal ... ok
[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: "V7dTayo.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 0,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpABPoQv/content/blog/multi-test.md`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/multi-test
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 39 characters and 39 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 33 characters and 33 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 41 characters and 41 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 33 characters and 33 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::util::test_utils] Created temp directory: TempDir { path: "/tmp/.tmpMVN4Zn" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpTbtxt5/content/blog/long-post.md`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/long-post
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpMVN4Zn/content/blog/referrer-test.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 38 characters and 38 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 54 characters and 54 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 250 characters and 250 graphemes
[INFO] [stdout] test draft::draft_builder::tests::test_blog_post_list_empty_display ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_debug_implementation ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_equality_for_simple_variants ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_error_message_consistency ... 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_error_trait_implementation ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_error_trait_with_source ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_file_extension_invalid_display ... 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] [stdout] test draft::draft_builder::tests::test_future_capacity_too_large_display ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_from_trait_implementations ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_io_error_display ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_io_error_from_conversion ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_io_error_various_kinds ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_non_exhaustive_attribute ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_path_not_found_display ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_path_not_found_with_various_paths ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_qualified_blog_post_list_empty_display ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_toml_datetime_parse_error_display ... 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_toml_datetime_parse_error_from_conversion ... 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_with_allow_draft_multiple_calls ... 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_sets_false ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_with_allow_draft_sets_true ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_different_valid_formats ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_empty_string ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 250 characters and 250 graphemes
[INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_error_preserves_state ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmp1zqlp8/content/blog/unicode-test.md`
[INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_error_types ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/unicode-test
[INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_invalid_format ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 41 characters and 41 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 19 characters and 13 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 43 characters and 37 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 43 characters and 37 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpAnY82v/content/blog/test-post.md`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/test-post
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 38 characters and 38 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 33 characters and 33 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpMVN4Zn/static/V7dTb3o.html
[INFO] [stderr] [2026-01-07T16:32:42Z 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: "/V7dTb3o.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::tests] The short link is: `"https://www.example.com/V7dTb3o.html"`
[INFO] [stdout] test draft::blog_post::tests::test_write_referrer_file_to ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_multiple_successful_calls ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stdout] test draft::blog_post::tests::test_unicode_grapheme_handling ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[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_returns_mutable_reference ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_valid_date ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stdout] test draft::tests::test_builder_creates_new_instance_each_time ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::tests] Result: Err(PostTooManyCharacters("Very Long Title That Will Cause Character Limit Issues", 347))
[INFO] [stdout] test draft::tests::test_builder_path_ownership ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z WARN  gen_bsky::draft::draft_builder] No blog posts found
[INFO] [stdout] test draft::tests::test_builder_url_ownership ... ok
[INFO] [stdout] test draft::draft_builder::tests::test_with_min_date_for_valid_date ... ok
[INFO] [stdout] test draft::tests::test_builder_with_complex_url ... ok
[INFO] [stdout] test draft::tests::test_builder_with_empty_path ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpTzOdot" }
[INFO] [stdout] test draft::blog_post::tests::test_post_text_too_many_characters ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpTzOdot`, 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_http_url ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpTzOdot/content/blog`
[INFO] [stdout] test draft::tests::test_builder_with_https_url ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpTzOdot`, name: `post_2.md`, frontmatter: "Title: Test Post Two will Fail"
[INFO] [stdout] test draft::tests::test_builder_with_relative_root_path ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpTzOdot`, 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_url_containing_path ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stdout] test draft::tests::test_builder_with_url_containing_port ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpTzOdot/content/blog")
[INFO] [stdout] test draft::tests::test_builder_with_valid_url_and_no_root ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpTzOdot/content/blog/post_2.md")
[INFO] [stdout] test draft::tests::test_builder_with_valid_url_and_root_path ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpTzOdot/content/blog/post_3.md")
[INFO] [stdout] test draft::tests::test_builder_with_windows_style_path ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpTzOdot/content/blog/post_1.md")
[INFO] [stdout] test draft::tests::test_builder_functional_style ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpTzOdot/content/blog/post_2.md` 
[INFO] [stdout] test draft::draft_builder::tests::test_with_minimum_date_method_chaining_success ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z 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] [stdout] test draft::tests::test_builder_with_absolute_root_path ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpTzOdot/content/blog/post_3.md` 
[INFO] [stdout] test draft::tests::test_write_bluesky_posts_empty_blog_posts ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpTzOdot/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z 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: "V7dTary.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 0,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpLz6JD8" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpLz6JD8`, 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-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpLz6JD8/content/blog`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpLz6JD8/content/blog")
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpLz6JD8/content/blog/test-post.md")
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpLz6JD8/content/blog/test-post.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z 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: "V7dTaxb.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 0,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/test-post.md`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/test-post
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 38 characters and 38 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 9 characters and 9 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 24 characters and 24 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 24 characters and 24 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_3.md`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_3
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 25 characters and 25 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmp2mXty8" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpn2T8zJ" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpn2T8zJ`, 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-01-07T16:32:42Z WARN  gen_bsky::draft::draft_builder] No blog posts found
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpn2T8zJ/content/blog`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpTvG0FF" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpTvG0FF`, 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-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpTvG0FF/content/blog`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpTvG0FF`, 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-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpn2T8zJ/content/blog")
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpn2T8zJ/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpTvG0FF/content/blog")
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpmRKDZU" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpmRKDZU`, 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-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpmRKDZU/content/blog`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpmRKDZU/content/blog")
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpmRKDZU/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpmRKDZU/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z 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: "V7dTas6.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 0,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpn2T8zJ/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpTvG0FF/content/blog/post_2.md")
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpTvG0FF/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpTvG0FF/content/blog/post_2.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpTvG0FF/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z 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: "V7dTas9.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 0,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z 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: "V7dTasA.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 0,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_2.md`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_2
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stdout] test draft::blog_post::tests::test_get_bluesky_record_success ... ok
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpRF92lN" }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpRF92lN`, 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-01-07T16:32:42Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpRF92lN/content/blog`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpRF92lN/content/blog")
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpRF92lN/content/blog/test-post.md")
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpRF92lN/content/blog/test-post.md` 
[INFO] [stderr] [2026-01-07T16:32:42Z 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: "V7dTbB2.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 0,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/test-post.md`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/test-post
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post link: 38 characters and 38 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 9 characters and 9 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 24 characters and 24 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 24 characters and 24 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_3.md` as `HyDnHy`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpTzOdot/bluesky/HyDnHy.post`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Write filename: `multi-test.md` as `PCL1PC`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpABPoQv/posts/PCL1PC.post`
[INFO] [stderr] [2026-01-07T16:32:42Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpn2T8zJ/bluesky/HwDlHw.post`
[INFO] [stderr] [2026-01-07T16:32:43Z INFO  gen_bsky::draft::blog_post] Blog post: BlogPost {
[INFO] [stderr]         path: "/tmp/.tmpABPoQv/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: "V7dTayo.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 1,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpABPoQv/content/blog/multi-test.md`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/multi-test
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 39 characters and 39 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 33 characters and 33 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes
[INFO] [stderr] [2026-01-07T16:32: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: "V7dTarw.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 0,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z 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_existing_directory ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Random name for test directory: `V7dTanq`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write filename: `test-post.md` as `NZJONZ`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpLz6JD8/deeply/nested/bluesky/directory/NZJONZ.post`
[INFO] [stdout] test draft::tests::test_write_bluesky_posts_creates_nested_directories ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_2.md` as `HxDmHx`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpuG2NEI" }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpuG2NEI`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpuG2NEI/content/blog`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpuG2NEI/content/blog")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write filename: `bluesky-test.md` as `ScORSc`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpn19CUv/posts/ScORSc.post`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpuG2NEI/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpuG2NEI/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpTvG0FF/bluesky/HxDmHx.post`
[INFO] [stdout] test draft::blog_post::tests::test_write_bluesky_record_to ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::tests] Record data: `{"createdAt":"2026-01-07T16:32:43.081581Z","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] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpuG2NEI/static/s/V7dTb7k.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTb7k.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32: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: "V7dTasD.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 0,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmp6FsSrY" }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmp6FsSrY`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmp6FsSrY/content/blog`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpuG2NEI/relative/path/V7dTb7k.html
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmp6FsSrY`, name: `post_2.md`, frontmatter: "Title: Test Post Two will Fail"
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmp6FsSrY`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32: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/V7dTb7k.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpmRKDZU/bluesky/HwDlHw.post`
[INFO] [stderr] [2026-01-07T16:32: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: "V7dTas6.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 1,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stdout] test draft::tests::test_write_referrers_absolute_vs_relative_path_handling ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmp6FsSrY/content/blog")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmp6FsSrY/content/blog/post_2.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmp6FsSrY/content/blog/post_3.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmp6FsSrY/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmp6FsSrY/content/blog/post_2.md` 
[INFO] [stderr] [2026-01-07T16:32: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-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmp6FsSrY/content/blog/post_3.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmp6FsSrY/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpcrrUbx" }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpcrrUbx`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpcrrUbx/content/blog`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpcrrUbx/content/blog")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpcrrUbx/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpcrrUbx/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmp6FsSrY/static/s/V7dTb8M.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTb8M.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmp6FsSrY/static/s/V7dTb8K.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTb8K.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpcrrUbx/static/s/V7dTb8T.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTb8T.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stdout] test draft::tests::test_write_referrers_continues_on_individual_errors ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpRl1Pqn" }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpRl1Pqn`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpRl1Pqn/content/blog`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpRl1Pqn`, name: `post_2.md`, frontmatter: "Title: Test Post Two will Fail"
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpRl1Pqn`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpRl1Pqn/content/blog")
[INFO] [stdout] test draft::tests::test_write_referrers_creates_directory_if_not_exists ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpRl1Pqn/content/blog/post_2.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpRl1Pqn/content/blog/post_3.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpRl1Pqn/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpRl1Pqn/content/blog/post_2.md` 
[INFO] [stderr] [2026-01-07T16:32: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-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpRl1Pqn/content/blog/post_3.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpRl1Pqn/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpbELbZ5" }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:43Z WARN  gen_bsky::draft::draft_builder] No blog posts found
[INFO] [stdout] test draft::tests::test_write_referrers_handles_empty_blog_posts ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpc9WTYp" }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpc9WTYp`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpc9WTYp/content/blog`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpc9WTYp/content/blog")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpc9WTYp/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpc9WTYp/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stdout] test draft::tests::test_write_referrers_directory_creation_failure ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpc9WTYp/static/s/V7dTb9F.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTb9F.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpB3fKge" }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpB3fKge`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpB3fKge/content/blog`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpB3fKge`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpB3fKge`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpB3fKge/content/blog")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpB3fKge/content/blog/post_2.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpB3fKge/content/blog/post_3.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpB3fKge/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpB3fKge/content/blog/post_2.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpB3fKge/content/blog/post_3.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpB3fKge/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpc9WTYp/another/path/V7dTb9F.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTb9F.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmptuNekC" }
[INFO] [stdout] test draft::tests::test_write_referrers_method_chaining ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmptuNekC`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmptuNekC/content/blog`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmptuNekC/content/blog")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmptuNekC/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmptuNekC/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write filename: `multi-test.md` as `PCL1PC`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpABPoQv/posts/PCL1PC.post`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmptuNekC/static/s/V7dTb9u.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTb9u.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z INFO  gen_bsky::draft::blog_post] Blog post: BlogPost {
[INFO] [stderr]         path: "/tmp/.tmpABPoQv/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: "V7dTayo.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 2,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpB3fKge/static/s/V7dTb9R.html
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `/tmp/.tmpABPoQv/content/blog/multi-test.md`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/multi-test
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 39 characters and 39 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 14 characters and 14 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 33 characters and 33 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 33 characters and 33 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 13 characters and 13 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 15 characters and 15 graphemes
[INFO] [stdout] test draft::tests::test_write_referrers_returns_self_reference ... ok
[INFO] [stderr] [2026-01-07T16:32: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/V7dTb9R.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpB3fKge/static/s/V7dTb9f.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTb9f.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmp4VAEOJ" }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmp4VAEOJ`, 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_write_referrers_processes_all_blog_posts ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmp4VAEOJ/content/blog`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmp4VAEOJ/content/blog")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmp4VAEOJ/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmp4VAEOJ/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpB3fKge/static/s/V7dTb9f.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTb9f.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmp4VAEOJ/static/s/V7dTbAa.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTbAa.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpW7Co2Z" }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpW7Co2Z`, 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-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpW7Co2Z/content/blog`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpW7Co2Z/content/blog")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpW7Co2Z/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpW7Co2Z/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building link with `https://www.example.com/` as root of url
[INFO] [stdout] test draft::tests::test_write_referrers_uses_existing_directory ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpW7Co2Z/deeply/nested/custom/path/V7dTbAf.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTbAf.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] Created temp directory: TempDir { path: "/tmp/.tmpVCrYit" }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] path: `/tmp/.tmpVCrYit`, 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_write_referrers_with_nested_custom_path ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::tests] creating blog store: `/tmp/.tmpVCrYit/content/blog`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Add default path to the path list as it is empty.
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpVCrYit/content/blog")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::draft_builder] Entry found: DirEntry("/tmp/.tmpVCrYit/content/blog/post_1.md")
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Reading front matter from `/tmp/.tmpVCrYit/content/blog/post_1.md` 
[INFO] [stderr] [2026-01-07T16:32: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_clone ... ok
[INFO] [stdout] test post::bsky_post::tests::test_bsky_post_debug ... ok
[INFO] [stdout] test post::bsky_post::tests::test_bsky_post_file_path_accessor ... ok
[INFO] [stdout] test post::bsky_post::tests::test_bsky_post_new ... ok
[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_with_different_content ... ok
[INFO] [stdout] test post::bsky_post::tests::test_bsky_post_post_accessor ... ok
[INFO] [stdout] test post::bsky_post::tests::test_bsky_post_set_state ... 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_set_state_same_state ... ok
[INFO] [stdout] test post::bsky_post::tests::test_bsky_post_state_accessor ... ok
[INFO] [stdout] test post::bsky_post::tests::test_bsky_post_state_clone ... 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_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_relative_path ... ok
[INFO] [stdout] test post::bsky_post::tests::test_bsky_post_with_unicode_content ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] redirect written and short link returned: /tmp/.tmpVCrYit/custom/referrers/V7dTbB0.html
[INFO] [stderr] [2026-01-07T16:32: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/V7dTbB0.html",
[INFO] [stderr]             query: None,
[INFO] [stderr]             fragment: None,
[INFO] [stderr]         },
[INFO] [stderr]     )
[INFO] [stdout] test draft::tests::test_write_referrers_with_custom_path ... ok
[INFO] [stdout] test post::bsky_post::tests::test_multiple_posts_state_filtering ... ok
[INFO] [stdout] test post::bsky_post::tests::test_state_changes_performance ... ok
[INFO] [stdout] test post::bsky_post::tests::test_many_posts_creation ... ok
[INFO] [stdout] test post::tests::test_count_deleted_none ... ok
[INFO] [stdout] test post::bsky_post::tests::test_state_transition_workflow ... ok
[INFO] [stdout] test post::tests::test_count_deleted_with_deleted_posts ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::post] Deleting related file: "/tmp/.tmpjEZ3z2/test1.post"
[INFO] [stdout] test post::tests::test_delete_posted_posts_file_not_found ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::post] Deleting related file: "/tmp/.tmpa0wN6L/test2.post"
[INFO] [stdout] test post::tests::test_delete_posted_posts_no_posted ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z INFO  gen_bsky::post] Successfully deleted `/tmp/.tmpa0wN6L/test2.post` bluesky post file
[INFO] [stdout] test post::tests::test_delete_posted_posts_with_posted ... ok
[INFO] [stdout] test post::tests::test_error_display ... ok
[INFO] [stdout] test post::tests::test_fluent_interface ... ok
[INFO] [stdout] test post::tests::test_load_accumulative ... ok
[INFO] [stdout] test post::tests::test_load_empty_directory ... 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_nonexistent_directory ... 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 draft::tests::test_write_bluesky_posts_with_default_store ... FAILED
[INFO] [stdout] test post::tests::test_large_number_of_posts ... ok
[INFO] [stdout] test post::tests::test_post_new_both_empty ... 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] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpTzOdot/bluesky/HwDlHw.post`
[INFO] [stdout] test draft::tests::test_write_bluesky_posts_continues_on_individual_failures ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write filename: `test-post.md` as `NZJONZ`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpRF92lN/custom/bluesky/path/NZJONZ.post`
[INFO] [stdout] test draft::tests::test_write_bluesky_posts_with_custom_store ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpmRKDZU/override/bsky/HwDlHw.post`
[INFO] [stdout] test draft::tests::test_write_bluesky_posts_path_resolution ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG reqwest::connect] starting new connection: https://bsky.social/
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpTvG0FF/bluesky/HwDlHw.post`
[INFO] [stdout] test post::tests::test_post_to_bluesky_testing_mode ... ok
[INFO] [stderr] [2026-01-07T16:32:43Z 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: "V7dTasA.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 1,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_2.md`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_2
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write filename: `multi-test.md` as `PCL1PC`
[INFO] [stderr] [2026-01-07T16:32:43Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpABPoQv/posts/PCL1PC.post`
[INFO] [stdout] test draft::blog_post::tests::test_write_bluesky_record_multiple_times ... ok
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_2.md` as `HxDmHx`
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpTvG0FF/bluesky/HxDmHx.post`
[INFO] [stderr] [2026-01-07T16:32: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: "V7dTasD.html",
[INFO] [stderr]             path: "s",
[INFO] [stderr]         },
[INFO] [stderr]         post_short_link: None,
[INFO] [stderr]         bluesky_count: 1,
[INFO] [stderr]     }
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post] Building post text
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post] Building post text with post dir: `content/blog/post_1.md`
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post] Post link: https://www.example.com/blog/post_1
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post] Length of post link: 35 characters and 35 graphemes
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post] Length of post short link: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of title: 23 characters and 23 graphemes
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky description: 19 characters and 19 graphemes
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post::front_matter] Length of bluesky tag contents: 0 characters and 0 graphemes
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post] Write filename: `post_1.md` as `HwDlHw`
[INFO] [stderr] [2026-01-07T16:32:44Z DEBUG gen_bsky::draft::blog_post] Write file: `/tmp/.tmpTvG0FF/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' (303) 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:     0x57d3d9b224b2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x57d3d9b224b2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::trace_unsynchronized::<std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x57d3d9b224b2 - std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x57d3d9b224b2 - <<std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[585f66e14d78f9ba]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x57d3d9b3bb4a - <core[585f66e14d78f9ba]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x57d3d9b3bb4a - core[585f66e14d78f9ba]::fmt::write
[INFO] [stdout]    6:     0x57d3d9b28f86 - std[3f03f8b59f91bef1]::io::default_write_fmt::<alloc[15e7b27aba85d2e2]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x57d3d9b28f86 - <alloc[15e7b27aba85d2e2]::vec::Vec<u8> as std[3f03f8b59f91bef1]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x57d3d9afd8ff - <std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x57d3d9afd8ff - std[3f03f8b59f91bef1]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x57d3d9b18e59 - std[3f03f8b59f91bef1]::panicking::default_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x57d3d906ce1e - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x57d3d906ce1e - test[30224e0cb089acd2]::test_main_with_exit_callback::<test[30224e0cb089acd2]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x57d3d9b190c2 - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x57d3d9b190c2 - std[3f03f8b59f91bef1]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x57d3d9afd9b8 - std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x57d3d9af2729 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_end_short_backtrace::<std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x57d3d9afeb9d - __rustc[caa99d26c7bae192]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x57d3d9b3c33c - core[585f66e14d78f9ba]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x57d3d9b3c082 - core[585f66e14d78f9ba]::result::unwrap_failed
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/result.rs:1867:5
[INFO] [stdout]   20:     0x57d3d8e125fd - <core[585f66e14d78f9ba]::result::Result<(), std[3f03f8b59f91bef1]::io::error::Error>>::unwrap
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/result.rs:1233:23
[INFO] [stdout]   21:     0x57d3d8e125fd - gen_bsky[91bcc94d31b00ca9]::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:     0x57d3d8fab5d2 - <core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>> as core[585f66e14d78f9ba]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/future/future.rs:133:9
[INFO] [stdout]   23:     0x57d3d8fab70d - <core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>> as core[585f66e14d78f9ba]::future::future::Future>::poll
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/future/future.rs:133:9
[INFO] [stdout]   24:     0x57d3d8f66f4d - <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:70
[INFO] [stdout]   25:     0x57d3d8f66d8b - tokio[ac4e0c85db8d6ee5]::task::coop::with_budget::<core[585f66e14d78f9ba]::task::poll::Poll<()>, <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:167:5
[INFO] [stdout]   26:     0x57d3d8f66d8b - tokio[ac4e0c85db8d6ee5]::task::coop::budget::<core[585f66e14d78f9ba]::task::poll::Poll<()>, <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:133:5
[INFO] [stdout]   27:     0x57d3d8f66d8b - <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:25
[INFO] [stdout]   28:     0x57d3d8f4f170 - <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::Context>::enter::<core[585f66e14d78f9ba]::task::poll::Poll<()>, <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:432:19
[INFO] [stdout]   29:     0x57d3d8f5f08d - <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:741:44
[INFO] [stdout]   30:     0x57d3d8f5cd24 - <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}, core[585f66e14d78f9ba]::option::Option<()>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:68
[INFO] [stdout]   31:     0x57d3d8dfc47b - <tokio[ac4e0c85db8d6ee5]::runtime::context::scoped::Scoped<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::Context>>::set::<<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}, core[585f66e14d78f9ba]::option::Option<()>>::{closure#0}, (alloc[15e7b27aba85d2e2]::boxed::Box<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::Core>, core[585f66e14d78f9ba]::option::Option<()>)>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   32:     0x57d3d8f9ca09 - tokio[ac4e0c85db8d6ee5]::runtime::context::set_scheduler::<(alloc[15e7b27aba85d2e2]::boxed::Box<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::Core>, core[585f66e14d78f9ba]::option::Option<()>), <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}, core[585f66e14d78f9ba]::option::Option<()>>::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:38
[INFO] [stdout]   33:     0x57d3d8eccd52 - <std[3f03f8b59f91bef1]::thread::local::LocalKey<tokio[ac4e0c85db8d6ee5]::runtime::context::Context>>::try_with::<tokio[ac4e0c85db8d6ee5]::runtime::context::set_scheduler<(alloc[15e7b27aba85d2e2]::boxed::Box<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::Core>, core[585f66e14d78f9ba]::option::Option<()>), <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}, core[585f66e14d78f9ba]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[15e7b27aba85d2e2]::boxed::Box<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::Core>, core[585f66e14d78f9ba]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/local.rs:513:12
[INFO] [stdout]   34:     0x57d3d8ecc41e - <std[3f03f8b59f91bef1]::thread::local::LocalKey<tokio[ac4e0c85db8d6ee5]::runtime::context::Context>>::with::<tokio[ac4e0c85db8d6ee5]::runtime::context::set_scheduler<(alloc[15e7b27aba85d2e2]::boxed::Box<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::Core>, core[585f66e14d78f9ba]::option::Option<()>), <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}, core[585f66e14d78f9ba]::option::Option<()>>::{closure#0}>::{closure#0}, (alloc[15e7b27aba85d2e2]::boxed::Box<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::Core>, core[585f66e14d78f9ba]::option::Option<()>)>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/local.rs:477:20
[INFO] [stdout]   35:     0x57d3d8f7083d - tokio[ac4e0c85db8d6ee5]::runtime::context::set_scheduler::<(alloc[15e7b27aba85d2e2]::boxed::Box<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::Core>, core[585f66e14d78f9ba]::option::Option<()>), <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}, core[585f66e14d78f9ba]::option::Option<()>>::{closure#0}>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:17
[INFO] [stdout]   36:     0x57d3d8f53840 - <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>::{closure#0}, core[585f66e14d78f9ba]::option::Option<()>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:27
[INFO] [stdout]   37:     0x57d3d8f53c56 - <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CoreGuard>::block_on::<core[585f66e14d78f9ba]::pin::Pin<&mut core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:729:24
[INFO] [stdout]   38:     0x57d3d8f5c0c0 - <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:200:33
[INFO] [stdout]   39:     0x57d3d8e387e3 - tokio[ac4e0c85db8d6ee5]::runtime::context::runtime::enter_runtime::<<tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CurrentThread>::block_on<core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>::{closure#0}, ()>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   40:     0x57d3d8f4e451 - <tokio[ac4e0c85db8d6ee5]::runtime::scheduler::current_thread::CurrentThread>::block_on::<core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:188:9
[INFO] [stdout]   41:     0x57d3d8f4d2b4 - <tokio[ac4e0c85db8d6ee5]::runtime::runtime::Runtime>::block_on_inner::<core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:356:52
[INFO] [stdout]   42:     0x57d3d8f4d6ec - <tokio[ac4e0c85db8d6ee5]::runtime::runtime::Runtime>::block_on::<core[585f66e14d78f9ba]::pin::Pin<&mut dyn core[585f66e14d78f9ba]::future::future::Future<Output = ()>>>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:330:18
[INFO] [stdout]   43:     0x57d3d8e2a42f - gen_bsky[91bcc94d31b00ca9]::draft::tests::test_write_bluesky_posts_with_default_store
[INFO] [stdout]                                at /opt/rustwide/workdir/src/draft.rs:1226:46
[INFO] [stdout]   44:     0x57d3d8e0c597 - gen_bsky[91bcc94d31b00ca9]::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:     0x57d3d8dbd6a6 - <gen_bsky[91bcc94d31b00ca9]::draft::tests::test_write_bluesky_posts_with_default_store::{closure#0} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x57d3d90611cb - <fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x57d3d90611cb - test[30224e0cb089acd2]::__rust_begin_short_backtrace::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:663:18
[INFO] [stdout]   48:     0x57d3d906da2a - test[30224e0cb089acd2]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:74
[INFO] [stdout]   49:     0x57d3d906da2a - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   50:     0x57d3d906da2a - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   51:     0x57d3d906da2a - std[3f03f8b59f91bef1]::panicking::catch_unwind::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   52:     0x57d3d906da2a - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   53:     0x57d3d906da2a - test[30224e0cb089acd2]::run_test_in_process
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:27
[INFO] [stdout]   54:     0x57d3d906da2a - test[30224e0cb089acd2]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:607:43
[INFO] [stdout]   55:     0x57d3d9067ef4 - test[30224e0cb089acd2]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:637:41
[INFO] [stdout]   56:     0x57d3d9067ef4 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_begin_short_backtrace::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   57:     0x57d3d9070522 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   58:     0x57d3d9070522 - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   59:     0x57d3d9070522 - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   60:     0x57d3d9070522 - std[3f03f8b59f91bef1]::panicking::catch_unwind::<(), core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   61:     0x57d3d9070522 - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   62:     0x57d3d9070522 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   63:     0x57d3d9070522 - <std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   64:     0x57d3d9b217df - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn core[585f66e14d78f9ba]::ops::function::FnOnce<(), Output = ()> + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   65:     0x57d3d9b217df - <std[3f03f8b59f91bef1]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   66:     0x7f132b6cfaa4 - <unknown>
[INFO] [stdout]   67:     0x7f132b75ca64 - clone
[INFO] [stdout]   68:                0x0 - <unknown>
[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. 343 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 2.11s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] running `Command { std: "docker" "inspect" "52a40a7395d0a8d0d7137ca4011e7a9d3c37a85ac42bf5c128dfbbfa0a33cd3e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "52a40a7395d0a8d0d7137ca4011e7a9d3c37a85ac42bf5c128dfbbfa0a33cd3e", kill_on_drop: false }`
[INFO] [stdout] 52a40a7395d0a8d0d7137ca4011e7a9d3c37a85ac42bf5c128dfbbfa0a33cd3e
