[INFO] fetching crate borsa 0.2.0...
[INFO] testing borsa-0.2.0 against master#c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38 for pr-146098-7
[INFO] extracting crate borsa 0.2.0 into /workspace/builds/worker-4-tc1/source
[INFO] started tweaking crates.io crate borsa 0.2.0
[INFO] removed 0 missing tests
[INFO] finished tweaking crates.io crate borsa 0.2.0
[INFO] tweaked toml for crates.io crate borsa 0.2.0 written to /workspace/builds/worker-4-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate borsa 0.2.0 on toolchain c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate borsa 0.2.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" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded polars-error v0.51.0
[INFO] [stderr]   Downloaded borsa-types v0.2.0
[INFO] [stderr]   Downloaded paft-utils v0.6.0
[INFO] [stderr]   Downloaded planus v1.1.1
[INFO] [stderr]   Downloaded paft-core v0.6.0
[INFO] [stderr]   Downloaded polars-utils v0.51.0
[INFO] [stderr]   Downloaded paft-domain v0.6.0
[INFO] [stderr]   Downloaded borsa-mock v0.2.0
[INFO] [stderr]   Downloaded borsa-core v0.2.0
[INFO] [stderr]   Downloaded polars-mem-engine v0.51.0
[INFO] [stderr]   Downloaded df-derive v0.1.1
[INFO] [stderr]   Downloaded polars-expr v0.51.0
[INFO] [stderr]   Downloaded polars-compute v0.51.0
[INFO] [stderr]   Downloaded polars-sql v0.51.0
[INFO] [stderr]   Downloaded skiplist v0.6.0
[INFO] [stderr]   Downloaded simd-json v0.15.1
[INFO] [stderr]   Downloaded polars-parquet v0.51.0
[INFO] [stderr]   Downloaded quick-xml v0.38.3
[INFO] [stderr]   Downloaded polars-io v0.51.0
[INFO] [stderr]   Downloaded polars-stream v0.51.0
[INFO] [stderr]   Downloaded polars-ops v0.51.0
[INFO] [stderr]   Downloaded object_store v0.12.4
[INFO] [stderr]   Downloaded polars-arrow v0.51.0
[INFO] [stderr]   Downloaded polars v0.51.0
[INFO] [stderr]   Downloaded polars-lazy v0.51.0
[INFO] [stderr]   Downloaded polars-core v0.51.0
[INFO] [stderr]   Downloaded polars-time v0.51.0
[INFO] [stderr]   Downloaded polars-arrow-format v0.2.1
[INFO] [stderr]   Downloaded paft-fundamentals v0.6.0
[INFO] [stderr]   Downloaded iso_currency v0.5.3
[INFO] [stderr]   Downloaded polars-plan v0.51.0
[INFO] [stderr]   Downloaded paft-money v0.6.0
[INFO] [stderr]   Downloaded paft-aggregates v0.6.0
[INFO] [stderr]   Downloaded isin v0.1.19
[INFO] [stderr]   Downloaded fs4 v0.13.1
[INFO] [stderr]   Downloaded halfbrown v0.3.0
[INFO] [stderr]   Downloaded value-trait v0.11.0
[INFO] [stderr]   Downloaded boxcar v0.2.14
[INFO] [stderr]   Downloaded polars-schema v0.51.0
[INFO] [stderr]   Downloaded paft-market v0.6.0
[INFO] [stderr]   Downloaded iso_country v0.1.4
[INFO] [stderr]   Downloaded polars-json v0.51.0
[INFO] [stderr]   Downloaded polars-row v0.51.0
[INFO] [stderr]   Downloaded paft v0.6.0
[INFO] [stderr]   Downloaded polars-dtype v0.51.0
[INFO] [stderr]   Downloaded serde_stacker v0.1.14
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] ccd5f0289f7124c5f9f76e4ead55750576ef708995b9b00e8fefb231b9becff3
[INFO] running `Command { std: "docker" "start" "-a" "ccd5f0289f7124c5f9f76e4ead55750576ef708995b9b00e8fefb231b9becff3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "ccd5f0289f7124c5f9f76e4ead55750576ef708995b9b00e8fefb231b9becff3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ccd5f0289f7124c5f9f76e4ead55750576ef708995b9b00e8fefb231b9becff3", kill_on_drop: false }`
[INFO] [stdout] ccd5f0289f7124c5f9f76e4ead55750576ef708995b9b00e8fefb231b9becff3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 59721d4849ae81844fd4db57c119f1bcfa3783d8cf2002adee9fc1495eacf02e
[INFO] running `Command { std: "docker" "start" "-a" "59721d4849ae81844fd4db57c119f1bcfa3783d8cf2002adee9fc1495eacf02e", kill_on_drop: false }`
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling rust_decimal v1.39.0
[INFO] [stderr]    Compiling regex-syntax v0.8.6
[INFO] [stderr]    Compiling arrayvec v0.7.6
[INFO] [stderr]    Compiling isin v0.1.19
[INFO] [stderr]    Compiling chrono-tz v0.10.4
[INFO] [stderr]    Compiling libc v0.2.175
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling iso_country v0.1.4
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling iso_currency v0.5.3
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling regex-automata v0.4.12
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling tokio v1.48.0
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling paft-utils v0.6.0
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling chrono v0.4.42
[INFO] [stderr]    Compiling bitflags v2.9.4
[INFO] [stderr]    Compiling paft-money v0.6.0
[INFO] [stderr]    Compiling paft-core v0.6.0
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling paft-domain v0.6.0
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling paft-fundamentals v0.6.0
[INFO] [stderr]    Compiling paft-market v0.6.0
[INFO] [stderr]    Compiling paft-aggregates v0.6.0
[INFO] [stderr]    Compiling paft v0.6.0
[INFO] [stderr]    Compiling borsa-types v0.2.0
[INFO] [stderr]    Compiling borsa-core v0.2.0
[INFO] [stderr]    Compiling borsa v0.2.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 34.02s
[INFO] running `Command { std: "docker" "inspect" "59721d4849ae81844fd4db57c119f1bcfa3783d8cf2002adee9fc1495eacf02e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "59721d4849ae81844fd4db57c119f1bcfa3783d8cf2002adee9fc1495eacf02e", kill_on_drop: false }`
[INFO] [stdout] 59721d4849ae81844fd4db57c119f1bcfa3783d8cf2002adee9fc1495eacf02e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 47cc704baa0eeff28ec475ca4b2e959286ffd25d8ea735b20ad9466210b7cd93
[INFO] running `Command { std: "docker" "start" "-a" "47cc704baa0eeff28ec475ca4b2e959286ffd25d8ea735b20ad9466210b7cd93", kill_on_drop: false }`
[INFO] [stderr]    Compiling tokio v1.48.0
[INFO] [stderr]    Compiling borsa-core v0.2.0
[INFO] [stderr]    Compiling borsa-mock v0.2.0
[INFO] [stderr]    Compiling borsa v0.2.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 11.78s
[INFO] running `Command { std: "docker" "inspect" "47cc704baa0eeff28ec475ca4b2e959286ffd25d8ea735b20ad9466210b7cd93", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "47cc704baa0eeff28ec475ca4b2e959286ffd25d8ea735b20ad9466210b7cd93", kill_on_drop: false }`
[INFO] [stdout] 47cc704baa0eeff28ec475ca4b2e959286ffd25d8ea735b20ad9466210b7cd93
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 3800902a655896fbc22de14616007b4adbc20daa5525852e231db04163497f90
[INFO] running `Command { std: "docker" "start" "-a" "3800902a655896fbc22de14616007b4adbc20daa5525852e231db04163497f90", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.22s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/borsa-9278e06c8d98ce7b)
[INFO] [stdout] 
[INFO] [stderr]      Running tests/dataframe_history.rs (/opt/rustwide/target/debug/deps/dataframe_history-3912d1a2a1e72e4e)
[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] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stderr]      Running tests/dataframe_quote.rs (/opt/rustwide/target/debug/deps/dataframe_quote-d3c1d0961490b6fa)
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[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 tests/router.rs (/opt/rustwide/target/debug/deps/router-704022edff584776)
[INFO] [stdout] 
[INFO] [stdout] running 96 tests
[INFO] [stdout] test router_analysis_not_found::all_not_found_returns_not_found ... ok
[INFO] [stdout] test router_analysis_upgrades_downgrades::upgrades_downgrades_falls_back_and_succeeds ... ok
[INFO] [stdout] test router_balance_sheet::balance_sheet_falls_back_and_succeeds ... ok
[INFO] [stdout] test router_calendar::calendar_falls_back_and_succeeds ... ok
[INFO] [stdout] test router_download::download_builder_allows_different_symbols ... ok
[INFO] [stdout] test router_download::download_builder_handles_empty_instruments_list ... ok
[INFO] [stdout] test router_download::download_builder_fetches_for_multiple_instruments ... ok
[INFO] [stdout] test router_download::download_builder_rejects_duplicate_symbols_in_instruments ... ok
[INFO] [stdout] test router_download::download_builder_rejects_duplicate_symbols_in_add_instrument ... ok
[INFO] [stdout] test router_history_attribution::history_with_attribution_marks_provider_spans ... ok
[INFO] [stdout] test router_history_auto_resample::auto_does_not_trigger_for_daily_series ... ok
[INFO] [stdout] test router_cashflow::cashflow_falls_back_and_succeeds ... ok
[INFO] [stdout] test router_history_auto_resample::auto_resamples_when_series_is_subdaily ... ok
[INFO] [stdout] test router_history_merge::merges_adjacent_ranges ... ok
[INFO] [stdout] test router_fetch_strategies::strategy_priority_with_fallback_obeys_order_and_timeout ... ok
[INFO] [stdout] test router_esg::esg_succeeds ... ok
[INFO] [stdout] test router_history_auto_resample::explicit_daily_or_weekly_overrides_auto ... ok
[INFO] [stdout] test router_analysis_upgrades_downgrades::upgrades_downgrades_mapping ... ok
[INFO] [stdout] test router_history_empty_is_skipped::empty_history_result_is_skipped ... ok
[INFO] [stdout] test router_history_fallback::history_falls_back_when_first_errors ... ok
[INFO] [stdout] test router_history_interval_largest_divisor::picks_largest_divisor_and_resamples_to_requested ... ok
[INFO] [stdout] test router_history_interval_passthrough::router_passes_through_supported_interval ... ok
[INFO] [stdout] test router_history_interval_rounddown_resample::router_rounds_down_and_resamples_to_requested_minutes ... ok
[INFO] [stdout] test router_history_not_found::all_not_found_returns_not_found ... ok
[INFO] [stdout] test router_history_merge_strategy::merge_strategy_fallback_handles_errors_gracefully ... ok
[INFO] [stdout] test router_history_not_found::all_ok_empty_returns_not_found ... ok
[INFO] [stdout] test router_history_merge_strategy::merge_strategy_deep_fetches_all_providers ... ok
[INFO] [stdout] test router_history_merge_strategy::merge_strategy_fallback_stops_at_first_success ... ok
[INFO] [stdout] test router_history_prefer_adjusted::default_behavior_keeps_priority_if_flag_not_set ... ok
[INFO] [stdout] test router_history_merge_strategy::merge_strategy_default_is_deep ... ok
[INFO] [stdout] test router_history_merge_strategy::merge_strategy_fallback_with_overlapping_data ... ok
[INFO] [stdout] test router_history_merge_strategy::merge_strategy_fallback_continues_on_empty_data ... ok
[INFO] [stdout] test router_history_prefer_adjusted::prefer_adjusted_drops_unadjusted_even_when_non_overlapping ... ok
[INFO] [stdout] test router_history_prefer_adjusted::prefers_adjusted_series_over_non_adjusted_on_overlap ... ok
[INFO] [stdout] test router_fetch_strategies::strategy_latency_ignores_faster_failure_and_returns_first_success ... ok
[INFO] [stdout] test router_history_validate::history_bad_period_order_is_rejected_by_constructor ... ok
[INFO] [stdout] test router_history_validate::history_with_valid_range_succeeds ... ok
[INFO] [stdout] test router_history_resample_daily::resamples_intraday_into_daily ... ok
[INFO] [stdout] test router_history_merge::prefers_first_on_overlap ... ok
[INFO] [stdout] test router_history_resample_daily::without_resample_returns_original_granularity ... ok
[INFO] [stdout] test router_history_resample_weekly::resamples_into_weekly_monday_start ... ok
[INFO] [stdout] test router_history_resample_weekly::weekly_takes_precedence_over_daily ... ok
[INFO] [stdout] test router_history_prefer_adjusted::no_preference_keeps_first_series_adjustedness_even_when_non_overlapping ... ok
[INFO] [stdout] test router_history_raw_close::raw_close_dropped_when_resampled ... ok
[INFO] [stdout] test router_history_raw_close::raw_close_preserved_for_single_source_no_resample ... ok
[INFO] [stdout] test router_holders::holders_falls_back_and_succeeds ... ok
[INFO] [stdout] test router_income_statement::income_statement_falls_back_and_succeeds ... ok
[INFO] [stdout] test router_info::router_fast_info_works ... ok
[INFO] [stdout] test router_info::router_info_aggregates_data ... ok
[INFO] [stdout] test router_info::router_info_ignores_unused_capabilities ... ok
[INFO] [stdout] test router_info::router_info_partial_failures_quote_ok_profile_and_target_fail ... ok
[INFO] [stdout] test router_info::router_info_suppresses_optional_warnings ... ok
[INFO] [stdout] test router_kind_filter_quote::router_skips_connectors_that_do_not_support_kind_for_quote ... ok
[INFO] [stdout] test router_option_chain::option_chain_falls_back_and_succeeds ... ok
[INFO] [stdout] test router_priority::per_kind_priority_is_applied ... ok
[INFO] [stdout] test router_options_expirations::expirations_falls_back_and_succeeds ... ok
[INFO] [stdout] test router_quote_not_found::all_not_found_returns_not_found ... ok
[INFO] [stdout] test router_priority::routing_policy_global_strict_excludes_unlisted ... ok
[INFO] [stdout] test router_priority::routing_policy_with_unknown_connector_fails ... ok
[INFO] [stdout] test router_quote::quote_fallback_first_success ... ok
[INFO] [stdout] test router_quote::quote_falls_back_when_exchange_mismatches ... ok
[INFO] [stdout] test router_quote::quote_without_exchange_is_accepted_when_not_provided ... ok
[INFO] [stdout] test router_quote::quote_respects_priority_override ... ok
[INFO] [stdout] test router_news::news_succeeds_and_passes_request ... ok
[INFO] [stdout] test router_fetch_strategies::strategy_latency_returns_fastest_success ... ok
[INFO] [stdout] test router_quote_not_found::not_found_does_not_block_success ... ok
[INFO] [stdout] test router_quotes_fallback::quotes_per_symbol_fallback_succeeds ... ok
[INFO] [stdout] test router_quote::quote_strict_rule_blocks_fallback ... ok
[INFO] [stdout] test router_quote_per_kind_priority::per_kind_priority_applies_to_quotes ... ok
[INFO] [stdout] test router_quote_provider_hot_swap::quote_capability_hot_swap_returns_error_not_panic ... ok
[INFO] [stdout] test router_quotes_multi::router_quotes_multi_groups_by_provider ... ok
[INFO] [stdout] test router_search_kind_filter::search_respects_connector_kind_support ... ok
[INFO] [stdout] test router_search_limit::search_applies_limit_after_merge ... ok
[INFO] [stdout] test router_stream_kind_hint::stream_quotes_respects_kind_hint_support ... ok
[INFO] [stdout] test router_search_priority::search_infers_kind_from_results_when_request_omits_it ... ok
[INFO] [stdout] test router_quote::quote_respects_exchange_override_in_provider_policy ... ok
[INFO] [stdout] test router_stream_downstream_drop::stream_quotes_exits_when_downstream_drops ... ok
[INFO] [stdout] test router_search_priority::search_respects_exchange_priority_kind_only ... ok
[INFO] [stdout] test router_stream_backoff::stream_backoff_jitter_bounds ... ok
[INFO] [stdout] test router_search_priority::search_respects_per_kind_priority_and_dedups ... ok
[INFO] [stdout] test router_search_priority::search_respects_exchange_priority_kind_and_symbol_override ... ok
[INFO] [stdout] test router_stream_quotes::stream_quotes_routes_to_streaming_connector ... ok
[INFO] [stdout] test router_search_priority::search_unknown_exchange_ranks_last ... ok
[INFO] [stdout] test router_search_unsupported::search_returns_unsupported_when_no_provider_available ... ok
[INFO] [stdout] test router_stream_no_provider::stream_quotes_errors_when_no_stream_connector ... ok
[INFO] [stdout] test router_stream_quotes_multi::stream_quotes_filters_symbols_and_emits_all ... ok
[INFO] [stdout] test router_stream_backoff::stream_backoff_exponential_no_jitter ... ok
[INFO] [stdout] test router_stream_symbol_filtering::stream_quotes_filters_to_requested_symbols_only ... ok
[INFO] [stdout] test router_stream_startup_fallback::stream_quotes_falls_back_when_first_cannot_start ... ok
[INFO] [stdout] test router_analysis_price_target::price_target_respects_per_kind_priority ... ok
[INFO] [stdout] test router_quote_concurrency::faster_lower_priority_does_not_beat_higher_priority_success ... ok
[INFO] [stdout] test router_analysis_recommendations::recommendations_respects_per_kind_priority ... ok
[INFO] [stdout] test router_analysis_recommendations_summary::recommendations_summary_respects_per_kind_priority ... ok
[INFO] [stdout] test router_stream_startup_all_fail::stream_quotes_errors_when_one_kind_fails_to_start ... ok
[INFO] [stdout] test router_stream_startup_all_fail::stream_quotes_errors_when_all_providers_fail_to_start ... ok
[INFO] [stdout] test router_stream_failover_end::stream_quotes_fails_over_when_first_provider_ends ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 96 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.69s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests borsa
[INFO] [stdout] 
[INFO] [stdout] running 5 tests
[INFO] [stdout] test src/core.rs - core::Borsa::builder (line 329) ... ignored
[INFO] [stdout] test src/lib.rs - (line 28) ... ignored
[INFO] [stdout] test src/lib.rs - (line 55) ... ignored
[INFO] [stdout] test src/lib.rs - (line 71) ... ignored
[INFO] [stdout] test src/lib.rs - (line 79) ... ignored
[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] [stdout] all doctests ran in 0.60s; merged doctests compilation took 0.60s
[INFO] running `Command { std: "docker" "inspect" "3800902a655896fbc22de14616007b4adbc20daa5525852e231db04163497f90", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3800902a655896fbc22de14616007b4adbc20daa5525852e231db04163497f90", kill_on_drop: false }`
[INFO] [stdout] 3800902a655896fbc22de14616007b4adbc20daa5525852e231db04163497f90
