[INFO] cloning repository https://github.com/RileyMathews/forgebot [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/RileyMathews/forgebot" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FRileyMathews%2Fforgebot", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FRileyMathews%2Fforgebot'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 53a818a4feffd95e8026ef8860a40b0e6bad712b [INFO] testing RileyMathews/forgebot against try#dec9417b8611e34e787a3e4c37686b5131f9e5c5 for pr-154210 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FRileyMathews%2Fforgebot" "/workspace/builds/worker-4-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/RileyMathews/forgebot [INFO] finished tweaking git repo https://github.com/RileyMathews/forgebot [INFO] tweaked toml for git repo https://github.com/RileyMathews/forgebot written to /workspace/builds/worker-4-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/RileyMathews/forgebot on toolchain dec9417b8611e34e787a3e4c37686b5131f9e5c5 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/RileyMathews/forgebot 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" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "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-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 63c8fa5327906b99aa5b22df970ac4dd6c30c432f5911cff00b8a883e7f65bbe [INFO] running `Command { std: "docker" "start" "-a" "63c8fa5327906b99aa5b22df970ac4dd6c30c432f5911cff00b8a883e7f65bbe", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "63c8fa5327906b99aa5b22df970ac4dd6c30c432f5911cff00b8a883e7f65bbe", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "63c8fa5327906b99aa5b22df970ac4dd6c30c432f5911cff00b8a883e7f65bbe", kill_on_drop: false }` [INFO] [stdout] 63c8fa5327906b99aa5b22df970ac4dd6c30c432f5911cff00b8a883e7f65bbe [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] d0a250886d9df1f2ee44114b433798077794a1344d6711d5345420eb2f8882ee [INFO] running `Command { std: "docker" "start" "-a" "d0a250886d9df1f2ee44114b433798077794a1344d6711d5345420eb2f8882ee", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.106 [INFO] [stderr] Compiling quote v1.0.45 [INFO] [stderr] Compiling unicode-ident v1.0.24 [INFO] [stderr] Compiling libc v0.2.183 [INFO] [stderr] Compiling memchr v2.8.0 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling typenum v1.19.0 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling slab v0.4.12 [INFO] [stderr] Compiling futures-channel v0.3.32 [INFO] [stderr] Compiling hashbrown v0.16.1 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling http v1.4.0 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling futures-sink v0.3.32 [INFO] [stderr] Compiling hashbrown v0.15.5 [INFO] [stderr] Compiling bitflags v2.11.0 [INFO] [stderr] Compiling ryu v1.0.23 [INFO] [stderr] Compiling event-listener v5.4.1 [INFO] [stderr] Compiling crc v3.4.0 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling indexmap v2.13.0 [INFO] [stderr] Compiling spin v0.9.8 [INFO] [stderr] Compiling log v0.4.29 [INFO] [stderr] Compiling openssl v0.10.75 [INFO] [stderr] Compiling hashlink v0.10.0 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling sync_wrapper v1.0.2 [INFO] [stderr] Compiling unicase v2.9.0 [INFO] [stderr] Compiling base64 v0.22.1 [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Compiling native-tls v0.2.18 [INFO] [stderr] Compiling flume v0.11.1 [INFO] [stderr] Compiling mime_guess v2.0.5 [INFO] [stderr] Compiling minimal-lexical v0.2.1 [INFO] [stderr] Compiling generic-array v0.14.7 [INFO] [stderr] Compiling libm v0.2.16 [INFO] [stderr] Compiling rustversion v1.0.22 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling openssl-probe v0.2.1 [INFO] [stderr] Compiling mio v1.1.1 [INFO] [stderr] Compiling socket2 v0.6.3 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling errno v0.3.14 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling signal-hook-registry v1.4.8 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling atoi v2.0.0 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling nom v7.1.3 [INFO] [stderr] Compiling block-buffer v0.10.4 [INFO] [stderr] Compiling crypto-common v0.1.7 [INFO] [stderr] Compiling getrandom v0.4.2 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling openssl-sys v0.9.111 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling libsqlite3-sys v0.30.1 [INFO] [stderr] Compiling tokio v1.50.0 [INFO] [stderr] Compiling sha2 v0.10.9 [INFO] [stderr] Compiling dotenvy v0.15.7 [INFO] [stderr] Compiling futures-intrusive v0.5.0 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling webpki-roots v1.0.6 [INFO] [stderr] Compiling linux-raw-sys v0.4.15 [INFO] [stderr] Compiling iri-string v0.7.10 [INFO] [stderr] Compiling dirs-sys v0.4.1 [INFO] [stderr] Compiling tracing-log v0.2.0 [INFO] [stderr] Compiling encoding_rs v0.8.35 [INFO] [stderr] Compiling home v0.5.12 [INFO] [stderr] Compiling iana-time-zone v0.1.65 [INFO] [stderr] Compiling askama_escape v0.10.3 [INFO] [stderr] Compiling uuid v1.22.0 [INFO] [stderr] Compiling dirs v5.0.1 [INFO] [stderr] Compiling hmac v0.12.1 [INFO] [stderr] Compiling askama_parser v0.2.1 [INFO] [stderr] Compiling serde_path_to_error v0.1.20 [INFO] [stderr] Compiling humansize v2.1.3 [INFO] [stderr] Compiling futures-executor v0.3.32 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling rustls v0.23.37 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling tokio-macros v2.6.1 [INFO] [stderr] Compiling futures-macro v0.3.32 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling yoke v0.8.1 [INFO] [stderr] Compiling tracing-subscriber v0.3.22 [INFO] [stderr] Compiling tokio-stream v0.1.18 [INFO] [stderr] Compiling zerovec v0.11.5 [INFO] [stderr] Compiling zerotrie v0.2.3 [INFO] [stderr] Compiling rustls-webpki v0.103.9 [INFO] [stderr] Compiling tinystr v0.8.2 [INFO] [stderr] Compiling potential_utf v0.1.4 [INFO] [stderr] Compiling icu_locale_core v2.1.1 [INFO] [stderr] Compiling icu_collections v2.1.1 [INFO] [stderr] Compiling icu_provider v2.1.1 [INFO] [stderr] Compiling icu_properties v2.1.2 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling either v1.15.0 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling basic-toml v0.1.10 [INFO] [stderr] Compiling chrono v0.4.44 [INFO] [stderr] Compiling which v6.0.3 [INFO] [stderr] Compiling axum-core v0.4.5 [INFO] [stderr] Compiling askama_derive v0.12.5 [INFO] [stderr] Compiling futures v0.3.32 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling sqlx-core v0.8.6 [INFO] [stderr] Compiling askama v0.12.1 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling sqlx-sqlite v0.8.6 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling sqlx-macros-core v0.8.6 [INFO] [stderr] Compiling sqlx-macros v0.8.6 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling sqlx v0.8.6 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling axum v0.7.9 [INFO] [stderr] Compiling reqwest v0.12.28 [INFO] [stderr] Compiling forgebot v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 36s [INFO] running `Command { std: "docker" "inspect" "d0a250886d9df1f2ee44114b433798077794a1344d6711d5345420eb2f8882ee", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "d0a250886d9df1f2ee44114b433798077794a1344d6711d5345420eb2f8882ee", kill_on_drop: false }` [INFO] [stdout] d0a250886d9df1f2ee44114b433798077794a1344d6711d5345420eb2f8882ee [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 92d9257425d573f22b536358a458834007ecaeeecff68439b15ddf4c1b5505d7 [INFO] running `Command { std: "docker" "start" "-a" "92d9257425d573f22b536358a458834007ecaeeecff68439b15ddf4c1b5505d7", kill_on_drop: false }` [INFO] [stderr] Compiling forgebot v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 17.77s [INFO] running `Command { std: "docker" "inspect" "92d9257425d573f22b536358a458834007ecaeeecff68439b15ddf4c1b5505d7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "92d9257425d573f22b536358a458834007ecaeeecff68439b15ddf4c1b5505d7", kill_on_drop: false }` [INFO] [stdout] 92d9257425d573f22b536358a458834007ecaeeecff68439b15ddf4c1b5505d7 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+dec9417b8611e34e787a3e4c37686b5131f9e5c5" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 21f41217779e9bf53c3933ac3a2bc711c719ed776819222ffd73d3ca32ac809c [INFO] running `Command { std: "docker" "start" "-a" "21f41217779e9bf53c3933ac3a2bc711c719ed776819222ffd73d3ca32ac809c", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.45s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/forgebot-c6392d0432c43faa) [INFO] [stdout] [INFO] [stdout] running 81 tests [INFO] [stdout] test config::tests::test_env_var_parse_with_default_invalid_parsing ... ok [INFO] [stdout] test config::tests::test_resolve_askpass_path_custom ... ok [INFO] [stdout] test config::tests::test_env_var_path_with_default ... ok [INFO] [stdout] test config::tests::test_env_var_with_default_uses_env_when_set ... ok [INFO] [stdout] test config::tests::test_resolve_askpass_path_default ... ok [INFO] [stdout] test forgejo::tests::test_webhook_events_include_review_comment ... ok [INFO] [stdout] test session::clone::tests::test_clone_auth_env_includes_non_interactive_askpass ... ok [INFO] [stdout] test session::clone::tests::test_bare_clone_path_has_valid_parent ... ok [INFO] [stdout] test session::clone::tests::test_clone_url_construction ... ok [INFO] [stdout] test session::clone::tests::test_clone_url_with_full_url_input ... ok [INFO] [stdout] test config::tests::test_setup_askpass_script_writes_expected_content ... ok [INFO] [stdout] test session::clone::tests::test_timeout_constant_is_10_minutes ... ok [INFO] [stdout] test config::tests::test_webhook_url ... ok [INFO] [stdout] test config::tests::test_validate_http_url ... ok [INFO] [stdout] test session::env_loader::tests::test_load_env_dispatcher_none ... ok [INFO] [stdout] test session::env_loader::tests::test_load_env_dispatcher_invalid_type ... ok [INFO] [stdout] test session::env_loader::tests::test_load_env_none ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_direnv_json_invalid_json ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_nix_json_filters_non_exported ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_nix_json_exported_vars ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_nix_json_invalid_json ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_nix_json_missing_value ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_nix_json_missing_variables ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_nix_json_realistic ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_direnv_json_special_chars ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_nix_json_filters_non_string_values ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_direnv_json_realistic ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_direnv_json_non_string_values ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_direnv_json_simple_vars ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_nix_json_empty ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_direnv_json_whitespace_only ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_direnv_json_non_object ... ok [INFO] [stdout] test session::env_loader::tests::test_parse_direnv_json_empty ... ok [INFO] [stdout] test session::clone::tests::test_clone_url_with_trailing_slash ... ok [INFO] [stdout] test session::opencode::tests::test_blocking_api_session_status_prefers_targeted_session ... ok [INFO] [stdout] test session::opencode::tests::test_build_acknowledgement_message_includes_async_notice ... ok [INFO] [stdout] test session::env_loader::tests::test_run_command_with_timeout_nonexistent_command ... ok [INFO] [stdout] test session::opencode::tests::test_describe_session_status_retry_message ... ok [INFO] [stdout] test session::opencode::tests::test_blocking_api_session_status_falls_back_to_any_busy ... ok [INFO] [stdout] test session::opencode::tests::test_external_session_id_filters_derived_and_empty_values ... ok [INFO] [stdout] test session::env_loader::tests::test_run_command_with_timeout_exceeded ... ok [INFO] [stdout] test session::opencode::tests::test_parse_model_input ... ok [INFO] [stdout] test session::env_loader::tests::test_run_command_with_timeout_success ... ok [INFO] [stdout] test session::opencode_api::tests::test_new_rejects_invalid_url ... ok [INFO] [stdout] test session::opencode::tests::test_build_acknowledgement_message_includes_link_when_present ... ok [INFO] [stdout] test session::repo_cleanup::tests::test_webhook_url ... ok [INFO] [stdout] test session::tests::test_build_build_prompt ... ok [INFO] [stdout] test session::tests::test_build_plan_prompt ... ok [INFO] [stdout] test session::opencode_api::tests::test_from_config_requires_base_url ... ok [INFO] [stdout] test session::tests::test_build_prompt_empty_comments ... ok [INFO] [stdout] test session::tests::test_build_revision_prompt ... ok [INFO] [stdout] test session::tests::test_clone_status_mappings ... ok [INFO] [stdout] test session::tests::test_format_timestamp ... ok [INFO] [stdout] test session::tests::test_derive_session_id ... ok [INFO] [stdout] test session::tests::test_opencode_session_web_url ... ok [INFO] [stdout] test session::tests::test_sanitize_for_session_id ... ok [INFO] [stdout] test session::tests::test_session_action_mappings ... ok [INFO] [stdout] test session::tests::test_session_mode_mappings ... ok [INFO] [stdout] test session::worktree::tests::test_bare_clone_path_computation ... ok [INFO] [stdout] test session::tests::test_session_state_busy_policy ... ok [INFO] [stdout] test session::worktree::tests::test_clone_exists_with_nonexistent_path ... ok [INFO] [stdout] test session::worktree::tests::test_worktree_path_computation ... ok [INFO] [stdout] test session::worktree::tests::test_parse_repo_full_name ... ok [INFO] [stdout] test webhook::handlers::tests::test_extract_issue_id_from_branch ... ok [INFO] [stdout] test webhook::handlers::tests::test_pr_number_from_issue_comment_when_comment_is_on_issue ... ok [INFO] [stdout] test webhook::models::tests::test_issue_comment_payload_allows_pull_request_marker_without_url ... ok [INFO] [stdout] test webhook::handlers::tests::test_pr_number_from_issue_comment_when_comment_is_on_pr ... ok [INFO] [stdout] test session::env_loader::tests::test_run_command_with_timeout_long_command ... ok [INFO] [stdout] test db::tests::test_update_issue_external_opencode_session_id_rejects_invalid_values ... ok [INFO] [stdout] test db::tests::test_update_issue_external_opencode_session_id_lifecycle ... ok [INFO] [stdout] test db::tests::test_get_issue_external_opencode_session_id_handles_legacy_and_empty_values ... ok [INFO] [stdout] test session::opencode_api::tests::test_prompt_async_accepts_no_content ... ok [INFO] [stdout] test session::opencode_api::tests::test_abort_returns_boolean ... ok [INFO] [stdout] test session::opencode_api::tests::test_health_parses_response ... ok [INFO] [stdout] test session::opencode_api::tests::test_health_http_error_surface ... ok [INFO] [stdout] test session::opencode_api::tests::test_get_session_sends_directory_query ... ok [INFO] [stdout] test session::opencode_api::tests::test_session_status_parses_variants ... ok [INFO] [stdout] test session::opencode_api::tests::test_bearer_token_header_is_set ... ok [INFO] [stdout] test session::opencode_api::tests::test_http_error_includes_context ... ok [INFO] [stdout] test session::opencode_api::tests::test_create_session_sends_directory_query ... ok [INFO] [stdout] test session::opencode_api::tests::test_router_roundtrip_for_body_shape ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 81 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.69s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/forgebot-53ec999f52198082) [INFO] [stderr] Running tests/auto_clone_adversarial.rs (/opt/rustwide/target/debug/deps/auto_clone_adversarial-bb6da27af01d2170) [INFO] [stdout] [INFO] [stdout] running 23 tests [INFO] [stdout] test test_state_transitions_sequence ... ok [INFO] [stdout] test test_validate_repo_full_name_accepts_valid_names ... ok [INFO] [stdout] test test_validate_repo_full_name_rejects_empty_parts ... ok [INFO] [stdout] test test_validate_repo_full_name_rejects_extra_slashes ... ok [INFO] [stdout] test test_validate_repo_full_name_rejects_single_component ... ok [INFO] [stdout] test test_update_status_for_nonexistent_repo_fails ... ok [INFO] [stdout] test test_validate_repo_full_name_rejects_special_chars ... ok [INFO] [stdout] test test_validate_repo_full_name_rejects_with_spaces ... ok [INFO] [stdout] test test_retry_clone_rejected_when_ready ... ok [INFO] [stdout] test test_clone_error_message_stored_correctly ... ok [INFO] [stdout] test test_concurrent_status_updates_handle_race ... ok [INFO] [stdout] test test_concurrent_retries_only_one_succeeds ... ok [INFO] [stdout] test test_reset_status_for_nonexistent_repo_returns_false ... ok [INFO] [stdout] test test_error_message_cleared_on_successful_reset ... ok [INFO] [stdout] test test_clone_attempts_counter_increments ... ok [INFO] [stdout] test test_retry_clone_rejected_from_pending_status ... ok [INFO] [stdout] test test_invalid_clone_status_rejected_by_database ... ok [INFO] [stdout] test test_retry_clone_succeeds_from_failed_status ... ok [INFO] [stdout] test test_retry_clone_rejected_while_cloning ... ok [INFO] [stdout] test test_clone_status_always_valid_enum_value ... ok [INFO] [stdout] test test_last_clone_attempt_timestamp_updates ... ok [INFO] [stdout] test test_very_long_clone_error_message_stored ... ok [INFO] [stdout] test test_startup_crash_recovery_resets_stuck_clones ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 23 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.50s [INFO] [stdout] [INFO] [stderr] Running tests/forgejo_integration.rs (/opt/rustwide/target/debug/deps/forgejo_integration-cca343da0e3d234b) [INFO] [stdout] [INFO] [stdout] running 5 tests [INFO] [stdout] test test_check_token_permissions ... ignored, Requires Forgejo instance - run manually with env vars set [INFO] [stdout] test test_create_and_delete_webhook ... ignored, Requires Forgejo instance - creates a webhook, then deletes it [INFO] [stdout] test test_get_issue ... ignored, Requires Forgejo instance with an issue - run manually with env vars set [INFO] [stdout] test test_list_issue_comments ... ignored, Requires Forgejo instance with an issue - run manually with env vars set [INFO] [stdout] test test_list_webhooks ... ignored, Requires Forgejo instance - run manually with env vars set [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 5 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running tests/repo_removal_adversarial.rs (/opt/rustwide/target/debug/deps/repo_removal_adversarial-2148e3b25ba63ba2) [INFO] [stdout] [INFO] [stdout] running 27 tests [INFO] [stdout] test test_repo_full_name_construction_with_special_chars ... ok [INFO] [stdout] test test_repo_full_name_with_numbers ... ok [INFO] [stdout] test test_repo_full_name_with_hyphens ... ok [INFO] [stdout] test test_repo_full_name_with_underscores ... ok [INFO] [stdout] test test_delete_nonexistent_repo_is_safe ... ok [INFO] [stdout] test test_repo_name_with_dots ... ok [INFO] [stdout] test test_multiple_get_sessions_concurrent ... ok [INFO] [stdout] test test_get_sessions_for_repo_empty ... ok [INFO] [stdout] test test_delete_repo_with_no_sessions ... ok [INFO] [stdout] test test_repo_removal_allows_busy_session ... ok [INFO] [stdout] test test_multiple_sessions_same_issue_prevented ... ok [INFO] [stdout] test test_get_sessions_for_repo_multiple ... ok [INFO] [stdout] test test_repo_removal_allows_error_session ... ok [INFO] [stdout] test test_delete_repo_cascade_deletes_sessions ... ok [INFO] [stdout] test test_delete_repo_multiple_times ... ok [INFO] [stdout] test test_owner_name_various_formats ... ok [INFO] [stdout] test test_repo_removal_allows_idle_session ... ok [INFO] [stdout] test test_repo_name_unicode ... ok [INFO] [stdout] test test_delete_repo_while_reading_sessions ... ok [INFO] [stdout] test test_repo_deletion_with_pr_id_sessions ... ok [INFO] [stdout] test test_repo_removal_checks_all_active_states ... ok [INFO] [stdout] test test_revising_state_is_now_valid_in_database ... ok [INFO] [stdout] test test_repo_removal_blocks_on_building_session ... ok [INFO] [stdout] test test_repo_removal_blocks_on_planning_session ... ok [INFO] [stdout] test test_session_with_extremely_long_worktree_path ... ok [INFO] [stdout] test test_update_session_state_to_all_valid_states ... ok [INFO] [stdout] test test_session_with_many_repos_isolation ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 27 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.66s [INFO] [stdout] [INFO] [stderr] Running tests/repo_removal_cleanup_adversarial.rs (/opt/rustwide/target/debug/deps/repo_removal_cleanup_adversarial-a8fcc1ba0a13456e) [INFO] [stdout] [INFO] [stdout] running 11 tests [INFO] [stdout] test test_delete_repo_idempotent ... ok [INFO] [stdout] test test_cleanup_has_all_session_info ... ok [INFO] [stdout] test test_cleanup_empty_repo_no_sessions ... ok [INFO] [stdout] test test_delete_repo_final_step_succeeds ... ok [INFO] [stdout] test test_worktree_paths_extracted_correctly ... ok [INFO] [stdout] test test_session_retrieval_before_cleanup ... ok [INFO] [stdout] test test_cleanup_uses_full_name_not_id ... ok [INFO] [stdout] test test_cleanup_handles_sessions_with_pr_ids ... ok [INFO] [stdout] test test_cleanup_handles_all_session_states ... ok [INFO] [stdout] test test_cleanup_multiple_sessions_all_deleted ... ok [INFO] [stderr] Running tests/repo_removal_handlers_adversarial.rs (/opt/rustwide/target/debug/deps/repo_removal_handlers_adversarial-e1da11cfc97605a9) [INFO] [stdout] test test_cleanup_preserves_other_repos ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 11 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.32s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 19 tests [INFO] [stdout] test test_owner_name_with_uppercase ... ok [INFO] [stdout] test test_owner_name_with_numbers ... ok [INFO] [stdout] test test_repo_name_preserves_dots ... ok [INFO] [stdout] test test_repo_name_with_hyphen_underscore ... ok [INFO] [stdout] test test_handler_allows_no_sessions ... ok [INFO] [stdout] test test_delete_repo_with_hyphen_underscore ... ok [INFO] [stdout] test test_delete_repo_with_dots_in_name ... ok [INFO] [stdout] test test_handler_logic_allows_error ... ok [INFO] [stdout] test test_handler_logic_allows_busy ... ok [INFO] [stdout] test test_handler_detects_any_active_state ... ok [INFO] [stdout] test test_handler_logic_allows_idle ... ok [INFO] [stdout] test test_handler_logic_blocks_building ... ok [INFO] [stdout] test test_session_created_after_active_check ... ok [INFO] [stdout] test test_cascade_delete_only_removes_sessions_for_repo ... ok [INFO] [stdout] test test_all_valid_states_recognized_by_handler ... ok [INFO] [stdout] test test_handler_logic_blocks_planning ... ok [INFO] [stdout] test test_delete_empty_repo_succeeds ... ok [INFO] [stdout] test test_delete_repo_with_many_sessions ... ok [INFO] [stdout] test test_active_check_handles_intermediate_states ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 19 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.42s [INFO] [stdout] [INFO] [stderr] Running tests/ui_root_routes.rs (/opt/rustwide/target/debug/deps/ui_root_routes-bdbebef61ef78f8b) [INFO] [stdout] [INFO] [stdout] running 2 tests [INFO] [stdout] test test_dashboard_route_is_root_mounted ... ok [INFO] [stdout] test test_add_repo_uses_root_path_and_old_ui_path_is_missing ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.21s [INFO] [stdout] [INFO] [stderr] Doc-tests forgebot [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "21f41217779e9bf53c3933ac3a2bc711c719ed776819222ffd73d3ca32ac809c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "21f41217779e9bf53c3933ac3a2bc711c719ed776819222ffd73d3ca32ac809c", kill_on_drop: false }` [INFO] [stdout] 21f41217779e9bf53c3933ac3a2bc711c719ed776819222ffd73d3ca32ac809c