[INFO] fetching crate agent-sdk 0.4.4...
[INFO] testing agent-sdk-0.4.4 against beta-2026-03-05 for beta-1.95-1
[INFO] extracting crate agent-sdk 0.4.4 into /workspace/builds/worker-4-tc2/source
[INFO] started tweaking crates.io crate agent-sdk 0.4.4
[INFO] removed 0 missing examples
[INFO] finished tweaking crates.io crate agent-sdk 0.4.4
[INFO] tweaked toml for crates.io crate agent-sdk 0.4.4 written to /workspace/builds/worker-4-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate agent-sdk 0.4.4 on toolchain beta-2026-03-05
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-03-05" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate agent-sdk 0.4.4 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" "+beta-2026-03-05" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[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" "+beta-2026-03-05" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 00d9778f5053f4c2295a1ddf1fd9366d7fcf9bd728984c2c7f91cdda88e9cf75
[INFO] running `Command { std: "docker" "start" "-a" "00d9778f5053f4c2295a1ddf1fd9366d7fcf9bd728984c2c7f91cdda88e9cf75", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "00d9778f5053f4c2295a1ddf1fd9366d7fcf9bd728984c2c7f91cdda88e9cf75", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "00d9778f5053f4c2295a1ddf1fd9366d7fcf9bd728984c2c7f91cdda88e9cf75", kill_on_drop: false }`
[INFO] [stdout] 00d9778f5053f4c2295a1ddf1fd9366d7fcf9bd728984c2c7f91cdda88e9cf75
[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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 376d156aa2ba0451ffbb32a837a0da275287a4b64598006fd29434ffbd6b970d
[INFO] running `Command { std: "docker" "start" "-a" "376d156aa2ba0451ffbb32a837a0da275287a4b64598006fd29434ffbd6b970d", kill_on_drop: false }`
[INFO] [stderr]    Compiling bytes v1.11.1
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling dunce v1.0.5
[INFO] [stderr]    Compiling fs_extra v1.3.0
[INFO] [stderr]    Compiling siphasher v1.0.2
[INFO] [stderr]    Compiling aws-lc-rs v1.15.4
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling rustls v0.23.36
[INFO] [stderr]    Compiling simd-adler32 v0.3.8
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling subtle v2.6.1
[INFO] [stderr]    Compiling mac v0.1.1
[INFO] [stderr]    Compiling precomputed-hash v0.1.1
[INFO] [stderr]    Compiling futf v0.1.5
[INFO] [stderr]    Compiling compression-core v0.4.31
[INFO] [stderr]    Compiling zmij v1.0.19
[INFO] [stderr]    Compiling phf_shared v0.11.3
[INFO] [stderr]    Compiling rustls-pki-types v1.14.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling tendril v0.4.3
[INFO] [stderr]    Compiling openssl-probe v0.2.1
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling match_token v0.1.0
[INFO] [stderr]    Compiling phf_generator v0.11.3
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling phf v0.11.3
[INFO] [stderr]    Compiling cc v1.2.55
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling rustls-native-certs v0.8.3
[INFO] [stderr]    Compiling iri-string v0.7.10
[INFO] [stderr]    Compiling phf_codegen v0.11.3
[INFO] [stderr]    Compiling string_cache_codegen v0.5.4
[INFO] [stderr]    Compiling regex-syntax v0.8.9
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling http v1.4.0
[INFO] [stderr]    Compiling string_cache v0.8.9
[INFO] [stderr]    Compiling flate2 v1.1.9
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling deranged v0.5.5
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling web_atoms v0.1.3
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling unsafe-libyaml v0.2.11
[INFO] [stderr]    Compiling time-core v0.1.8
[INFO] [stderr]    Compiling num-conv v0.2.0
[INFO] [stderr]    Compiling compression-codecs v0.4.36
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling uuid v1.20.0
[INFO] [stderr]    Compiling glob v0.3.3
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling async-stream v0.3.6
[INFO] [stderr]    Compiling serde_yaml v0.9.34+deprecated
[INFO] [stderr]    Compiling cmake v0.1.57
[INFO] [stderr]    Compiling time v0.3.46
[INFO] [stderr]    Compiling aws-lc-sys v0.37.0
[INFO] [stderr]    Compiling markup5ever v0.16.2
[INFO] [stderr]    Compiling html5ever v0.31.0
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling html2text v0.14.4
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling async-compression v0.4.37
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling rustls-webpki v0.103.9
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling rustls-platform-verifier v0.6.2
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling reqwest v0.13.1
[INFO] [stderr]    Compiling agent-sdk v0.4.4 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 52.23s
[INFO] running `Command { std: "docker" "inspect" "376d156aa2ba0451ffbb32a837a0da275287a4b64598006fd29434ffbd6b970d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "376d156aa2ba0451ffbb32a837a0da275287a4b64598006fd29434ffbd6b970d", kill_on_drop: false }`
[INFO] [stdout] 376d156aa2ba0451ffbb32a837a0da275287a4b64598006fd29434ffbd6b970d
[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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 5730bb566db277495718165e1dbe7d2dbe9ef28da8b3b1aef75aaa5e04b6a645
[INFO] running `Command { std: "docker" "start" "-a" "5730bb566db277495718165e1dbe7d2dbe9ef28da8b3b1aef75aaa5e04b6a645", kill_on_drop: false }`
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling markup5ever v0.16.2
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]    Compiling rustls-platform-verifier v0.6.2
[INFO] [stderr]    Compiling is_terminal_polyfill v1.70.2
[INFO] [stderr]    Compiling anstyle-query v1.1.5
[INFO] [stderr]    Compiling jiff v0.2.18
[INFO] [stderr]    Compiling html5ever v0.31.0
[INFO] [stderr]    Compiling anstream v0.6.21
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling html2text v0.14.4
[INFO] [stderr]    Compiling tempfile v3.24.0
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling env_filter v0.1.4
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling async-compression v0.4.37
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling reqwest v0.13.1
[INFO] [stderr]    Compiling agent-sdk v0.4.4 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 43.86s
[INFO] running `Command { std: "docker" "inspect" "5730bb566db277495718165e1dbe7d2dbe9ef28da8b3b1aef75aaa5e04b6a645", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5730bb566db277495718165e1dbe7d2dbe9ef28da8b3b1aef75aaa5e04b6a645", kill_on_drop: false }`
[INFO] [stdout] 5730bb566db277495718165e1dbe7d2dbe9ef28da8b3b1aef75aaa5e04b6a645
[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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] cda69883931cf3d23145e597c487d34015c896447b552c5bf434dfc3be096806
[INFO] running `Command { std: "docker" "start" "-a" "cda69883931cf3d23145e597c487d34015c896447b552c5bf434dfc3be096806", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.34s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/agent_sdk-87285a7ed73f81c2)
[INFO] [stdout] 
[INFO] [stdout] running 364 tests
[INFO] [stdout] test agent_loop::tests::test_builder_creates_agent_loop ... ok
[INFO] [stdout] test agent_loop::tests::test_builder_with_custom_config ... ok
[INFO] [stdout] test agent_loop::tests::test_build_assistant_message ... ok
[INFO] [stdout] test agent_loop::tests::test_extract_content_mixed ... ok
[INFO] [stdout] test agent_loop::tests::test_builder_with_tools ... ok
[INFO] [stdout] test agent_loop::tests::test_extract_content_tool_use ... ok
[INFO] [stdout] test agent_loop::tests::test_millis_to_u64 ... ok
[INFO] [stdout] test agent_loop::tests::test_extract_content_text_only ... ok
[INFO] [stdout] test agent_loop::tests::test_builder_with_custom_stores ... ok
[INFO] [stdout] test agent_loop::tests::test_simple_text_response ... ok
[INFO] [stdout] test agent_loop::tests::test_max_turns_limit ... ok
[INFO] [stdout] test agent_loop::tests::test_tool_execution ... ok
[INFO] [stdout] test agent_loop::tests::test_unknown_tool_handling ... ok
[INFO] [stdout] test context::compactor::tests::test_format_messages_for_summary_truncates_tool_results_unicode_safely ... ok
[INFO] [stdout] test context::compactor::tests::test_needs_compaction_above_threshold ... ok
[INFO] [stdout] test context::compactor::tests::test_needs_compaction_auto_disabled ... ok
[INFO] [stdout] test context::compactor::tests::test_needs_compaction_below_threshold ... ok
[INFO] [stdout] test context::config::tests::test_builder_pattern ... ok
[INFO] [stdout] test context::config::tests::test_default_config ... ok
[INFO] [stdout] test context::estimator::tests::test_empty_history ... ok
[INFO] [stdout] test capabilities::tests::test_allowed_commands_restriction ... ok
[INFO] [stdout] test context::estimator::tests::test_estimate_blocks_message ... ok
[INFO] [stdout] test context::estimator::tests::test_estimate_history ... ok
[INFO] [stdout] test context::estimator::tests::test_estimate_text ... ok
[INFO] [stdout] test context::estimator::tests::test_estimate_text_message ... ok
[INFO] [stdout] test context::estimator::tests::test_estimate_tool_result ... ok
[INFO] [stdout] test capabilities::tests::test_denied_takes_precedence ... ok
[INFO] [stdout] test filesystem::tests::test_in_memory_delete ... ok
[INFO] [stdout] test filesystem::tests::test_in_memory_directories ... ok
[INFO] [stdout] test filesystem::tests::test_in_memory_exists ... ok
[INFO] [stdout] test context::compactor::tests::test_compact_history_too_few_messages ... ok
[INFO] [stdout] test context::compactor::tests::test_format_messages_for_summary ... ok
[INFO] [stdout] test context::compactor::tests::test_compact_history ... ok
[INFO] [stdout] test llm::router::tests::complexity_to_tier ... ok
[INFO] [stdout] test llm::streaming::tests::test_accumulator_empty ... ok
[INFO] [stdout] test filesystem::tests::test_in_memory_grep ... ok
[INFO] [stdout] test filesystem::tests::test_in_memory_list_dir ... ok
[INFO] [stdout] test filesystem::tests::test_in_memory_write_and_read ... ok
[INFO] [stdout] test filesystem::tests::test_in_memory_glob ... ok
[INFO] [stdout] test agent_loop::tests::test_server_error_recovery ... ok
[INFO] [stdout] test llm::streaming::tests::test_accumulator_multiple_text_blocks ... ok
[INFO] [stdout] test llm::streaming::tests::test_accumulator_invalid_tool_json ... ok
[INFO] [stdout] test llm::streaming::tests::test_accumulator_mixed_content ... ok
[INFO] [stdout] test agent_loop::tests::test_rate_limit_recovery ... ok
[INFO] [stdout] test llm::streaming::tests::test_accumulator_skips_empty_text ... ok
[INFO] [stdout] test llm::streaming::tests::test_accumulator_tool_use ... ok
[INFO] [stdout] test mcp::client::tests::test_client_info ... ok
[INFO] [stdout] test mcp::client::tests::test_mcp_protocol_version ... ok
[INFO] [stdout] test mcp::protocol::tests::test_mcp_content_text ... ok
[INFO] [stdout] test mcp::protocol::tests::test_request_id_variants ... ok
[INFO] [stdout] test mcp::protocol::tests::test_mcp_tool_definition_deserialization ... ok
[INFO] [stdout] test mcp::tool_bridge::tests::test_format_mcp_content_empty ... ok
[INFO] [stdout] test mcp::protocol::tests::test_json_rpc_response_success ... ok
[INFO] [stdout] test mcp::protocol::tests::test_json_rpc_response_error ... ok
[INFO] [stdout] test llm::streaming::tests::test_accumulator_text_deltas ... ok
[INFO] [stdout] test mcp::tool_bridge::tests::test_format_mcp_content_image ... ok
[INFO] [stdout] test mcp::tool_bridge::tests::test_format_mcp_content_resource_with_text ... ok
[INFO] [stdout] test mcp::tool_bridge::tests::test_format_mcp_content_text ... ok
[INFO] [stdout] test mcp::tool_bridge::tests::test_format_mcp_content_resource ... ok
[INFO] [stdout] test mcp::protocol::tests::test_json_rpc_request_serialization ... ok
[INFO] [stdout] test capabilities::tests::test_glob_matching ... ok
[INFO] [stdout] test capabilities::tests::test_allowed_paths_restriction ... ok
[INFO] [stdout] test mcp::tool_bridge::tests::test_format_mcp_content_multiple ... ok
[INFO] [stdout] test mcp::transport::tests::test_request_id_generation ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_invalid_input ... ok
[INFO] [stdout] test capabilities::tests::test_read_only_cannot_write ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_dangerous_command_denied ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_exec_disabled ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_tool_metadata ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_truncate_command_function ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_allowed_commands_restriction ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_denied_path ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_simple_command ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_empty_output ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_command_with_stderr ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_sudo_command_denied ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_command_not_found ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_custom_timeout ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_file_not_found ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_permission_denied ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_invalid_input ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_command_nonzero_exit ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_tool_metadata ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_truncate_string_function ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_replace_all_true ... ok
[INFO] [stdout] test primitive_tools::bash::tests::test_bash_long_output_truncated ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_multiple_occurrences_without_replace_all ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_invalid_input ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_directory_path ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_simple_replacement ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_permission_denied ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_multiline_replacement ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_empty_new_string_deletes ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_allowed_paths_restriction ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_tool_metadata ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_filters_inaccessible_files ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_preserves_surrounding_content ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_special_characters ... ok
[INFO] [stdout] test capabilities::tests::test_dangerous_commands_denied ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_invalid_input ... ok
[INFO] [stdout] test capabilities::tests::test_default_allows_normal_files ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_empty_directory ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_no_matches ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_empty_file ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_filters_inaccessible_files ... ok
[INFO] [stdout] test capabilities::tests::test_default_denies_sensitive_files ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_permission_denied ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_no_matches ... ok
[INFO] [stdout] test primitive_tools::edit::tests::test_edit_string_not_found ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_tool_metadata ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_specific_file_extension ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_truncate_line_function ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_estimate_lines_for_tokens ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_allowed_path_restriction ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_denied_path_via_capabilities ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_with_path ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_long_line_truncated ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_recursive_pattern ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_directory_returns_error ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_with_path ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_invalid_input ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_non_recursive ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_file_with_special_characters ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_large_file_exceeds_token_limit ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_entire_file ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_simple_pattern ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_multiple_files ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_permission_denied ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_large_file_with_explicit_limit_bypasses_check ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_large_file_with_pagination ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_tool_metadata ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_empty_file ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_allowed_path_restriction ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_invalid_input_missing_content ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_invalid_input_missing_path ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_simple_pattern ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_content_with_special_characters ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_special_regex_characters ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_empty_content ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_permission_denied_no_write_capability ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_offset_beyond_file_length ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_permission_denied_via_denied_paths ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_with_offset_and_limit ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_tool_metadata ... ok
[INFO] [stdout] test providers::anthropic::tests::test_api_content_block_text_serialization ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_with_offset ... ok
[INFO] [stdout] test providers::anthropic::tests::test_api_content_block_tool_result_with_error_serialization ... ok
[INFO] [stdout] test providers::anthropic::tests::test_api_content_block_tool_result_serialization ... ok
[INFO] [stdout] test providers::anthropic::tests::test_api_request_with_stream ... ok
[INFO] [stdout] test providers::anthropic::tests::test_api_content_block_tool_use_serialization ... ok
[INFO] [stdout] test providers::anthropic::tests::test_api_response_deserialization ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_regex_pattern ... ok
[INFO] [stdout] test agent_loop::tests::test_rate_limit_handling ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_multiline_content ... ok
[INFO] [stdout] test providers::anthropic::tests::test_api_response_with_tool_use_deserialization ... ok
[INFO] [stdout] test providers::anthropic::tests::test_api_response_mixed_content_deserialization ... ok
[INFO] [stdout] test providers::anthropic::tests::test_api_role_serialization ... ok
[INFO] [stdout] test providers::anthropic::tests::test_api_stop_reason_deserialization ... ok
[INFO] [stdout] test providers::anthropic::tests::test_api_tool_serialization ... ok
[INFO] [stdout] test providers::anthropic::tests::test_model_constants_have_expected_values ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_nonexistent_file ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_case_insensitive ... ok
[INFO] [stdout] test providers::anthropic::tests::test_sse_delta_types_deserialization ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_large_file ... ok
[INFO] [stdout] test agent_loop::tests::test_server_error_handling ... ok
[INFO] [stdout] test providers::anthropic::tests::test_sse_content_block_types_deserialization ... ok
[INFO] [stdout] test providers::anthropic::tests::test_sse_message_stop_emits_usage ... ok
[INFO] [stdout] test providers::anthropic::tests::test_sse_text_delta_parsing ... ok
[INFO] [stdout] test providers::anthropic::tests::test_sse_tool_use_start_parsing ... ok
[INFO] [stdout] test providers::gemini::tests::test_api_content_serialization ... ok
[INFO] [stdout] test providers::anthropic::tests::test_sse_input_json_delta_parsing ... ok
[INFO] [stdout] test providers::anthropic::tests::test_sse_message_delta_parsing ... ok
[INFO] [stdout] test providers::anthropic::tests::test_sse_message_start_captures_input_tokens ... ok
[INFO] [stdout] test providers::gemini::tests::test_api_generation_config_serialization ... ok
[INFO] [stdout] test providers::gemini::tests::test_api_part_function_call_serialization ... ok
[INFO] [stdout] test providers::gemini::tests::test_api_part_text_serialization ... ok
[INFO] [stdout] test providers::gemini::tests::test_api_finish_reason_deserialization ... ok
[INFO] [stdout] test providers::gemini::tests::test_api_part_function_response_serialization ... ok
[INFO] [stdout] test providers::gemini::tests::test_api_response_deserialization ... ok
[INFO] [stdout] test providers::gemini::tests::test_api_response_with_function_call_deserialization ... ok
[INFO] [stdout] test providers::gemini::tests::test_api_tool_config_serialization ... ok
[INFO] [stdout] test providers::gemini::tests::test_build_api_contents_assistant ... ok
[INFO] [stdout] test providers::gemini::tests::test_build_api_contents_simple ... ok
[INFO] [stdout] test providers::gemini::tests::test_build_content_blocks_text_only ... ok
[INFO] [stdout] test providers::gemini::tests::test_convert_tools_to_config ... ok
[INFO] [stdout] test providers::gemini::tests::test_build_content_blocks_with_function_call ... ok
[INFO] [stdout] test providers::gemini::tests::test_model_constants_have_expected_values ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_to_nested_directory ... ok
[INFO] [stdout] test primitive_tools::read::tests::test_read_with_limit ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_new_file ... ok
[INFO] [stdout] test providers::gemini::tests::test_streaming_response_function_call_deserialization ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_overwrite_existing_file ... ok
[INFO] [stdout] test providers::gemini::tests::test_streaming_response_with_usage_deserialization ... ok
[INFO] [stdout] test providers::gemini::tests::test_uuid_simple_generates_unique_ids ... ok
[INFO] [stdout] test providers::openai::tests::test_api_finish_reason_deserialization ... ok
[INFO] [stdout] test providers::openai::tests::test_api_message_serialization_simple ... ok
[INFO] [stdout] test providers::openai::tests::test_api_message_serialization_with_tool_calls ... ok
[INFO] [stdout] test providers::openai::tests::test_api_response_deserialization ... ok
[INFO] [stdout] test primitive_tools::write::tests::test_write_to_directory_path_returns_error ... ok
[INFO] [stdout] test providers::openai::tests::test_api_role_serialization ... ok
[INFO] [stdout] test providers::openai::tests::test_api_response_with_tool_calls_deserialization ... ok
[INFO] [stdout] test providers::openai::tests::test_api_tool_message_serialization ... ok
[INFO] [stdout] test providers::openai::tests::test_api_tool_serialization ... ok
[INFO] [stdout] test providers::openai::tests::test_build_api_messages_empty_system ... ok
[INFO] [stdout] test providers::openai::tests::test_build_content_blocks_text_only ... ok
[INFO] [stdout] test providers::openai::tests::test_build_content_blocks_with_tool_calls ... ok
[INFO] [stdout] test providers::openai::tests::test_build_api_messages_with_system ... ok
[INFO] [stdout] test providers::openai::tests::test_convert_tool ... ok
[INFO] [stdout] test providers::gemini::tests::test_streaming_response_text_deserialization ... ok
[INFO] [stdout] test providers::gemini::tests::test_provider_is_cloneable ... ok
[INFO] [stdout] test providers::openai::tests::test_gpt4o_factory_creates_gpt4o_provider ... ok
[INFO] [stdout] test providers::anthropic::tests::test_provider_is_cloneable ... ok
[INFO] [stdout] test providers::openai::tests::test_gpt52_thinking_factory_creates_provider ... ok
[INFO] [stdout] test providers::openai::tests::test_model_constants_have_expected_values ... ok
[INFO] [stdout] test providers::openai::tests::test_gpt41_factory_creates_gpt41_provider ... ok
[INFO] [stdout] test providers::anthropic::tests::test_sonnet_factory_creates_sonnet_provider ... ok
[INFO] [stdout] test providers::openai::tests::test_gpt4o_mini_factory_creates_gpt4o_mini_provider ... ok
[INFO] [stdout] test providers::anthropic::tests::test_haiku_factory_creates_haiku_provider ... ok
[INFO] [stdout] test providers::openai::tests::test_sse_chunk_text_delta_deserialization ... ok
[INFO] [stdout] test providers::openai::tests::test_sse_chunk_tool_call_arguments_delta_deserialization ... ok
[INFO] [stdout] test providers::openai::tests::test_sse_chunk_tool_call_delta_deserialization ... ok
[INFO] [stdout] test providers::openai::tests::test_sse_chunk_with_finish_reason_deserialization ... ok
[INFO] [stdout] test providers::openai::tests::test_sse_chunk_with_usage_deserialization ... ok
[INFO] [stdout] test providers::openai::tests::test_sse_finish_reason_deserialization ... ok
[INFO] [stdout] test providers::openai::tests::test_streaming_request_serialization ... ok
[INFO] [stdout] test providers::anthropic::tests::test_new_creates_provider_with_custom_model ... ok
[INFO] [stdout] test providers::openai_responses::tests::test_api_response_deserialization ... ok
[INFO] [stdout] test providers::openai_responses::tests::test_api_response_with_function_call ... ok
[INFO] [stdout] test providers::openai_responses::tests::test_api_tool_serialization ... ok
[INFO] [stdout] test providers::gemini::tests::test_flash_lite_factory_creates_flash_lite_provider ... ok
[INFO] [stdout] test providers::openai_responses::tests::test_build_content_blocks_text ... ok
[INFO] [stdout] test providers::gemini::tests::test_new_creates_provider_with_custom_model ... ok
[INFO] [stdout] test providers::openai_responses::tests::test_model_constant ... ok
[INFO] [stdout] test providers::openai_responses::tests::test_reasoning_effort_serialization ... ok
[INFO] [stdout] test providers::openai::tests::test_gpt5_factory_creates_gpt5_provider ... ok
[INFO] [stdout] test reminders::tests::test_append_reminder ... ok
[INFO] [stdout] test reminders::tests::test_no_todo_reminder_when_recently_used ... ok
[INFO] [stdout] test reminders::tests::test_reminder_config_builder ... ok
[INFO] [stdout] test reminders::tests::test_reminder_config_disabled ... ok
[INFO] [stdout] test providers::gemini::tests::test_pro_factory_creates_pro_provider ... ok
[INFO] [stdout] test reminders::tests::test_reminder_tracker_new ... ok
[INFO] [stdout] test reminders::tests::test_reminder_tracker_record_tool_use ... ok
[INFO] [stdout] test reminders::tests::test_reminder_tracker_repeated_action ... ok
[INFO] [stdout] test reminders::tests::test_reminder_trigger_always ... ok
[INFO] [stdout] test reminders::tests::test_reminder_trigger_input_matches ... ok
[INFO] [stdout] test reminders::tests::test_reminder_trigger_result_contains ... ok
[INFO] [stdout] test reminders::tests::test_repeated_action_warning ... ok
[INFO] [stdout] test reminders::tests::test_todo_reminder_after_turns ... ok
[INFO] [stdout] test reminders::tests::test_tool_reminder_builders ... ok
[INFO] [stdout] test reminders::tests::test_wrap_reminder ... ok
[INFO] [stdout] test reminders::tests::test_wrap_reminder_trims_whitespace ... ok
[INFO] [stdout] test skills::loader::tests::test_file_loader_exists ... ok
[INFO] [stdout] test skills::loader::tests::test_file_loader_list ... ok
[INFO] [stdout] test skills::loader::tests::test_file_loader_list_empty_dir ... ok
[INFO] [stdout] test skills::loader::tests::test_file_loader_list_nonexistent_dir ... ok
[INFO] [stdout] test skills::loader::tests::test_file_loader_load ... ok
[INFO] [stdout] test skills::loader::tests::test_file_loader_load_not_found ... ok
[INFO] [stdout] test skills::loader::tests::test_in_memory_loader ... ok
[INFO] [stdout] test reminders::tests::test_reminder_tracker_advance_turn ... ok
[INFO] [stdout] test skills::loader::tests::test_in_memory_loader_not_found ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_empty_body ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_invalid_yaml ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_missing_closing_delimiter ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_missing_frontmatter ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_missing_name ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_preserves_markdown_formatting ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_simple_skill ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_skill_with_allowed_tools ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_skill_with_extra_metadata ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_skill_with_tools ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_with_enabled_disabled_tools ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_with_id_instead_of_name ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_with_instructions_alias ... ok
[INFO] [stdout] test providers::openai_responses::tests::test_with_reasoning_effort ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_with_title_instead_of_name ... ok
[INFO] [stdout] test skills::tests::test_is_tool_allowed_denied_takes_precedence ... ok
[INFO] [stdout] test skills::tests::test_is_tool_allowed_no_restrictions ... ok
[INFO] [stdout] test providers::anthropic::tests::test_opus_factory_creates_opus_provider ... ok
[INFO] [stdout] test skills::tests::test_is_tool_allowed_with_denied ... ok
[INFO] [stdout] test skills::tests::test_is_tool_allowed_with_whitelist ... ok
[INFO] [stdout] test stores::tests::test_execution_store_basic_operations ... ok
[INFO] [stdout] test skills::tests::test_skill_builder ... ok
[INFO] [stdout] test stores::tests::test_execution_store_operation_id_lookup ... ok
[INFO] [stdout] test providers::openai::tests::test_o1_factory_creates_o1_provider ... ok
[INFO] [stdout] test stores::tests::test_in_memory_state_store ... ok
[INFO] [stdout] test stores::tests::test_in_memory_message_store ... ok
[INFO] [stdout] test stores::tests::test_execution_store_complete_execution ... ok
[INFO] [stdout] test subagent::tests::test_subagent_config_builder ... ok
[INFO] [stdout] test subagent::factory::tests::test_subagent_config_builder ... ok
[INFO] [stdout] test subagent::tests::test_subagent_config_defaults ... ok
[INFO] [stdout] test subagent::tests::test_subagent_result_field_extraction ... ok
[INFO] [stdout] test subagent::tests::test_subagent_result_serialization ... ok
[INFO] [stdout] test todo::tests::test_todo_item_new ... ok
[INFO] [stdout] test todo::tests::test_todo_state_count_by_status ... ok
[INFO] [stdout] test todo::tests::test_todo_state_current_task ... ok
[INFO] [stdout] test todo::tests::test_todo_status_icons ... ok
[INFO] [stdout] test todo::tests::test_todo_state_format_display ... ok
[INFO] [stdout] test todo::tests::test_todo_status_serde ... ok
[INFO] [stdout] test tools::tests::test_dynamic_tool_name ... ok
[INFO] [stdout] test tools::tests::test_filter_tools ... ok
[INFO] [stdout] test tools::tests::test_filter_tools_keep_all ... ok
[INFO] [stdout] test providers::openai_responses::tests::test_build_content_blocks_function_call ... ok
[INFO] [stdout] test tools::tests::test_filter_tools_remove_all ... ok
[INFO] [stdout] test tools::tests::test_to_llm_tools ... ok
[INFO] [stdout] test tools::tests::test_tool_name_serialization ... ok
[INFO] [stdout] test tools::tests::test_tool_registry ... ok
[INFO] [stdout] test user_interaction::tests::test_ask_user_tool_creation ... ok
[INFO] [stdout] test user_interaction::tests::test_ask_user_tool_execute ... ok
[INFO] [stdout] test user_interaction::tests::test_ask_user_with_options ... ok
[INFO] [stdout] test user_interaction::tests::test_confirmation_request_new ... ok
[INFO] [stdout] test user_interaction::tests::test_confirmation_request_with_context ... ok
[INFO] [stdout] test user_interaction::tests::test_confirmation_response_serialization ... ok
[INFO] [stdout] test user_interaction::tests::test_question_request_new ... ok
[INFO] [stdout] test user_interaction::tests::test_question_request_with_options ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_empty_system_prompt_in_frontmatter_uses_body ... ok
[INFO] [stdout] test skills::parser::tests::test_parse_with_system_prompt_in_frontmatter ... ok
[INFO] [stdout] test stores::tests::test_replace_history ... ok
[INFO] [stdout] test user_interaction::tests::test_question_response ... ok
[INFO] [stdout] test user_interaction::tests::test_ask_user_cancelled ... ok
[INFO] [stdout] test web::fetch::tests::test_format_from_str ... ok
[INFO] [stdout] test web::fetch::tests::test_format_name ... ok
[INFO] [stdout] test web::fetch::tests::test_convert_html_text ... ok
[INFO] [stdout] test providers::openai::tests::test_o3_factory_creates_o3_provider ... ok
[INFO] [stdout] test providers::openai::tests::test_provider_is_cloneable ... ok
[INFO] [stdout] test providers::openai::tests::test_new_creates_provider_with_custom_model ... ok
[INFO] [stdout] test providers::openai::tests::test_with_base_url_creates_provider_with_custom_url ... ok
[INFO] [stdout] test providers::openai::tests::test_o4_mini_factory_creates_o4_mini_provider ... ok
[INFO] [stdout] test web::provider::tests::test_search_response_serialization ... ok
[INFO] [stdout] test web::provider::tests::test_search_result_serialization ... ok
[INFO] [stdout] test web::search::tests::test_format_search_results_empty ... ok
[INFO] [stdout] test web::search::tests::test_format_search_results_with_data ... ok
[INFO] [stdout] test web::search::tests::test_web_search_tool_execute ... ok
[INFO] [stdout] test web::search::tests::test_web_search_tool_input_schema ... ok
[INFO] [stdout] test web::search::tests::test_web_search_tool_metadata ... ok
[INFO] [stdout] test web::search::tests::test_web_search_tool_missing_query ... ok
[INFO] [stdout] test web::search::tests::test_web_search_tool_no_results ... ok
[INFO] [stdout] test web::search::tests::test_web_search_tool_override_max_results ... ok
[INFO] [stdout] test web::search::tests::test_web_search_tool_with_max_results ... ok
[INFO] [stdout] test providers::openai::tests::test_gpt5_mini_factory_creates_provider ... ok
[INFO] [stdout] test web::security::tests::test_allowed_domains ... ok
[INFO] [stdout] test web::security::tests::test_blocked_hosts ... ok
[INFO] [stdout] test web::security::tests::test_default_validator ... ok
[INFO] [stdout] test web::security::tests::test_http_allowed_with_flag ... ok
[INFO] [stdout] test web::security::tests::test_http_blocked_by_default ... ok
[INFO] [stdout] test web::security::tests::test_invalid_url ... ok
[INFO] [stdout] test web::security::tests::test_is_private_ipv4 ... ok
[INFO] [stdout] test web::security::tests::test_localhost_blocked ... ok
[INFO] [stdout] test web::security::tests::test_max_redirects ... ok
[INFO] [stdout] test web::security::tests::test_metadata_endpoints_blocked ... ok
[INFO] [stdout] test web::security::tests::test_valid_https_url ... ok
[INFO] [stdout] test web::fetch::tests::test_link_fetch_tool_metadata ... ok
[INFO] [stdout] test web::fetch::tests::test_link_fetch_tool_input_schema ... ok
[INFO] [stdout] test web::provider::tests::test_brave_provider_creation ... ok
[INFO] [stdout] test web::fetch::tests::test_link_fetch_blocked_url ... ok
[INFO] [stdout] test providers::openai_responses::tests::test_codex_factory ... ok
[INFO] [stdout] test web::fetch::tests::test_link_fetch_invalid_url ... ok
[INFO] [stdout] test web::fetch::tests::test_link_fetch_missing_url ... ok
[INFO] [stdout] test providers::gemini::tests::test_flash_factory_creates_flash_provider ... ok
[INFO] [stdout] test tools::tests::test_display_name ... ok
[INFO] [stdout] test web::fetch::tests::test_default_format ... ok
[INFO] [stdout] test web::provider::tests::test_brave_provider_with_custom_client ... ok
[INFO] [stdout] test web::fetch::tests::test_with_validator ... ok
[INFO] [stdout] test primitive_tools::grep::tests::test_grep_many_matches_truncated ... ok
[INFO] [stdout] test primitive_tools::glob::tests::test_glob_many_files_truncated ... ok
[INFO] [stderr]    Doc-tests agent_sdk
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 364 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 2.97s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 45 tests
[INFO] [stdout] test src/agent_loop.rs - agent_loop (line 21) ... ignored
[INFO] [stdout] test src/agent_loop.rs - agent_loop::AgentLoop (line 446) ... ignored
[INFO] [stdout] test src/agent_loop.rs - agent_loop::AgentLoop<Ctx,P,H,M,S>::run (line 556) ... ignored
[INFO] [stdout] test src/agent_loop.rs - agent_loop::AgentLoop<Ctx,P,H,M,S>::run_turn (line 656) ... ignored
[INFO] [stdout] test src/agent_loop.rs - agent_loop::AgentLoopBuilder (line 118) ... ignored
[INFO] [stdout] test src/agent_loop.rs - agent_loop::AgentLoopBuilder<Ctx,P,H,M,S>::execution_store (line 242) ... ignored
[INFO] [stdout] test src/agent_loop.rs - agent_loop::AgentLoopBuilder<Ctx,P,H,M,S>::with_auto_compaction (line 287) ... ignored
[INFO] [stdout] test src/agent_loop.rs - agent_loop::AgentLoopBuilder<Ctx,P,H,M,S>::with_compaction (line 270) ... ignored
[INFO] [stdout] test src/agent_loop.rs - agent_loop::AgentLoopBuilder<Ctx,P,H,M,S>::with_skill (line 302) ... ignored
[INFO] [stdout] test src/context.rs - context (line 18) ... ignored
[INFO] [stdout] test src/lib.rs - (line 130) - compile ... ok
[INFO] [stdout] test src/lib.rs - (line 13) - compile ... ok
[INFO] [stdout] test src/lib.rs - (line 226) - compile ... ok
[INFO] [stdout] test src/capabilities.rs - capabilities::AgentCapabilities (line 10) ... ok
[INFO] [stdout] test src/lib.rs - (line 64) - compile ... ok
[INFO] [stdout] test src/mcp.rs - mcp (line 18) ... ignored
[INFO] [stdout] test src/mcp/client.rs - mcp::client::McpClient (line 24) ... ignored
[INFO] [stdout] test src/mcp/tool_bridge.rs - mcp::tool_bridge::McpToolBridge (line 20) ... ignored
[INFO] [stdout] test src/mcp/tool_bridge.rs - mcp::tool_bridge::register_mcp_tools (line 150) ... ignored
[INFO] [stdout] test src/mcp/transport.rs - mcp::transport::McpTransport (line 21) ... ignored
[INFO] [stdout] test src/skills.rs - skills (line 23) ... ignored
[INFO] [stdout] test src/skills/loader.rs - skills::loader::FileSkillLoader (line 39) ... ignored
[INFO] [stdout] test src/subagent.rs - subagent (line 16) ... ignored
[INFO] [stdout] test src/subagent.rs - subagent::SubagentTool (line 144) ... ignored
[INFO] [stdout] test src/subagent/factory.rs - subagent::factory (line 8) ... ignored
[INFO] [stdout] test src/tools.rs - tools (line 14) ... ignored
[INFO] [stdout] test src/tools.rs - tools::AsyncTool (line 341) ... ignored
[INFO] [stdout] test src/tools.rs - tools::ErasedTool (line 429) ... ignored
[INFO] [stdout] test src/tools.rs - tools::ProgressStage (line 149) ... ignored
[INFO] [stdout] test src/tools.rs - tools::ToolName (line 62) ... ignored
[INFO] [stdout] test src/todo.rs - todo (line 9) - compile ... ok
[INFO] [stdout] test src/tools.rs - tools::ToolRegistry<Ctx>::filter (line 716) ... ignored
[INFO] [stdout] test src/web.rs - web (line 13) ... ignored
[INFO] [stdout] test src/web/fetch.rs - web::fetch::LinkFetchTool (line 44) ... ignored
[INFO] [stdout] test src/web/provider.rs - web::provider::BraveSearchProvider (line 76) ... ignored
[INFO] [stdout] test src/web/provider.rs - web::provider::SearchProvider (line 37) ... ignored
[INFO] [stdout] test src/web/search.rs - web::search::WebSearchTool (line 19) ... ignored
[INFO] [stdout] test src/web/security.rs - web::security::UrlValidator (line 29) ... ignored
[INFO] [stdout] test src/user_interaction.rs - user_interaction (line 29) - compile ... ok
[INFO] [stdout] test src/context/config.rs - context::config::CompactionConfig (line 11) ... ok
[INFO] [stdout] test src/lib.rs - (line 172) ... ok
[INFO] [stdout] test src/lib.rs - (line 297) ... ok
[INFO] [stdout] test src/lib.rs - (line 242) ... ok
[INFO] [stdout] test src/reminders.rs - reminders (line 10) ... ok
[INFO] [stdout] test src/lib.rs - (line 84) ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 13 passed; 0 failed; 32 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] all doctests ran in 1.34s; merged doctests compilation took 1.30s
[INFO] running `Command { std: "docker" "inspect" "cda69883931cf3d23145e597c487d34015c896447b552c5bf434dfc3be096806", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cda69883931cf3d23145e597c487d34015c896447b552c5bf434dfc3be096806", kill_on_drop: false }`
[INFO] [stdout] cda69883931cf3d23145e597c487d34015c896447b552c5bf434dfc3be096806
