[INFO] fetching crate ig-client 0.11.2... [INFO] testing ig-client-0.11.2 against master#562dee4820c458d823175268e41601d4c060588a for pr-154210-1 [INFO] extracting crate ig-client 0.11.2 into /workspace/builds/worker-4-tc1/source [INFO] removed /workspace/builds/worker-4-tc1/source/rust-toolchain.toml [INFO] started tweaking crates.io crate ig-client 0.11.2 [INFO] removed 0 missing tests [INFO] finished tweaking crates.io crate ig-client 0.11.2 [INFO] tweaked toml for crates.io crate ig-client 0.11.2 written to /workspace/builds/worker-4-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate ig-client 0.11.2 on toolchain 562dee4820c458d823175268e41601d4c060588a [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate ig-client 0.11.2 already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] 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 jsonptr v0.7.1 [INFO] [stderr] Downloaded alloca v0.4.0 [INFO] [stderr] Downloaded tokio-tungstenite v0.29.0 [INFO] [stderr] Downloaded prettytable-rs v0.10.0 [INFO] [stderr] Downloaded nonzero_ext v0.3.0 [INFO] [stderr] Downloaded page_size v0.6.0 [INFO] [stderr] Downloaded criterion-plot v0.8.2 [INFO] [stderr] Downloaded quanta v0.12.6 [INFO] [stderr] Downloaded tungstenite v0.29.0 [INFO] [stderr] Downloaded spinning_top v0.3.0 [INFO] [stderr] Downloaded raw-cpuid v11.6.0 [INFO] [stderr] Downloaded criterion v0.8.2 [INFO] [stderr] Downloaded governor v0.10.4 [INFO] [stderr] Downloaded lightstreamer-rs v0.3.1 [INFO] [stderr] Downloaded json-patch v4.1.0 [INFO] [stderr] Downloaded csv-core v0.1.13 [INFO] [stderr] Downloaded pretty-simple-display v0.1.0 [INFO] [stderr] Downloaded csv v1.4.0 [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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 40e772db43b4254534335cb50d0da2b42ea35f575d0ce15e996e64766f749bf1 [INFO] running `Command { std: "docker" "start" "-a" "40e772db43b4254534335cb50d0da2b42ea35f575d0ce15e996e64766f749bf1", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "40e772db43b4254534335cb50d0da2b42ea35f575d0ce15e996e64766f749bf1", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "40e772db43b4254534335cb50d0da2b42ea35f575d0ce15e996e64766f749bf1", kill_on_drop: false }` [INFO] [stdout] 40e772db43b4254534335cb50d0da2b42ea35f575d0ce15e996e64766f749bf1 [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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] da3906d83e3388046a176d914e46a095c8f3b4560ed6ea2b73d30112f6b85caf [INFO] running `Command { std: "docker" "start" "-a" "da3906d83e3388046a176d914e46a095c8f3b4560ed6ea2b73d30112f6b85caf", kill_on_drop: false }` [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling memchr v2.8.0 [INFO] [stderr] Compiling bytes v1.11.1 [INFO] [stderr] Compiling futures-io v0.3.32 [INFO] [stderr] Compiling openssl-sys v0.9.112 [INFO] [stderr] Compiling zerocopy v0.8.47 [INFO] [stderr] Compiling zerocopy-derive v0.8.47 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling slab v0.4.12 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling foreign-types-shared v0.1.1 [INFO] [stderr] Compiling openssl v0.10.76 [INFO] [stderr] Compiling foreign-types v0.3.2 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling tokio v1.50.0 [INFO] [stderr] Compiling native-tls v0.2.18 [INFO] [stderr] Compiling futures-util v0.3.32 [INFO] [stderr] Compiling http v1.4.0 [INFO] [stderr] Compiling getrandom v0.2.17 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling thiserror v2.0.18 [INFO] [stderr] Compiling crossbeam-utils v0.8.21 [INFO] [stderr] Compiling tracing v0.1.44 [INFO] [stderr] Compiling foldhash v0.1.5 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling hashbrown v0.15.5 [INFO] [stderr] Compiling indexmap v2.13.0 [INFO] [stderr] Compiling tinyvec_macros v0.1.1 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling crc-catalog v2.4.0 [INFO] [stderr] Compiling icu_normalizer v2.1.1 [INFO] [stderr] Compiling crc v3.4.0 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling tinyvec v1.11.0 [INFO] [stderr] Compiling either v1.15.0 [INFO] [stderr] Compiling hashlink v0.10.0 [INFO] [stderr] Compiling log v0.4.29 [INFO] [stderr] Compiling futures-sink v0.3.32 [INFO] [stderr] Compiling unicode-normalization v0.1.25 [INFO] [stderr] Compiling idna v1.1.0 [INFO] [stderr] Compiling rand_core v0.9.5 [INFO] [stderr] Compiling parking_lot v0.12.5 [INFO] [stderr] Compiling concurrent-queue v2.5.0 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling hmac v0.12.1 [INFO] [stderr] Compiling form_urlencoded v1.2.2 [INFO] [stderr] Compiling tracing-core v0.1.36 [INFO] [stderr] Compiling unicode-bidi v0.3.18 [INFO] [stderr] Compiling unicode-properties v0.1.4 [INFO] [stderr] Compiling hashbrown v0.16.1 [INFO] [stderr] Compiling ppv-lite86 v0.2.21 [INFO] [stderr] Compiling rustls v0.23.37 [INFO] [stderr] Compiling stringprep v0.1.5 [INFO] [stderr] Compiling rand_chacha v0.9.0 [INFO] [stderr] Compiling url v2.5.8 [INFO] [stderr] Compiling hkdf v0.12.4 [INFO] [stderr] Compiling event-listener v5.4.1 [INFO] [stderr] Compiling tokio-util v0.7.18 [INFO] [stderr] Compiling futures-intrusive v0.5.0 [INFO] [stderr] Compiling chrono v0.4.44 [INFO] [stderr] Compiling crossbeam-queue v0.3.12 [INFO] [stderr] Compiling sha2 v0.10.9 [INFO] [stderr] Compiling md-5 v0.10.6 [INFO] [stderr] Compiling dotenvy v0.15.7 [INFO] [stderr] Compiling home v0.5.12 [INFO] [stderr] Compiling byteorder v1.5.0 [INFO] [stderr] Compiling base64 v0.22.1 [INFO] [stderr] Compiling whoami v1.6.1 [INFO] [stderr] Compiling h2 v0.4.13 [INFO] [stderr] Compiling tokio-stream v0.1.18 [INFO] [stderr] Compiling rand v0.9.2 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling futures-channel v0.3.32 [INFO] [stderr] Compiling sqlx-core v0.8.6 [INFO] [stderr] Compiling atoi v2.0.0 [INFO] [stderr] Compiling num-conv v0.2.0 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling time-macros v0.2.27 [INFO] [stderr] Compiling deranged v0.5.8 [INFO] [stderr] Compiling half v2.7.1 [INFO] [stderr] Compiling sha1 v0.10.6 [INFO] [stderr] Compiling aho-corasick v1.1.4 [INFO] [stderr] Compiling alloca v0.4.0 [INFO] [stderr] Compiling cookie v0.18.1 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling dirs-sys-next v0.1.2 [INFO] [stderr] Compiling regex-syntax v0.8.10 [INFO] [stderr] Compiling portable-atomic v1.13.1 [INFO] [stderr] Compiling data-encoding v2.10.0 [INFO] [stderr] Compiling sqlx-postgres v0.8.6 [INFO] [stderr] Compiling hyper v1.8.1 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling tokio-rustls v0.26.4 [INFO] [stderr] Compiling hyper-util v0.1.20 [INFO] [stderr] Compiling regex-automata v0.4.14 [INFO] [stderr] Compiling tungstenite v0.29.0 [INFO] [stderr] Compiling clap_builder v4.6.0 [INFO] [stderr] Compiling ciborium-ll v0.2.2 [INFO] [stderr] Compiling tower v0.5.3 [INFO] [stderr] Compiling dirs-next v2.0.0 [INFO] [stderr] Compiling time v0.3.47 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling jsonptr v0.7.1 [INFO] [stderr] Compiling itertools v0.13.0 [INFO] [stderr] Compiling sqlx-macros-core v0.8.6 [INFO] [stderr] Compiling tracing-log v0.2.0 [INFO] [stderr] Compiling csv-core v0.1.13 [INFO] [stderr] Compiling raw-cpuid v11.6.0 [INFO] [stderr] Compiling iri-string v0.7.10 [INFO] [stderr] Compiling hashbrown v0.14.5 [INFO] [stderr] Compiling tracing-subscriber v0.3.23 [INFO] [stderr] Compiling dashmap v6.1.0 [INFO] [stderr] Compiling criterion-plot v0.8.2 [INFO] [stderr] Compiling csv v1.4.0 [INFO] [stderr] Compiling clap v4.6.0 [INFO] [stderr] Compiling json-patch v4.1.0 [INFO] [stderr] Compiling sqlx-macros v0.8.6 [INFO] [stderr] Compiling tower-http v0.6.8 [INFO] [stderr] Compiling quanta v0.12.6 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Compiling rustls-platform-verifier v0.6.2 [INFO] [stderr] Compiling tokio-tungstenite v0.29.0 [INFO] [stderr] Compiling rand v0.10.0 [INFO] [stderr] Compiling rayon v1.11.0 [INFO] [stderr] Compiling term v0.7.0 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling ciborium v0.2.2 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling tinytemplate v1.2.1 [INFO] [stderr] Compiling futures-executor v0.3.32 [INFO] [stderr] Compiling spinning_top v0.3.0 [INFO] [stderr] Compiling page_size v0.6.0 [INFO] [stderr] Compiling is-terminal v0.4.17 [INFO] [stderr] Compiling encoding_rs v0.8.35 [INFO] [stderr] Compiling nonzero_ext v0.3.0 [INFO] [stderr] Compiling futures-timer v3.0.3 [INFO] [stderr] Compiling web-time v1.1.0 [INFO] [stderr] Compiling unicode-width v0.1.14 [INFO] [stderr] Compiling encode_unicode v1.0.0 [INFO] [stderr] Compiling governor v0.10.4 [INFO] [stderr] Compiling futures v0.3.32 [INFO] [stderr] Compiling lightstreamer-rs v0.3.1 [INFO] [stderr] Compiling nanoid v0.4.0 [INFO] [stderr] Compiling pretty-simple-display v0.1.0 [INFO] [stderr] Compiling prettytable-rs v0.10.0 [INFO] [stderr] Compiling dotenv v0.15.0 [INFO] [stderr] Compiling criterion v0.8.2 [INFO] [stderr] Compiling reqwest v0.13.2 [INFO] [stderr] Compiling sqlx v0.8.6 [INFO] [stderr] Compiling ig-client v0.11.2 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 41s [INFO] running `Command { std: "docker" "inspect" "da3906d83e3388046a176d914e46a095c8f3b4560ed6ea2b73d30112f6b85caf", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "da3906d83e3388046a176d914e46a095c8f3b4560ed6ea2b73d30112f6b85caf", kill_on_drop: false }` [INFO] [stdout] da3906d83e3388046a176d914e46a095c8f3b4560ed6ea2b73d30112f6b85caf [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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 909c9bc0f7ba7b57d10ef343e6d16fd69108a0019dbc24608f125fe18b0823e4 [INFO] running `Command { std: "docker" "start" "-a" "909c9bc0f7ba7b57d10ef343e6d16fd69108a0019dbc24608f125fe18b0823e4", kill_on_drop: false }` [INFO] [stderr] Compiling ig-client v0.11.2 (/opt/rustwide/workdir) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 23.42s [INFO] running `Command { std: "docker" "inspect" "909c9bc0f7ba7b57d10ef343e6d16fd69108a0019dbc24608f125fe18b0823e4", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "909c9bc0f7ba7b57d10ef343e6d16fd69108a0019dbc24608f125fe18b0823e4", kill_on_drop: false }` [INFO] [stdout] 909c9bc0f7ba7b57d10ef343e6d16fd69108a0019dbc24608f125fe18b0823e4 [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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+562dee4820c458d823175268e41601d4c060588a" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 4b97158892db90d5eb55d75223b934ba18b220e005fb6a02d93c055ec4b55da5 [INFO] running `Command { std: "docker" "start" "-a" "4b97158892db90d5eb55d75223b934ba18b220e005fb6a02d93c055ec4b55da5", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.61s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/ig_client-8f66a04b8b2a4f42) [INFO] [stdout] [INFO] [stdout] running 134 tests [INFO] [stdout] test model::responses::tests::test_deserialize_working_orders_from_file ... ignored, requires Data/working_orders.json file [INFO] [stdout] test application::auth::test_v2_response_deserialization ... ok [INFO] [stdout] test model::streaming::tests::test_get_streaming_account_fields_multiple ... ok [INFO] [stdout] test model::streaming::tests::test_get_streaming_chart_fields_multiple ... ok [INFO] [stdout] test model::streaming::tests::test_get_streaming_account_fields_empty ... ok [INFO] [stdout] test application::auth::test_v2_response_deserialization_prod ... ok [INFO] [stdout] test model::streaming::tests::test_get_streaming_market_fields_empty ... ok [INFO] [stdout] test model::streaming::tests::test_get_streaming_market_fields_single ... ok [INFO] [stdout] test application::rate_limiter::tests::test_rate_limiter_allows_requests ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_account_field_default ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_chart_field_debug ... ok [INFO] [stdout] test model::streaming::tests::test_get_streaming_market_fields_multiple ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_chart_field_default ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_account_field_debug ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_chart_field_display ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_market_field_clone ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_chart_field_serialization ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_market_field_default ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_market_field_debug ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_market_field_display ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_market_field_equality ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_market_field_hash ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_market_field_serialization ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_price_field_default ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_price_field_display ... ok [INFO] [stdout] test presentation::account::tests::pnl_buy_is_zero_when_bid_missing ... ok [INFO] [stdout] test presentation::account::tests::pnl_buy_uses_bid_and_computes_difference ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_price_field_debug ... ok [INFO] [stdout] test presentation::account::tests::pnl_sell_is_zero_when_offer_missing ... ok [INFO] [stdout] test presentation::account::tests::pnl_field_overrides_calculation_when_present ... ok [INFO] [stdout] test presentation::account::tests::pnl_sell_uses_offer_and_matches_sample_data ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_data_get_scale ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_fields_creation ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_fields_default ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_scale_debug ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_scale_default ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_scale_display ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_account_field_display ... ok [INFO] [stdout] test model::streaming::tests::test_streaming_account_field_serialization ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_data_default ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_scale_hash ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_scale_serialization ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_data_is_tick ... ok [INFO] [stdout] test presentation::market::tests::test_category_market_status_default ... ok [INFO] [stdout] test presentation::market::tests::test_create_market_fields_all_market_states ... ok [INFO] [stdout] test presentation::market::tests::test_create_market_fields_invalid_market_delay ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_scale_equality ... ok [INFO] [stdout] test presentation::market::tests::test_category_default ... ok [INFO] [stdout] test presentation::market::tests::test_category_instrument_default ... ok [INFO] [stdout] test presentation::market::tests::test_create_market_fields_invalid_market_state ... ok [INFO] [stdout] test presentation::market::tests::test_create_market_fields_with_empty_map ... ok [INFO] [stdout] test presentation::market::tests::test_create_market_fields_with_valid_data ... ok [INFO] [stdout] test presentation::market::tests::test_expiry_details_creation ... ok [INFO] [stdout] test presentation::market::tests::test_currency_creation ... ok [INFO] [stdout] test presentation::market::tests::test_market_data_is_call_returns_true_for_call_option ... ok [INFO] [stdout] test presentation::market::tests::test_market_data_is_put_returns_true_for_put_option ... ok [INFO] [stdout] test model::streaming::tests::test_get_streaming_chart_fields_empty ... ok [INFO] [stdout] test presentation::market::tests::test_market_data_neither_call_nor_put ... ok [INFO] [stdout] test presentation::market::tests::test_market_delay_values ... ok [INFO] [stdout] test presentation::market::tests::test_market_navigation_node_creation ... ok [INFO] [stdout] test presentation::market::tests::test_market_fields_default ... ok [INFO] [stdout] test presentation::market::tests::test_market_state_default ... ok [INFO] [stdout] test presentation::market::tests::test_market_state_serialization ... ok [INFO] [stdout] test presentation::market::tests::test_market_node_creation ... ok [INFO] [stdout] test presentation::trade::tests::test_open_position_update_creation ... ok [INFO] [stdout] test presentation::trade::tests::test_open_position_update_default ... ok [INFO] [stdout] test presentation::trade::tests::test_open_position_update_serialization ... ok [INFO] [stdout] test presentation::trade::tests::test_trade_data_creation ... ok [INFO] [stdout] test presentation::trade::tests::test_trade_data_default ... ok [INFO] [stdout] test presentation::market::tests::test_price_point_creation ... ok [INFO] [stdout] test presentation::chart::tests::test_chart_data_is_candle ... ok [INFO] [stdout] test presentation::market::tests::test_presentation_market_data_default ... ok [INFO] [stdout] test presentation::market::tests::test_price_allowance_creation ... ok [INFO] [stdout] test presentation::market::tests::test_step_distance_creation ... ok [INFO] [stdout] test presentation::trade::tests::test_working_order_update_default ... ok [INFO] [stdout] test presentation::market::tests::test_step_unit_serialization ... ok [INFO] [stdout] test presentation::trade::tests::test_working_order_update_serialization ... ok [INFO] [stdout] test presentation::trade::tests::test_working_order_update_creation ... ok [INFO] [stdout] test storage::historical_prices::tests::test_parse_snapshot_time_dash_format ... ok [INFO] [stdout] test storage::historical_prices::tests::test_parse_snapshot_time_different_years ... ok [INFO] [stdout] test storage::historical_prices::tests::test_parse_snapshot_time_all_months ... ok [INFO] [stdout] test storage::historical_prices::tests::test_parse_snapshot_time_invalid_format ... ok [INFO] [stdout] test storage::historical_prices::tests::test_parse_snapshot_time_end_of_day ... ok [INFO] [stdout] test storage::historical_prices::tests::test_parse_snapshot_time_empty_string ... ok [INFO] [stdout] test storage::historical_prices::tests::test_parse_snapshot_time_midnight ... ok [INFO] [stdout] test storage::historical_prices::tests::test_parse_snapshot_time_partial_date ... ok [INFO] [stdout] test storage::historical_prices::tests::test_parse_snapshot_time_slash_format ... ok [INFO] [stdout] test storage::historical_prices::tests::test_storage_stats_creation ... ok [INFO] [stdout] test storage::historical_prices::tests::test_parse_snapshot_time_without_seconds_dash ... ok [INFO] [stdout] test storage::market_database::tests::test_convert_market_data_to_instrument ... ignored [INFO] [stdout] test presentation::trade::tests::test_trade_fields_default ... ok [INFO] [stdout] test storage::historical_prices::tests::test_parse_snapshot_time_without_seconds_slash ... ok [INFO] [stdout] test storage::historical_prices::tests::test_table_stats_creation ... ok [INFO] [stdout] test presentation::trade::tests::test_trade_fields_with_confirms ... ok [INFO] [stdout] test storage::historical_prices::tests::test_storage_stats_default ... ok [INFO] [stdout] test storage::market_persistence::tests::test_market_hierarchy_node_creation ... ok [INFO] [stdout] test storage::market_persistence::tests::test_market_instrument_creation ... ok [INFO] [stdout] test storage::utils::tests::test_database_config_creation ... ok [INFO] [stdout] test storage::utils::tests::test_deserialize_from_json_malformed ... ok [INFO] [stdout] test storage::utils::tests::test_deserialize_from_json_invalid ... ok [INFO] [stdout] test storage::utils::tests::test_deserialize_from_json_valid ... ok [INFO] [stdout] test storage::utils::tests::test_deserialize_from_json_with_null ... ok [INFO] [stdout] test storage::utils::tests::test_deserialize_vec ... ok [INFO] [stdout] test storage::utils::tests::test_serialize_empty_string ... ok [INFO] [stdout] test storage::market_persistence::tests::test_build_path ... ok [INFO] [stdout] test storage::utils::tests::test_serialize_to_json_simple_struct ... ok [INFO] [stdout] test storage::utils::tests::test_serialize_to_json_with_none ... ok [INFO] [stdout] test storage::utils::tests::test_serialize_special_characters ... ok [INFO] [stdout] test storage::utils::tests::test_serialize_vec ... ok [INFO] [stdout] test utils::logger::tests_setup_logger::test_logger_called_once ... ok [INFO] [stdout] test storage::utils::tests::test_serialize_deserialize_roundtrip ... ok [INFO] [stdout] test utils::logger::tests_setup_logger::test_logger_initialization_debug ... ok [INFO] [stdout] test utils::logger::tests_setup_logger::test_logger_initialization_info ... ok [INFO] [stdout] test utils::logger::tests_setup_logger_bis::test_debug_log_level ... ok [INFO] [stdout] test utils::logger::tests_setup_logger_bis::test_invalid_log_level ... ok [INFO] [stdout] test utils::logger::tests_setup_logger::test_logger_initialization_default ... ok [INFO] [stdout] test utils::logger::tests_setup_logger_bis::test_error_log_level ... ok [INFO] [stdout] test utils::logger::tests_setup_logger_bis::test_default_log_level ... ok [INFO] [stdout] test utils::logger::tests_setup_logger_bis::test_trace_log_level ... ok [INFO] [stdout] test utils::logger::tests_setup_logger_bis::test_warn_log_level ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_end_of_month_prefix ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_daily_prefix ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_special_format ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_weekly_prefix ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_weekly_with_day ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_incomplete_parenthesis ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_quarterly_prefix ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_with_parenthesis ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_no_option ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_with_accents ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_end_of_month_suffix ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_decimal_strike ... ok [INFO] [stdout] test utils::parsing::tests::test_parse_instrument_name_standard_option ... ok [INFO] [stderr] Running tests/integration/mod.rs (/opt/rustwide/target/debug/deps/integration_tests-0503634c77d1a82c) [INFO] [stdout] test application::rate_limiter::tests::test_rate_limiter_wait ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 132 passed; 0 failed; 2 ignored; 0 measured; 0 filtered out; finished in 1.01s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 10 tests [INFO] [stdout] test account_tests::test_get_account_activity ... ignored [INFO] [stderr] Running tests/unit/mod.rs (/opt/rustwide/target/debug/deps/unit_tests-a8cd657c860e674c) [INFO] [stdout] test account_tests::test_get_accounts ... ignored [INFO] [stdout] test account_tests::test_get_transaction_history ... ignored [INFO] [stdout] test auth_tests::test_login ... ignored [INFO] [stdout] test market_tests::test_get_historical_prices ... ignored [INFO] [stdout] test market_tests::test_get_market_details ... ignored [INFO] [stdout] test market_tests::test_get_market_navigation ... ignored [INFO] [stdout] test market_tests::test_get_market_navigation_node ... ignored [INFO] [stdout] test market_tests::test_get_multiple_market_details ... ignored [INFO] [stdout] test market_tests::test_search_markets ... ignored [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 10 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 251 tests [INFO] [stdout] test application::test_auth::session_expiry_checks_and_alias ... ok [INFO] [stdout] test application::test_auth::session_is_oauth_and_ws_info_propagates ... ok [INFO] [stdout] test application::test_listener::test_listener_error_handling ... ok [INFO] [stdout] test application::models::test_auth::test_placeholder ... ok [INFO] [stdout] test application::test_auth::websocket_info_password_formats_and_empty_when_missing ... ok [INFO] [stdout] test application::test_listener::test_listener_on_item_update ... ok [INFO] [stdout] test application::test_listener::test_listener_new ... ok [INFO] [stdout] test application::test_listener::test_listener_on_subscription ... ok [INFO] [stdout] test error_tests::test_app_error_from_auth_error ... ok [INFO] [stdout] test application::test_listener::test_listener_multiple_updates ... ok [INFO] [stdout] test error_tests::test_app_error_from_box_dyn_error ... ok [INFO] [stdout] test error_tests::test_app_error_from_io_error ... ok [INFO] [stdout] test error_tests::test_app_error_from_serde_json_error ... ok [INFO] [stdout] test error_tests::test_app_error_from_sqlx_error ... ok [INFO] [stdout] test error_tests::test_app_error_invalid_input ... ok [INFO] [stdout] test error_tests::test_app_error_not_found ... ok [INFO] [stdout] test error_tests::test_app_error_rate_limit_exceeded ... ok [INFO] [stdout] test error_tests::test_app_error_serialization_error ... ok [INFO] [stdout] test error_tests::test_app_error_deserialization ... ok [INFO] [stdout] test error_tests::test_app_error_unauthorized ... ok [INFO] [stdout] test error_tests::test_app_error_websocket_error ... ok [INFO] [stdout] test error_tests::test_auth_error_display ... ok [INFO] [stdout] test error_tests::test_app_error_unexpected ... ok [INFO] [stdout] test error_tests::test_auth_error_from_box_dyn_error ... ok [INFO] [stdout] test error_tests::test_auth_error_from_box_dyn_error_send_sync ... ok [INFO] [stdout] test error_tests::test_auth_error_unexpected ... ok [INFO] [stdout] test error_tests::test_fetch_error_display ... ok [INFO] [stdout] test model::test_auth::test_oauth_token_clone ... ok [INFO] [stdout] test model::test_auth::test_oauth_token_expire_at ... ok [INFO] [stdout] test model::test_auth::test_oauth_token_is_expired_expired ... ok [INFO] [stdout] test model::test_auth::test_oauth_token_is_expired_not_expired ... ok [INFO] [stdout] test model::test_auth::test_oauth_token_serialization ... ok [INFO] [stdout] test model::test_auth::test_session_response_clone ... ok [INFO] [stdout] test model::test_auth::test_session_response_get_session_v2 ... ok [INFO] [stdout] test model::test_auth::test_session_response_get_session_v3 ... ok [INFO] [stdout] test model::test_auth::test_session_response_is_expired_v3 ... ok [INFO] [stdout] test model::test_auth::test_session_response_serialization ... ok [INFO] [stdout] test model::test_auth::test_session_response_v2_is_v2 ... ok [INFO] [stdout] test model::test_auth::test_session_response_v3_is_v3 ... ok [INFO] [stdout] test error_tests::test_auth_error_rate_limit_exceeded ... ok [INFO] [stdout] test model::test_config::test_config_api_version_some ... ok [INFO] [stdout] test model::test_config::test_config_api_version_none ... ok [INFO] [stdout] test model::test_config::test_config_clone ... ok [INFO] [stdout] test model::test_config::test_config_default ... ok [INFO] [stdout] test model::test_config::test_config_display ... ok [INFO] [stdout] test model::test_config::test_config_new ... ok [INFO] [stdout] test model::test_config::test_config_serialization ... ok [INFO] [stdout] test model::test_config::test_credentials_clone ... ok [INFO] [stdout] test model::test_config::test_credentials_display ... ok [INFO] [stdout] test model::test_config::test_credentials_serialization ... ok [INFO] [stdout] test model::test_config::test_credentials_without_tokens ... ok [INFO] [stdout] test model::test_config::test_rate_limiter_config_clone ... ok [INFO] [stdout] test model::test_config::test_rate_limiter_config_serialization ... ok [INFO] [stdout] test model::test_config::test_rest_api_config_clone ... ok [INFO] [stdout] test model::test_config::test_rest_api_config_serialization ... ok [INFO] [stdout] test model::test_config::test_websocket_config_clone ... ok [INFO] [stdout] test model::test_config::test_websocket_config_serialization ... ok [INFO] [stdout] test model::test_requests::close_position_requests ... ok [INFO] [stdout] test model::test_config::test_credentials_with_tokens ... ok [INFO] [stdout] test model::test_requests::create_option_helpers_sell_and_buy_default_levels ... ok [INFO] [stdout] test model::test_requests::create_option_helpers_with_force_open_flag ... ok [INFO] [stdout] test model::test_requests::create_order_limit_and_chainers ... ok [INFO] [stdout] test model::test_requests::create_order_market_defaults_and_rounding ... ok [INFO] [stdout] test model::test_requests::create_working_order_builders ... ok [INFO] [stdout] test model::test_requests::recent_prices_request_builders ... ok [INFO] [stdout] test model::test_responses::dbentry_from_marketnode_and_marketdata ... ok [INFO] [stdout] test model::test_responses::historical_prices_response_helpers_and_display ... ok [INFO] [stdout] test model::test_responses::market_navigation_response_deserializes_null_as_empty ... ok [INFO] [stdout] test model::test_responses::market_search_response_helpers_and_display ... ok [INFO] [stdout] test model::test_responses::multiple_market_details_response_helpers_and_display ... ok [INFO] [stdout] test model::test_responses::order_confirmation_response_deserialize_status_and_fields ... ok [INFO] [stdout] test model::test_responses::positions_response_compact_by_epic_merges_positions ... ok [INFO] [stdout] test model::test_responses::simple_deal_reference_responses_serde_field_names ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::streaming_price_field_tests::test_streaming_price_field_clone_and_equality ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::streaming_price_field_tests::test_streaming_price_field_debug_format ... ok [INFO] [stdout] test application::test_listener::test_listener_with_different_data ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::streaming_price_field_tests::test_streaming_price_field_default ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::streaming_price_field_tests::test_streaming_price_field_in_hashset ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::streaming_price_field_tests::test_streaming_price_field_serialization_format ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::test_streaming_account_data_field_clone_and_equality ... ok [INFO] [stdout] test model::test_auth::test_security_headers_clone ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::test_streaming_account_data_field_debug_display_consistency ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::streaming_price_field_tests::test_streaming_price_field_debug_display_consistency ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::test_streaming_account_data_field_debug_format ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::test_streaming_account_data_field_default ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::test_streaming_account_data_field_in_hashset ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::test_streaming_account_data_field_serialization_format ... ok [INFO] [stdout] test model::test_streaming::test_streaming_chart_field_clone_and_equality ... ok [INFO] [stdout] test model::test_streaming::test_streaming_chart_field_debug_display_consistency ... ok [INFO] [stdout] test model::test_streaming::test_streaming_chart_field_debug_format ... ok [INFO] [stdout] test model::test_streaming::test_streaming_chart_field_default ... ok [INFO] [stdout] test model::test_streaming::test_streaming_chart_field_display_format ... ok [INFO] [stdout] test model::test_streaming::test_streaming_chart_field_in_hashset ... ok [INFO] [stdout] test application::test_listener::test_listener_thread_safety ... ok [INFO] [stdout] test model::test_streaming::test_streaming_chart_field_serialization_format ... ok [INFO] [stdout] test model::test_streaming::test_streaming_market_field_clone_and_equality ... ok [INFO] [stdout] test model::test_streaming::test_streaming_market_field_debug_display_consistency ... ok [INFO] [stdout] test model::test_streaming::test_streaming_market_field_default ... ok [INFO] [stdout] test model::test_streaming::test_streaming_market_field_debug_format ... ok [INFO] [stdout] test model::test_streaming::test_streaming_market_field_display_format ... ok [INFO] [stdout] test model::test_streaming::test_streaming_market_field_serialization_format ... ok [INFO] [stdout] test presentation::serialization_tests::tests::test_option_string_empty_as_none_deserialize ... ok [INFO] [stdout] test model::test_streaming::test_streaming_market_field_in_hashset ... ok [INFO] [stdout] test presentation::serialization_tests::tests::test_string_as_bool_opt_deserialize ... ok [INFO] [stdout] test presentation::serialization_tests::tests::test_string_as_bool_opt_deserialize_errors ... ok [INFO] [stdout] test presentation::serialization_tests::tests::test_string_as_bool_opt_serialize ... ok [INFO] [stdout] test presentation::serialization_tests::tests::test_string_as_float_opt_deserialize ... ok [INFO] [stdout] test presentation::serialization_tests::tests::test_string_as_float_opt_deserialize_errors ... ok [INFO] [stdout] test presentation::serialization_tests::tests::test_string_as_float_opt_serialize ... ok [INFO] [stdout] test presentation::test_account::test_account_data_clone ... ok [INFO] [stdout] test presentation::test_account::test_account_data_default ... ok [INFO] [stdout] test presentation::test_account::test_account_data_from_item_update_empty ... ok [INFO] [stdout] test presentation::test_account::test_account_data_from_item_update_with_fields ... ok [INFO] [stdout] test presentation::test_account::test_account_fields_default ... ok [INFO] [stdout] test presentation::test_chart::test_chart_data_clone ... ok [INFO] [stdout] test presentation::test_chart::test_chart_data_default ... ok [INFO] [stdout] test presentation::test_chart::test_chart_data_from_item_update_empty ... ok [INFO] [stdout] test presentation::test_chart::test_chart_data_from_item_update_with_fields ... ok [INFO] [stdout] test presentation::test_chart::test_chart_data_serialization ... ok [INFO] [stdout] test presentation::test_chart::test_chart_fields_default ... ok [INFO] [stdout] test presentation::test_market::test_market_data_clone ... ok [INFO] [stdout] test presentation::test_market::test_market_data_display ... ok [INFO] [stdout] test presentation::test_market::test_market_data_serialization ... ok [INFO] [stdout] test presentation::test_price::test_dealing_flag_copy ... ok [INFO] [stdout] test presentation::test_price::test_dealing_flag_default ... ok [INFO] [stdout] test presentation::test_price::test_dealing_flag_serialization ... ok [INFO] [stdout] test presentation::test_price::test_price_data_clone ... ok [INFO] [stdout] test presentation::test_price::test_price_data_default ... ok [INFO] [stdout] test presentation::test_price::test_price_data_display ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_item_update_closingonly_backward_compat ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_item_update_closingsonly_flag ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_item_update_dlg_flag_with_trailing_spaces ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_item_update_empty ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_item_update_empty_dlg_flag_is_none ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_item_update_empty_strings ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::test_streaming_account_data_field_display_format ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_item_update_with_all_fields ... ok [INFO] [stdout] test model::test_streaming::streaming_account_data_field_tests::streaming_price_field_tests::test_streaming_price_field_display_format ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_item_update_with_changed_fields ... ok [INFO] [stdout] test presentation::serialization_tests::tests::test_option_string_empty_as_none_serialize ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_item_update_with_net_chg_fields ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_trait_does_not_panic_on_error ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_item_update_invalid_float ... ok [INFO] [stdout] test presentation::test_price::test_price_data_from_item_update_with_bid_offer ... ok [INFO] [stdout] test presentation::test_serialization::test_string_as_bool_opt_false ... ok [INFO] [stdout] test presentation::test_serialization::test_string_as_bool_opt_null ... ok [INFO] [stdout] test presentation::test_serialization::test_string_as_float_opt_negative ... ok [INFO] [stdout] test presentation::test_serialization::test_string_as_bool_opt_true ... ok [INFO] [stdout] test presentation::test_serialization::test_string_as_float_opt_null ... ok [INFO] [stdout] test presentation::test_serialization::test_string_as_float_opt_valid ... ok [INFO] [stdout] test presentation::test_trade::test_trade_data_clone ... ok [INFO] [stdout] test presentation::test_price::test_price_fields_default ... ok [INFO] [stdout] test presentation::test_trade::test_trade_data_display ... ok [INFO] [stdout] test presentation::test_serialization::test_string_as_float_opt_scientific ... ok [INFO] [stdout] test presentation::test_serialization::test_string_as_float_opt_zero ... ok [INFO] [stdout] test presentation::test_trade::test_trade_data_from_item_update_empty ... ok [INFO] [stdout] test presentation::test_trade::test_trade_data_from_item_update_with_confirms ... ok [INFO] [stdout] test presentation::test_transaction::test_store_transaction_clone ... ok [INFO] [stdout] test presentation::test_trade::test_trade_fields_default ... ok [INFO] [stdout] test presentation::test_transaction::test_store_transaction_display ... ok [INFO] [stdout] test presentation::test_transaction::test_store_transaction_default ... ok [INFO] [stdout] test presentation::test_transaction::test_store_transaction_partial_eq ... ok [INFO] [stdout] test presentation::test_price::test_dealing_flag_all_variants ... ok [INFO] [stdout] test presentation::test_transaction::test_store_transaction_pnl_parsing_with_comma ... ok [INFO] [stdout] test presentation::test_transaction::test_store_transaction_serialization ... ok [INFO] [stdout] test presentation::test_transaction::test_store_transaction_is_fee_detection ... ok [INFO] [stdout] test presentation::test_transaction::test_store_transaction_from_account_transaction ... ok [INFO] [stdout] test presentation::test_transaction::test_store_transaction_from_account_transaction_ref ... ok [INFO] [stdout] test storage::storage_utils_tests::test_deserialize_from_json ... ok [INFO] [stdout] test storage::storage_utils_tests::test_deserialize_from_json_invalid ... ok [INFO] [stdout] test presentation::test_transaction::test_transaction_list_from_vec ... ok [INFO] [stdout] test storage::storage_utils_tests::test_serialize_complex_types ... ok [INFO] [stdout] test storage::storage_utils_tests::test_serialize_deserialize_roundtrip ... ok [INFO] [stdout] test storage::storage_utils_tests::test_serialize_to_json ... ok [INFO] [stdout] test storage::test_historical_prices::parse_snapshot_time_accepts_multiple_formats ... ok [INFO] [stdout] test storage::test_historical_prices::parse_snapshot_time_rejects_invalid_inputs ... ok [INFO] [stdout] test storage::test_historical_prices::storage_stats_default_is_zero ... ok [INFO] [stdout] test presentation::test_transaction::test_transaction_list_as_ref ... ok [INFO] [stdout] test storage::test_utils::test_deserialize_from_json ... ok [INFO] [stdout] test storage::test_utils::test_deserialize_from_json_invalid ... ok [INFO] [stdout] test storage::test_utils::test_deserialize_from_json_with_whitespace ... ok [INFO] [stdout] test storage::test_market_database::convert_market_data_to_instrument_maps_fields ... ok [INFO] [stdout] test storage::test_market_database::convert_update_time_handles_valid_invalid_and_none ... ok [INFO] [stdout] test storage::test_market_database::find_symbol_for_market_picks_first_matching_key_or_unknown ... ok [INFO] [stdout] test storage::test_utils::test_deserialize_option_some ... ok [INFO] [stdout] test storage::test_utils::test_deserialize_vec ... ok [INFO] [stdout] test storage::test_utils::test_serialize_nested_struct ... ok [INFO] [stdout] test storage::test_utils::test_serialize_option_none ... ok [INFO] [stdout] test storage::test_utils::test_serialize_option_some ... ok [INFO] [stdout] test storage::test_utils::test_serialize_to_json ... ok [INFO] [stdout] test storage::test_utils::test_serialize_to_json_empty_string ... ok [INFO] [stdout] test storage::test_utils::test_serialize_to_json_special_chars ... ok [INFO] [stdout] test storage::test_utils::test_serialize_vec ... ok [INFO] [stdout] test test_error::test_app_error_display_deserialization ... ok [INFO] [stdout] test test_error::test_app_error_display_invalid_input ... ok [INFO] [stdout] test test_error::test_app_error_display_not_found ... ok [INFO] [stdout] test test_error::test_app_error_display_rate_limit ... ok [INFO] [stdout] test test_error::test_app_error_display_serialization ... ok [INFO] [stdout] test test_error::test_app_error_display_unauthorized ... ok [INFO] [stdout] test test_error::test_app_error_display_unexpected ... ok [INFO] [stdout] test test_error::test_app_error_display_websocket ... ok [INFO] [stdout] test storage::test_utils::test_deserialize_option_none ... ok [INFO] [stdout] test test_error::test_app_error_from_io ... ok [INFO] [stdout] test storage::test_market_database::is_valid_epic_format_checks_dot_count ... ok [INFO] [stdout] test test_error::test_app_error_from_serde ... ok [INFO] [stdout] test utils::parsing_tests::tests::test_normalize_text ... ok [INFO] [stdout] test utils::parsing_tests::tests::test_parsed_option_info_display ... ok [INFO] [stdout] test utils::test_config::test_get_env_or_default_with_bool ... ok [INFO] [stdout] test utils::test_config::test_get_env_or_default_with_integer ... ok [INFO] [stdout] test utils::parsing_tests::tests::test_parse_instrument_name_wrapper ... ok [INFO] [stdout] test utils::test_config::test_get_env_or_default_with_invalid_parse ... ok [INFO] [stdout] test utils::test_config::test_get_env_or_default_with_missing_var ... ok [INFO] [stdout] test utils::test_config::test_get_env_or_none_with_float ... ok [INFO] [stdout] test utils::test_config::test_get_env_or_none_with_invalid_parse ... ok [INFO] [stdout] test utils::test_config::test_get_env_or_none_with_missing_var ... ok [INFO] [stdout] test utils::test_config::test_get_env_or_none_with_string ... ok [INFO] [stdout] test utils::test_finance::test_calculate_percentage_return ... ok [INFO] [stdout] test utils::test_finance::test_calculate_percentage_return_zero_initial_value ... ok [INFO] [stdout] test utils::test_finance::test_calculate_pnl_buy_position_profit ... ok [INFO] [stdout] test utils::test_finance::test_calculate_pnl_missing_prices ... ok [INFO] [stdout] test utils::test_finance::test_calculate_pnl_sell_position_profit ... ok [INFO] [stdout] test utils::test_id::test_get_id_contains_valid_chars ... ok [INFO] [stdout] test utils::test_id::test_get_id_length ... ok [INFO] [stdout] test test_error::test_app_error_oauth_token_expired ... ok [INFO] [stdout] test storage::test_utils::test_serialize_deserialize_roundtrip ... ok [INFO] [stdout] test utils::test_config::test_get_env_or_none_with_existing_var ... ok [INFO] [stdout] test utils::test_config::test_get_env_or_default_with_existing_var ... ok [INFO] [stdout] test utils::test_id::test_get_id_uniqueness ... ok [INFO] [stdout] test utils::test_model_utils::test_extract_markets_from_deeply_nested_hierarchy ... ok [INFO] [stdout] test utils::test_model_utils::test_extract_markets_from_empty_hierarchy ... ok [INFO] [stdout] test utils::test_id::test_get_id_returns_some ... ok [INFO] [stdout] test utils::test_model_utils::test_extract_markets_from_multiple_nodes ... ok [INFO] [stdout] test utils::test_model_utils::test_extract_markets_from_nested_hierarchy ... ok [INFO] [stdout] test utils::test_model_utils::test_extract_markets_preserves_market_data ... ok [INFO] [stdout] test utils::test_retry::test_retry_config_default ... ok [INFO] [stdout] test utils::test_retry::test_retry_config_delay_secs_getter ... ok [INFO] [stdout] test utils::test_retry::test_retry_config_infinite ... ok [INFO] [stdout] test utils::test_retry::test_retry_config_max_retries_getter ... ok [INFO] [stdout] test utils::test_retry::test_retry_config_new ... ok [INFO] [stdout] test utils::test_retry::test_retry_config_with_delay ... ok [INFO] [stdout] test utils::test_retry::test_retry_config_with_max_retries ... ok [INFO] [stdout] test utils::test_retry::test_retry_config_with_max_retries_and_delay ... ok [INFO] [stdout] test utils::tools_tests::tests::test_version_constant ... ok [INFO] [stdout] test utils::test_model_utils::test_extract_markets_from_node_without_markets ... ok [INFO] [stdout] test utils::test_model_utils::test_extract_markets_from_single_node_with_market ... ok [INFO] [stdout] test utils::tools_tests::tests::test_version_function ... ok [INFO] [stdout] test utils::tools_tests::tests::test_version_format ... ok [INFO] [stdout] test utils::test_id::test_get_id_multiple_calls ... ok [INFO] [stdout] test application::test_client::get_multiple_market_details_empty_returns_default ... ok [INFO] [stdout] test application::test_client::get_multiple_market_details_more_than_50_returns_error ... ok [INFO] [stdout] test application::test_client::client_default_new_equivalence ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 251 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.68s [INFO] [stdout] [INFO] [stderr] Doc-tests ig_client [INFO] [stdout] [INFO] [stdout] running 29 tests [INFO] [stdout] test src/application/client.rs - application::client::StreamerClient::account_subscribe (line 1314) ... ignored [INFO] [stdout] test src/application/client.rs - application::client::StreamerClient::chart_subscribe (line 1492) ... ignored [INFO] [stdout] test src/application/client.rs - application::client::StreamerClient::market_subscribe (line 1151) ... ignored [INFO] [stdout] test src/application/client.rs - application::client::StreamerClient::price_subscribe (line 1393) ... ignored [INFO] [stdout] test src/application/client.rs - application::client::StreamerClient::trade_subscribe (line 1233) ... ignored [INFO] [stdout] test src/application/dynamic_streamer.rs - application::dynamic_streamer::DynamicMarketStreamer (line 29) ... ignored [INFO] [stdout] test src/application/dynamic_streamer.rs - application::dynamic_streamer::DynamicMarketStreamer::add (line 133) ... ignored [INFO] [stdout] test src/application/dynamic_streamer.rs - application::dynamic_streamer::DynamicMarketStreamer::clear (line 207) ... ignored [INFO] [stdout] test src/application/dynamic_streamer.rs - application::dynamic_streamer::DynamicMarketStreamer::connect (line 391) ... ignored [INFO] [stdout] test src/application/dynamic_streamer.rs - application::dynamic_streamer::DynamicMarketStreamer::disconnect (line 420) ... ignored [INFO] [stdout] test src/application/dynamic_streamer.rs - application::dynamic_streamer::DynamicMarketStreamer::get_epics (line 226) ... ignored [INFO] [stdout] test src/application/dynamic_streamer.rs - application::dynamic_streamer::DynamicMarketStreamer::get_receiver (line 246) ... ignored [INFO] [stdout] test src/application/dynamic_streamer.rs - application::dynamic_streamer::DynamicMarketStreamer::new (line 98) ... ignored [INFO] [stdout] test src/application/dynamic_streamer.rs - application::dynamic_streamer::DynamicMarketStreamer::remove (line 171) ... ignored [INFO] [stdout] test src/application/dynamic_streamer.rs - application::dynamic_streamer::DynamicMarketStreamer::start (line 369) ... ignored [INFO] [stdout] test src/application/rate_limiter.rs - application::rate_limiter::RateLimiter::check (line 100) ... ignored [INFO] [stdout] test src/application/rate_limiter.rs - application::rate_limiter::RateLimiter::new (line 44) ... ignored [INFO] [stdout] test src/application/rate_limiter.rs - application::rate_limiter::RateLimiter::wait (line 81) ... ignored [INFO] [stdout] test src/lib.rs - (line 172) ... ignored [INFO] [stdout] test src/lib.rs - (line 195) ... ignored [INFO] [stdout] test src/lib.rs - (line 219) ... ignored [INFO] [stdout] test src/lib.rs - (line 247) ... ignored [INFO] [stdout] test src/lib.rs - (line 302) ... ignored [INFO] [stdout] test src/lib.rs - (line 481) ... ignored [INFO] [stdout] test src/lib.rs - (line 78) ... ignored [INFO] [stdout] test src/lib.rs - prelude (line 588) ... ignored [INFO] [stdout] test src/model/http.rs - model::http::make_http_request (line 374) ... ignored [INFO] [stdout] test src/utils/id.rs - utils::id::get_id (line 15) ... ok [INFO] [stdout] test src/utils/parsing.rs - utils::parsing::parse_instrument_name (line 105) ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 2 passed; 0 failed; 27 ignored; 0 measured; 0 filtered out; finished in 0.06s [INFO] [stdout] [INFO] [stdout] all doctests ran in 1.99s; merged doctests compilation took 1.87s [INFO] running `Command { std: "docker" "inspect" "4b97158892db90d5eb55d75223b934ba18b220e005fb6a02d93c055ec4b55da5", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4b97158892db90d5eb55d75223b934ba18b220e005fb6a02d93c055ec4b55da5", kill_on_drop: false }` [INFO] [stdout] 4b97158892db90d5eb55d75223b934ba18b220e005fb6a02d93c055ec4b55da5