[INFO] cloning repository https://github.com/TikTzuki/tradeon
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/TikTzuki/tradeon" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTikTzuki%2Ftradeon", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTikTzuki%2Ftradeon'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 39bb3ab35681b2bdfd290efe846b77d1c2586fa8
[INFO] testing TikTzuki/tradeon against try#33835004928d3bf65db4d4712e1330766263b0bd for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FTikTzuki%2Ftradeon" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/TikTzuki/tradeon
[INFO] finished tweaking git repo https://github.com/TikTzuki/tradeon
[INFO] tweaked toml for git repo https://github.com/TikTzuki/tradeon written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/TikTzuki/tradeon on toolchain 33835004928d3bf65db4d4712e1330766263b0bd
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/TikTzuki/tradeon 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" "+33835004928d3bf65db4d4712e1330766263b0bd" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: /workspace/builds/worker-5-tc2/source/crates/tradeon-core/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr] warning: /workspace/builds/worker-5-tc2/source/crates/dataset/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2f2ca0edfa230f4c09cbb26c4a3f55d912d31bcc8fe89dbcf0fb0f42bd3998c9
[INFO] running `Command { std: "docker" "start" "-a" "2f2ca0edfa230f4c09cbb26c4a3f55d912d31bcc8fe89dbcf0fb0f42bd3998c9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2f2ca0edfa230f4c09cbb26c4a3f55d912d31bcc8fe89dbcf0fb0f42bd3998c9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2f2ca0edfa230f4c09cbb26c4a3f55d912d31bcc8fe89dbcf0fb0f42bd3998c9", kill_on_drop: false }`
[INFO] [stdout] 2f2ca0edfa230f4c09cbb26c4a3f55d912d31bcc8fe89dbcf0fb0f42bd3998c9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 8089a4d46cfde05419bcb28fc4481fb19a4a4414ff49d9bd0ce9de9a30dba083
[INFO] running `Command { std: "docker" "start" "-a" "8089a4d46cfde05419bcb28fc4481fb19a4a4414ff49d9bd0ce9de9a30dba083", kill_on_drop: false }`
[INFO] [stderr] warning: /opt/rustwide/workdir/crates/tradeon-core/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr] warning: /opt/rustwide/workdir/crates/dataset/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr]    Compiling unicode-ident v1.0.22
[INFO] [stderr]    Compiling quote v1.0.41
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling libc v0.2.177
[INFO] [stderr]    Compiling futures-core v0.3.31
[INFO] [stderr]    Compiling generic-array v0.14.9
[INFO] [stderr]    Compiling futures-io v0.3.31
[INFO] [stderr]    Compiling proc-macro2 v1.0.103
[INFO] [stderr]    Compiling log v0.4.28
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]    Compiling foldhash v0.2.0
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling find-msvc-tools v0.1.4
[INFO] [stderr]    Compiling syn v2.0.108
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]    Compiling cc v1.2.44
[INFO] [stderr]    Compiling try-lock v0.2.5
[INFO] [stderr]    Compiling writeable v0.6.2
[INFO] [stderr]    Compiling litemap v0.8.1
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling mio v1.1.0
[INFO] [stderr]    Compiling socket2 v0.6.1
[INFO] [stderr]    Compiling signal-hook-registry v1.4.6
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling want v0.3.1
[INFO] [stderr]    Compiling icu_normalizer_data v2.1.1
[INFO] [stderr]    Compiling icu_properties_data v2.1.1
[INFO] [stderr]    Compiling atomic-waker v1.1.2
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling bytes v1.10.1
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling rustls-pki-types v1.13.0
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling tokio v1.48.0
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling indexmap v2.12.1
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling openssl-sys v0.9.110
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]    Compiling hashlink v0.10.0
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling crunchy v0.2.4
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling rustls-webpki v0.103.8
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling tiny-keccak v2.0.2
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling pin-project v1.1.10
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling matchit v0.7.3
[INFO] [stderr]    Compiling openssl v0.10.74
[INFO] [stderr]    Compiling parking v2.2.1
[INFO] [stderr]    Compiling adler2 v2.0.1
[INFO] [stderr]    Compiling simd-adler32 v0.3.7
[INFO] [stderr]    Compiling openssl-probe v0.1.6
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling deranged v0.5.5
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling icu_properties v2.1.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling http v1.3.1
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling tracing-serde v0.2.0
[INFO] [stderr]    Compiling async-stream v0.3.6
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling prost-derive v0.13.5
[INFO] [stderr]    Compiling url v2.5.7
[INFO] [stderr]    Compiling axum-core v0.4.5
[INFO] [stderr]    Compiling sharded-slab v0.1.7
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling nu-ansi-term v0.50.3
[INFO] [stderr]    Compiling ucd-trie v0.1.7
[INFO] [stderr]    Compiling crc-catalog v2.4.0
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling typeid v1.0.3
[INFO] [stderr]    Compiling tinyvec v1.10.0
[INFO] [stderr]    Compiling tracing-subscriber v0.3.20
[INFO] [stderr]    Compiling pest v2.8.3
[INFO] [stderr]    Compiling crc v3.4.0
[INFO] [stderr]    Compiling time v0.3.44
[INFO] [stderr]    Compiling prost v0.13.5
[INFO] [stderr]    Compiling const-random-macro v0.1.16
[INFO] [stderr]    Compiling prost-types v0.13.5
[INFO] [stderr]    Compiling flate2 v1.1.5
[INFO] [stderr]    Compiling utoipa-gen v5.4.0
[INFO] [stderr]    Compiling base64ct v1.8.0
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling pem-rfc7468 v0.7.0
[INFO] [stderr]    Compiling hdrhistogram v7.5.4
[INFO] [stderr]    Compiling pest_meta v2.8.3
[INFO] [stderr]    Compiling const-random v0.1.18
[INFO] [stderr]    Compiling unicode-normalization v0.1.25
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling tokio-util v0.7.16
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling h2 v0.4.12
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling axum v0.7.9
[INFO] [stderr]    Compiling tower v0.4.13
[INFO] [stderr]    Compiling chrono v0.4.42
[INFO] [stderr]    Compiling encoding_rs v0.8.35
[INFO] [stderr]    Compiling unicode-bidi v0.3.18
[INFO] [stderr]    Compiling humantime v2.3.0
[INFO] [stderr]    Compiling winnow v0.7.13
[INFO] [stderr]    Compiling const-oid v0.9.6
[INFO] [stderr]    Compiling erased-serde v0.4.9
[INFO] [stderr]    Compiling unicode-properties v0.1.4
[INFO] [stderr]    Compiling anstyle-query v1.1.4
[INFO] [stderr]    Compiling anstream v0.6.21
[INFO] [stderr]    Compiling stringprep v0.1.5
[INFO] [stderr]    Compiling der v0.7.10
[INFO] [stderr]    Compiling darling_core v0.21.3
[INFO] [stderr]    Compiling pest_generator v2.8.3
[INFO] [stderr]    Compiling event-listener v5.4.1
[INFO] [stderr]    Compiling dlv-list v0.5.2
[INFO] [stderr]    Compiling futures-intrusive v0.5.0
[INFO] [stderr]    Compiling toml_parser v1.0.9+spec-1.1.0
[INFO] [stderr]    Compiling curve25519-dalek v4.1.3
[INFO] [stderr]    Compiling tracing-appender v0.2.3
[INFO] [stderr]    Compiling hyper v1.7.0
[INFO] [stderr]    Compiling crossbeam-queue v0.3.12
[INFO] [stderr]    Compiling serde_spanned v1.0.4
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling signature v2.2.0
[INFO] [stderr]    Compiling dotenvy v0.15.7
[INFO] [stderr]    Compiling whoami v1.6.1
[INFO] [stderr]    Compiling utoipa v5.4.0
[INFO] [stderr]    Compiling data-encoding v2.9.0
[INFO] [stderr]    Compiling ordered-multimap v0.7.3
[INFO] [stderr]    Compiling clap_builder v4.5.51
[INFO] [stderr]    Compiling hyper-util v0.1.17
[INFO] [stderr]    Compiling sqlx-core v0.9.0-alpha.1
[INFO] [stderr]    Compiling darling_macro v0.21.3
[INFO] [stderr]    Compiling hkdf v0.12.4
[INFO] [stderr]    Compiling pest_derive v2.8.3
[INFO] [stderr]    Compiling spki v0.7.3
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling http-body v0.4.6
[INFO] [stderr]    Compiling atoi v2.0.0
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]    Compiling curve25519-dalek-derive v0.1.1
[INFO] [stderr]    Compiling toml_datetime v0.7.3
[INFO] [stderr]    Compiling hyper-timeout v0.5.2
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]    Compiling tonic v0.12.3
[INFO] [stderr]    Compiling rustls v0.23.34
[INFO] [stderr]    Compiling arraydeque v0.5.1
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling convert_case v0.6.0
[INFO] [stderr]    Compiling clap v4.5.51
[INFO] [stderr]    Compiling yaml-rust2 v0.10.4
[INFO] [stderr]    Compiling toml v0.9.8
[INFO] [stderr]    Compiling sqlx-postgres v0.9.0-alpha.1
[INFO] [stderr]    Compiling console-api v0.8.1
[INFO] [stderr]    Compiling serde-untagged v0.1.9
[INFO] [stderr]    Compiling json5 v0.4.1
[INFO] [stderr]    Compiling pkcs8 v0.10.2
[INFO] [stderr]    Compiling darling v0.21.3
[INFO] [stderr]    Compiling rust-ini v0.21.3
[INFO] [stderr]    Compiling ed25519 v2.2.3
[INFO] [stderr]    Compiling ron v0.12.0
[INFO] [stderr]    Compiling console-subscriber v0.4.1
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling pathdiff v0.2.3
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]    Compiling utf-8 v0.7.6
[INFO] [stderr]    Compiling tungstenite v0.21.0
[INFO] [stderr]    Compiling config v0.15.19
[INFO] [stderr]    Compiling ed25519-dalek v2.2.0
[INFO] [stderr]    Compiling serde_with_macros v3.16.0
[INFO] [stderr]    Compiling signatory v0.27.1
[INFO] [stderr]    Compiling dyson_log v0.1.0
[INFO] [stderr]    Compiling sqlx-macros-core v0.9.0-alpha.1
[INFO] [stderr]    Compiling hyper-tls v0.5.0
[INFO] [stderr]    Compiling axum-core v0.5.6
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling serde_repr v0.1.20
[INFO] [stderr]    Compiling rustls-pemfile v1.0.4
[INFO] [stderr]    Compiling toml_datetime v1.0.0+spec-1.1.0
[INFO] [stderr]    Compiling serde_path_to_error v0.1.20
[INFO] [stderr]    Compiling rustls-pemfile v2.2.0
[INFO] [stderr]    Compiling matchit v0.8.4
[INFO] [stderr]    Compiling xml-rs v0.8.28
[INFO] [stderr]    Compiling sync_wrapper v0.1.2
[INFO] [stderr]    Compiling zlib-rs v0.5.5
[INFO] [stderr]    Compiling toml_writer v1.0.6+spec-1.1.0
[INFO] [stderr]    Compiling axum v0.8.8
[INFO] [stderr]    Compiling reqwest v0.11.27
[INFO] [stderr]    Compiling toml v1.0.2+spec-1.1.0
[INFO] [stderr]    Compiling serde-xml-rs v0.8.1
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling rustls-native-certs v0.7.3
[INFO] [stderr]    Compiling sqlx-macros v0.9.0-alpha.1
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling serde_with v3.16.0
[INFO] [stderr]    Compiling libz-rs-sys v0.5.5
[INFO] [stderr]    Compiling nkeys v0.4.5
[INFO] [stderr]    Compiling tokio-tungstenite v0.21.0
[INFO] [stderr]    Compiling utils v0.1.0 (/opt/rustwide/workdir/crates/utils)
[INFO] [stderr]    Compiling tryhard v0.5.2
[INFO] [stderr]    Compiling serde_qs v0.12.0
[INFO] [stderr]    Compiling serde_nanos v0.1.4
[INFO] [stderr]    Compiling rustls-webpki v0.102.8
[INFO] [stderr]    Compiling webpki-roots v1.0.4
[INFO] [stderr]    Compiling nuid v0.5.0
[INFO] [stderr]    Compiling iri-string v0.7.10
[INFO] [stderr]    Compiling bumpalo v3.19.0
[INFO] [stderr]    Compiling inventory v0.3.21
[INFO] [stderr]    Compiling boolinator v2.4.0
[INFO] [stderr]    Compiling binance-rs-async v1.3.3
[INFO] [stderr]    Compiling tradeon-core v0.1.0 (/opt/rustwide/workdir/crates/tradeon-core)
[INFO] [stderr]    Compiling zopfli v0.8.3
[INFO] [stderr]    Compiling async-nats v0.45.0
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling sqlx v0.9.0-alpha.1
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling unicase v2.9.0
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling zip v3.0.0
[INFO] [stderr]    Compiling rust-embed-utils v8.11.0
[INFO] [stderr]    Compiling inout v0.1.4
[INFO] [stderr]    Compiling utoipa-swagger-ui-vendored v0.1.2
[INFO] [stderr]    Compiling cipher v0.4.4
[INFO] [stderr]    Compiling rust-embed-impl v8.11.0
[INFO] [stderr]    Compiling universal-hash v0.5.1
[INFO] [stderr]    Compiling polyval v0.6.2
[INFO] [stderr]    Compiling rust-embed v8.11.0
[INFO] [stderr]    Compiling ghash v0.5.1
[INFO] [stderr]    Compiling utoipa-axum v0.2.0
[INFO] [stderr]    Compiling aes v0.8.4
[INFO] [stderr]    Compiling ctr v0.9.2
[INFO] [stderr]    Compiling utoipa-rapidoc v6.0.0
[INFO] [stderr]    Compiling utoipa-redoc v6.0.0
[INFO] [stderr]    Compiling utoipa-scalar v0.3.0
[INFO] [stderr]    Compiling sim v0.1.0 (/opt/rustwide/workdir/crates/sim)
[INFO] [stderr]    Compiling aead v0.5.2
[INFO] [stderr]    Compiling dyson_boot v0.1.1
[INFO] [stderr]    Compiling aes-gcm v0.10.3
[INFO] [stderr]    Compiling utoipa-swagger-ui v9.0.2
[INFO] [stderr]    Compiling dyson_http v0.1.1
[INFO] [stderr]    Compiling dataset v0.1.0 (/opt/rustwide/workdir/crates/dataset)
[INFO] [stdout] warning: unused import: `oneshot`
[INFO] [stdout]   --> crates/dataset/src/dataset/generic_kline.rs:14:27
[INFO] [stdout]    |
[INFO] [stdout] 14 | use tokio::sync::{RwLock, oneshot};
[INFO] [stdout]    |                           ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `run_live_data` is never used
[INFO] [stdout]    --> crates/dataset/src/dataset/generic_kline.rs:104:14
[INFO] [stdout]     |
[INFO] [stdout]  89 | impl GenericKlineDataset {
[INFO] [stdout]     | ------------------------ associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 104 |     async fn run_live_data(_self: Arc<&Self>) -> anyhow::Result<u128> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for the crate
[INFO] [stdout]  --> crates/dataset/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | / pub mod binance;
[INFO] [stdout] 2 | | pub mod dataset;
[INFO] [stdout] 3 | | pub mod domain;
[INFO] [stdout] 4 | | pub mod error;
[INFO] [stdout] 5 | | pub mod persistence;
[INFO] [stdout] 6 | | pub mod prelude;
[INFO] [stdout] 7 | | pub mod sync;
[INFO] [stdout]   | |_____________^
[INFO] [stdout]   |
[INFO] [stdout]   = note: requested on the command line with `-W missing-docs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod dataset;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub mod error;
[INFO] [stdout]   | ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:5:1
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub mod persistence;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:6:1
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub mod prelude;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/binance/mod.rs:5:1
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub mod market;
[INFO] [stdout]   | ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub order_id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub side: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub position_side: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub quote_qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 40 |     pub realized_pnl: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub commission: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub commission_asset: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub time: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 44 |     pub maker: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub buyer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:49:1
[INFO] [stdout]    |
[INFO] [stdout] 49 | / pub struct FuturesBinanceClient {
[INFO] [stdout] 50 | |     account: FuturesAccount,
[INFO] [stdout] 51 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: requested on the command line with `-W missing-debug-implementations`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:16:1
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct OHLCVCandle(pub i64, pub f64, pub f64, pub f64, pub f64, pub f64);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:17:1
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub trait OHLCV {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     fn timestamp(&self) -> &i64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn open(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     fn high(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     fn low(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     fn close(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn volume(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:53:1
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub trait KlineHistory: Send + Sync {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 | /     async fn get_hist<T: Send + Sync>(
[INFO] [stdout] 55 | |         &self,
[INFO] [stdout] 56 | |         symbol: &str,
[INFO] [stdout] 57 | |         interval: &Interval,
[INFO] [stdout] ...  |
[INFO] [stdout] 62 | |     where
[INFO] [stdout] 63 | |         T: Into<Option<u64>>;
[INFO] [stdout]    | |_____________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 65 |     fn kline_limit(&self) -> u16;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stdout]    |
[INFO] [stdout] 68 | / pub enum Exchange {
[INFO] [stdout] 69 | |     BINANCE(BinanceExchange),
[INFO] [stdout] 70 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an enum
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub enum Exchange {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     BINANCE(BinanceExchange),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> crates/dataset/src/binance/market.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct BinanceExchange {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/market.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn new() -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     pub id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     pub order_id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 31 |     pub price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub quote_qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub commission: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub commission_asset: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub time: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub is_buyer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub is_maker: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub is_best_match: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:43:1
[INFO] [stdout]    |
[INFO] [stdout] 43 | / pub struct BinanceClient {
[INFO] [stdout] 44 | |     account: Account,
[INFO] [stdout] 45 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/dataset/mod.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub mod factory;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct UniverseImpl {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub interval: Interval,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub fn ti_to_ts(&self, ti: u128) -> u128 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     pub fn ts_to_ti(&self, ts: u128) -> u128 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub fn format_path(&self) -> String {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a macro
[INFO] [stdout]  --> crates/dataset/src/dataset/factory.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | macro_rules! register_datasource {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:30:1
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn make_dataset(cfg: DatasetConfig) -> Option<Box<dyn Dataset>> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:37:1
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub fn build_datasource_from_xml(xml_str: &str) -> anyhow::Result<Box<dyn Dataset>> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/persistence/mod.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod error;
[INFO] [stdout]   | ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/persistence/mod.rs:3:1
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub mod kline_repos;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]  --> crates/dataset/src/persistence/error.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 |     Database(#[from] SqlxError),
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     DuplicateKey {
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 12 |         symbol: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |         interval: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |         time: DateTime<Utc>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     PoolExhausted,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     InvalidData(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Config(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct FuturesTradeRepo {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | /     pub async fn upsert_from_exchange(
[INFO] [stdout] 33 | |         &self,
[INFO] [stdout] 34 | |         user_id: &str,
[INFO] [stdout] 35 | |         trades: &[NewFuturesTrade],
[INFO] [stdout] 36 | |     ) -> Result<u64, DatasetError> {
[INFO] [stdout]    | |__________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:94:5
[INFO] [stdout]    |
[INFO] [stdout] 94 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<FuturesTrade>, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/futures_trade_repo.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 110 | /     pub async fn get_last_trade_time(
[INFO] [stdout] 111 | |         &self,
[INFO] [stdout] 112 | |         user_id: &str,
[INFO] [stdout] 113 | |         exchange: &str,
[INFO] [stdout] 114 | |         symbol: &str,
[INFO] [stdout] 115 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stdout]     | |____________________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     pub time: DateTime<Utc>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     pub interval: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     pub open: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     pub high: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     pub low: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     pub close: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     pub volume: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:30:1
[INFO] [stdout]    |
[INFO] [stdout] 30 | / pub struct KlineRepo {
[INFO] [stdout] 31 | |     pool: PgPool,
[INFO] [stdout] 32 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/persistence/trade_repo.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/trade_repo.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub async fn insert(&self, user_id: &str, t: &NewTrade) -> Result<i64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:112:5
[INFO] [stdout]     |
[INFO] [stdout] 112 | /     pub async fn get_trades_for_symbol(
[INFO] [stdout] 113 | |         &self,
[INFO] [stdout] 114 | |         user_id: &str,
[INFO] [stdout] 115 | |         symbol: &str,
[INFO] [stdout] 116 | |     ) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stdout]     | |_________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:133:5
[INFO] [stdout]     |
[INFO] [stdout] 133 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:149:5
[INFO] [stdout]     |
[INFO] [stdout] 149 |     pub async fn list_symbols(&self, user_id: &str) -> Result<Vec<String>, DatasetError> {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:158:5
[INFO] [stdout]     |
[INFO] [stdout] 158 | /     pub async fn get_last_trade_time(
[INFO] [stdout] 159 | |         &self,
[INFO] [stdout] 160 | |         user_id: &str,
[INFO] [stdout] 161 | |         exchange: &str,
[INFO] [stdout] 162 | |         symbol: &str,
[INFO] [stdout] 163 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stdout]     | |____________________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | /     pub fn new(
[INFO] [stdout] 21 | |         api_key: &str,
[INFO] [stdout] 22 | |         secret_key: &str,
[INFO] [stdout] 23 | |         store: TradeRepo,
[INFO] [stdout] 24 | |         symbols: Vec<String>,
[INFO] [stdout] 25 | |         user_id: String,
[INFO] [stdout] 26 | |     ) -> Self {
[INFO] [stdout]    | |_____________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 46 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:11:1
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct FuturesTradeSync {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | /     pub fn new(
[INFO] [stdout] 20 | |         api_key: &str,
[INFO] [stdout] 21 | |         secret_key: &str,
[INFO] [stdout] 22 | |         store: FuturesTradeRepo,
[INFO] [stdout] 23 | |         symbols: Vec<String>,
[INFO] [stdout] 24 | |         user_id: String,
[INFO] [stdout] 25 | |     ) -> Self {
[INFO] [stdout]    | |_____________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling portfolio v0.1.0 (/opt/rustwide/workdir/crates/portfolio)
[INFO] [stderr]    Compiling strategy v0.1.0 (/opt/rustwide/workdir/crates/strategy)
[INFO] [stdout] warning: function `crossover` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:551:4
[INFO] [stdout]     |
[INFO] [stdout] 551 | fn crossover(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossunder` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:565:4
[INFO] [stdout]     |
[INFO] [stdout] 565 | fn crossunder(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `export_tradingview_html` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/html_visualizer.rs:361:15
[INFO] [stdout]     |
[INFO] [stdout] 361 | pub(super) fn export_tradingview_html(
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for the crate
[INFO] [stdout]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | / pub mod indicator;
[INFO] [stdout] 2 | | pub mod strategy;
[INFO] [stdout]   | |_________________^
[INFO] [stdout]   |
[INFO] [stdout]   = note: requested on the command line with `-W missing-docs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod indicator;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/strategy/src/lib.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod strategy;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 67 |     pub open: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub high: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub low: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:70:5
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub close: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub volume: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:161:5
[INFO] [stdout]     |
[INFO] [stdout] 161 |     pub ma: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:162:5
[INFO] [stdout]     |
[INFO] [stdout] 162 |     pub ma_trend_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:163:5
[INFO] [stdout]     |
[INFO] [stdout] 163 |     pub ma_trend_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:166:5
[INFO] [stdout]     |
[INFO] [stdout] 166 |     pub top_fractals: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:167:5
[INFO] [stdout]     |
[INFO] [stdout] 167 |     pub bot_fractals: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:170:5
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub macd_line: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:171:5
[INFO] [stdout]     |
[INFO] [stdout] 171 |     pub macd_signal: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:172:5
[INFO] [stdout]     |
[INFO] [stdout] 172 |     pub macd_hist: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:173:5
[INFO] [stdout]     |
[INFO] [stdout] 173 |     pub macd_color_green: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:176:5
[INFO] [stdout]     |
[INFO] [stdout] 176 |     pub bearish_pinbar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:177:5
[INFO] [stdout]     |
[INFO] [stdout] 177 |     pub bullish_pinbar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:178:5
[INFO] [stdout]     |
[INFO] [stdout] 178 |     pub dark_cloud_cover: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:179:5
[INFO] [stdout]     |
[INFO] [stdout] 179 |     pub piercing_line: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:180:5
[INFO] [stdout]     |
[INFO] [stdout] 180 |     pub bearish_harami: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:181:5
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub bullish_harami: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:182:5
[INFO] [stdout]     |
[INFO] [stdout] 182 |     pub bearish_engulfing: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:183:5
[INFO] [stdout]     |
[INFO] [stdout] 183 |     pub bullish_engulfing: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:184:5
[INFO] [stdout]     |
[INFO] [stdout] 184 |     pub bearish_fractal_cross: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:185:5
[INFO] [stdout]     |
[INFO] [stdout] 185 |     pub bullish_fractal_cross: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:188:5
[INFO] [stdout]     |
[INFO] [stdout] 188 |     pub reversal_pinbar_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:189:5
[INFO] [stdout]     |
[INFO] [stdout] 189 |     pub reversal_pinbar_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:190:5
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub shaved_bar_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:191:5
[INFO] [stdout]     |
[INFO] [stdout] 191 |     pub shaved_bar_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:192:5
[INFO] [stdout]     |
[INFO] [stdout] 192 |     pub inside_bar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:193:5
[INFO] [stdout]     |
[INFO] [stdout] 193 |     pub outside_bar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:196:5
[INFO] [stdout]     |
[INFO] [stdout] 196 |     pub bar_color_up: Vec<bool>,   // Lime - confirmed bullish
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:197:5
[INFO] [stdout]     |
[INFO] [stdout] 197 |     pub bar_color_down: Vec<bool>, // Maroon - confirmed bearish
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:200:5
[INFO] [stdout]     |
[INFO] [stdout] 200 |     pub bar_alert: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:201:5
[INFO] [stdout]     |
[INFO] [stdout] 201 |     pub bar_alert_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:202:5
[INFO] [stdout]     |
[INFO] [stdout] 202 |     pub bar_alert_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]     --> crates/strategy/src/indicator/cds_trend.rs:1017:1
[INFO] [stdout]      |
[INFO] [stdout] 1017 | / pub fn write_html_visualization(
[INFO] [stdout] 1018 | |     path: &str,
[INFO] [stdout] 1019 | |     candles: &[Candle],
[INFO] [stdout] 1020 | |     out: &CdsTrendOutput,
[INFO] [stdout] 1021 | | ) -> std::io::Result<()> {
[INFO] [stdout]      | |________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]  --> crates/strategy/src/strategy.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub trait Strategy {}
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling api v0.1.0 (/opt/rustwide/workdir/crates/api)
[INFO] [stderr]    Compiling my_first_strategy v0.1.0 (/opt/rustwide/workdir/crates/my_first_strategy)
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:10:33
[INFO] [stdout]    |
[INFO] [stdout] 10 |     let key = Key::<Aes256Gcm>::from_slice(key);
[INFO] [stdout]    |                                 ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:33:33
[INFO] [stdout]    |
[INFO] [stdout] 33 |     let key = Key::<Aes256Gcm>::from_slice(key);
[INFO] [stdout]    |                                 ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:35:24
[INFO] [stdout]    |
[INFO] [stdout] 35 |     let nonce = Nonce::from_slice(nonce_bytes);
[INFO] [stdout]    |                        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CdsTrendOutput` is never constructed
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:162:19
[INFO] [stdout]     |
[INFO] [stdout] 162 | pub(crate) struct CdsTrendOutput {
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:213:4
[INFO] [stdout]     |
[INFO] [stdout] 213 | fn sma(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `ema` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:234:4
[INFO] [stdout]     |
[INFO] [stdout] 234 | fn ema(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `wma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:253:4
[INFO] [stdout]     |
[INFO] [stdout] 253 | fn wma(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `vwma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:274:4
[INFO] [stdout]     |
[INFO] [stdout] 274 | fn vwma(candles: &[Candle], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `smma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:297:4
[INFO] [stdout]     |
[INFO] [stdout] 297 | fn smma(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dema` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:321:4
[INFO] [stdout]     |
[INFO] [stdout] 321 | fn dema(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tema` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:337:4
[INFO] [stdout]     |
[INFO] [stdout] 337 | fn tema(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hull_ma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:355:4
[INFO] [stdout]     |
[INFO] [stdout] 355 | fn hull_ma(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `zema` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:379:4
[INFO] [stdout]     |
[INFO] [stdout] 379 | fn zema(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tma` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:395:4
[INFO] [stdout]     |
[INFO] [stdout] 395 | fn tma(series: &[f64], length: usize) -> Vec<Option<f64>> {
[INFO] [stdout]     |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `variant` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:402:4
[INFO] [stdout]     |
[INFO] [stdout] 402 | fn variant(
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `detect_fractals` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:429:4
[INFO] [stdout]     |
[INFO] [stdout] 429 | fn detect_fractals(candles: &[Candle]) -> (Vec<Option<f64>>, Vec<Option<f64>>) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_macd` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:488:4
[INFO] [stdout]     |
[INFO] [stdout] 488 | fn calculate_macd(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `lowest` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:530:4
[INFO] [stdout]     |
[INFO] [stdout] 530 | fn lowest(candles: &[Candle], end_idx: usize, length: usize) -> f64 {
[INFO] [stdout]     |    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `highest` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:542:4
[INFO] [stdout]     |
[INFO] [stdout] 542 | fn highest(candles: &[Candle], end_idx: usize, length: usize) -> f64 {
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossover` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:554:4
[INFO] [stdout]     |
[INFO] [stdout] 554 | fn crossover(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossunder` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:568:4
[INFO] [stdout]     |
[INFO] [stdout] 568 | fn crossunder(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `detect_patterns` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:587:4
[INFO] [stdout]     |
[INFO] [stdout] 587 | fn detect_patterns(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_cds_trend` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:836:15
[INFO] [stdout]     |
[INFO] [stdout] 836 | pub(crate) fn run_cds_trend(candles: &[Candle], config: &CdsTrendConfig) -> CdsTrendOutput {
[INFO] [stdout]     |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `length` is never read
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1023:5
[INFO] [stdout]      |
[INFO] [stdout] 1022 | struct EmaState {
[INFO] [stdout]      |        -------- field in this struct
[INFO] [stdout] 1023 |     length: usize,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `EmaState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `length` and `buffer` are never read
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1118:5
[INFO] [stdout]      |
[INFO] [stdout] 1117 | struct HullMaState {
[INFO] [stdout]      |        ----------- fields in this struct
[INFO] [stdout] 1118 |     length: usize,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1122 |     buffer: VecDeque<f64>,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `HullMaState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `reset` is never used
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1674:19
[INFO] [stdout]      |
[INFO] [stdout] 1294 | impl CdsTrendStream {
[INFO] [stdout]      | ------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1674 |     pub(crate) fn reset(&mut self) {
[INFO] [stdout]      |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/my_first_strategy/src/main.rs:36:1
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct MyChannelHub {}
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: requested on the command line with `-W missing-debug-implementations`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/my_first_strategy/src/main.rs:39:1
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct Payload {}
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `decrypt` is never used
[INFO] [stdout]   --> crates/api/src/crypto.rs:23:15
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub(crate) fn decrypt(encrypted: &str, key: &[u8]) -> Result<String, String> {
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 7m 09s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: binance-rs-async v1.3.3
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] running `Command { std: "docker" "inspect" "8089a4d46cfde05419bcb28fc4481fb19a4a4414ff49d9bd0ce9de9a30dba083", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8089a4d46cfde05419bcb28fc4481fb19a4a4414ff49d9bd0ce9de9a30dba083", kill_on_drop: false }`
[INFO] [stdout] 8089a4d46cfde05419bcb28fc4481fb19a4a4414ff49d9bd0ce9de9a30dba083
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f6c0d23dadf93e6b05956f87b8060b1ba473c7cc1a5f99bebe6cc57f0a064a5c
[INFO] running `Command { std: "docker" "start" "-a" "f6c0d23dadf93e6b05956f87b8060b1ba473c7cc1a5f99bebe6cc57f0a064a5c", kill_on_drop: false }`
[INFO] [stderr] warning: /opt/rustwide/workdir/crates/dataset/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr] warning: /opt/rustwide/workdir/crates/tradeon-core/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling zerocopy v0.8.27
[INFO] [stderr]    Compiling zerocopy-derive v0.8.27
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling toml_parser v1.0.9+spec-1.1.0
[INFO] [stderr]    Compiling toml_datetime v0.7.3
[INFO] [stderr]    Compiling rstest_macros v0.26.1
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]    Compiling sqlx-core v0.9.0-alpha.1
[INFO] [stderr]    Compiling glob v0.3.3
[INFO] [stderr]    Compiling relative-path v1.9.3
[INFO] [stderr]    Compiling toml_edit v0.23.7
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling futures-timer v3.0.3
[INFO] [stderr]    Compiling rayon v1.11.0
[INFO] [stderr]    Compiling proc-macro-crate v3.4.0
[INFO] [stderr]    Compiling prost-derive v0.13.5
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling criterion-plot v0.6.0
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling hyper-util v0.1.17
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling axum-core v0.4.5
[INFO] [stderr]    Compiling prost v0.13.5
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling sqlx-postgres v0.9.0-alpha.1
[INFO] [stderr]    Compiling prost-types v0.13.5
[INFO] [stderr]    Compiling tower v0.4.13
[INFO] [stderr]    Compiling hyper-timeout v0.5.2
[INFO] [stderr]    Compiling tungstenite v0.21.0
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling axum v0.7.9
[INFO] [stderr]    Compiling tokio-tungstenite v0.21.0
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling nuid v0.5.0
[INFO] [stderr]    Compiling nkeys v0.4.5
[INFO] [stderr]    Compiling axum v0.8.8
[INFO] [stderr]    Compiling async-nats v0.45.0
[INFO] [stderr]    Compiling half v2.7.1
[INFO] [stderr]    Compiling rstest v0.26.1
[INFO] [stderr]    Compiling plotters v0.3.7
[INFO] [stderr]    Compiling ciborium-ll v0.2.2
[INFO] [stderr]    Compiling ciborium v0.2.2
[INFO] [stderr]    Compiling tinytemplate v1.2.1
[INFO] [stderr]    Compiling oorandom v11.1.5
[INFO] [stderr]    Compiling criterion v0.7.0
[INFO] [stderr]    Compiling sqlx-macros-core v0.9.0-alpha.1
[INFO] [stderr]    Compiling tonic v0.12.3
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling utoipa-scalar v0.3.0
[INFO] [stderr]    Compiling utoipa-axum v0.2.0
[INFO] [stderr]    Compiling sqlx-macros v0.9.0-alpha.1
[INFO] [stderr]    Compiling utoipa-redoc v6.0.0
[INFO] [stderr]    Compiling utoipa-swagger-ui v9.0.2
[INFO] [stderr]    Compiling utoipa-rapidoc v6.0.0
[INFO] [stderr]    Compiling console-api v0.8.1
[INFO] [stderr]    Compiling dyson_http v0.1.1
[INFO] [stderr]    Compiling console-subscriber v0.4.1
[INFO] [stderr]    Compiling hyper-tls v0.5.0
[INFO] [stderr]    Compiling utils v0.1.0 (/opt/rustwide/workdir/crates/utils)
[INFO] [stderr]    Compiling reqwest v0.11.27
[INFO] [stderr]    Compiling sqlx v0.9.0-alpha.1
[INFO] [stderr]    Compiling dyson_log v0.1.0
[INFO] [stderr]    Compiling tradeon-core v0.1.0 (/opt/rustwide/workdir/crates/tradeon-core)
[INFO] [stderr]    Compiling binance-rs-async v1.3.3
[INFO] [stderr]    Compiling sim v0.1.0 (/opt/rustwide/workdir/crates/sim)
[INFO] [stderr]    Compiling dataset v0.1.0 (/opt/rustwide/workdir/crates/dataset)
[INFO] [stdout] warning: unused import: `oneshot`
[INFO] [stdout]   --> crates/dataset/src/dataset/generic_kline.rs:14:27
[INFO] [stdout]    |
[INFO] [stdout] 14 | use tokio::sync::{RwLock, oneshot};
[INFO] [stdout]    |                           ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `oneshot`
[INFO] [stdout]   --> crates/dataset/src/dataset/generic_kline.rs:14:27
[INFO] [stdout]    |
[INFO] [stdout] 14 | use tokio::sync::{RwLock, oneshot};
[INFO] [stdout]    |                           ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `run_live_data` is never used
[INFO] [stdout]    --> crates/dataset/src/dataset/generic_kline.rs:104:14
[INFO] [stdout]     |
[INFO] [stdout]  89 | impl GenericKlineDataset {
[INFO] [stdout]     | ------------------------ associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 104 |     async fn run_live_data(_self: Arc<&Self>) -> anyhow::Result<u128> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for the crate
[INFO] [stdout]  --> crates/dataset/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | / pub mod binance;
[INFO] [stdout] 2 | | pub mod dataset;
[INFO] [stdout] 3 | | pub mod domain;
[INFO] [stdout] 4 | | pub mod error;
[INFO] [stdout] 5 | | pub mod persistence;
[INFO] [stdout] 6 | | pub mod prelude;
[INFO] [stdout] 7 | | pub mod sync;
[INFO] [stdout]   | |_____________^
[INFO] [stdout]   |
[INFO] [stdout]   = note: requested on the command line with `-W missing-docs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod dataset;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub mod error;
[INFO] [stdout]   | ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:5:1
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub mod persistence;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:6:1
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub mod prelude;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/binance/mod.rs:5:1
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub mod market;
[INFO] [stdout]   | ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub order_id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub side: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub position_side: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub quote_qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 40 |     pub realized_pnl: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub commission: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub commission_asset: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub time: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 44 |     pub maker: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub buyer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:49:1
[INFO] [stdout]    |
[INFO] [stdout] 49 | / pub struct FuturesBinanceClient {
[INFO] [stdout] 50 | |     account: FuturesAccount,
[INFO] [stdout] 51 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: requested on the command line with `-W missing-debug-implementations`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:16:1
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct OHLCVCandle(pub i64, pub f64, pub f64, pub f64, pub f64, pub f64);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:17:1
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub trait OHLCV {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     fn timestamp(&self) -> &i64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn open(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     fn high(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     fn low(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     fn close(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn volume(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:53:1
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub trait KlineHistory: Send + Sync {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 | /     async fn get_hist<T: Send + Sync>(
[INFO] [stdout] 55 | |         &self,
[INFO] [stdout] 56 | |         symbol: &str,
[INFO] [stdout] 57 | |         interval: &Interval,
[INFO] [stdout] ...  |
[INFO] [stdout] 62 | |     where
[INFO] [stdout] 63 | |         T: Into<Option<u64>>;
[INFO] [stdout]    | |_____________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 65 |     fn kline_limit(&self) -> u16;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stdout]    |
[INFO] [stdout] 68 | / pub enum Exchange {
[INFO] [stdout] 69 | |     BINANCE(BinanceExchange),
[INFO] [stdout] 70 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an enum
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub enum Exchange {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     BINANCE(BinanceExchange),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> crates/dataset/src/binance/market.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct BinanceExchange {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/market.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn new() -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     pub id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     pub order_id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 31 |     pub price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub quote_qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub commission: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub commission_asset: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub time: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub is_buyer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub is_maker: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub is_best_match: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:43:1
[INFO] [stdout]    |
[INFO] [stdout] 43 | / pub struct BinanceClient {
[INFO] [stdout] 44 | |     account: Account,
[INFO] [stdout] 45 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/dataset/mod.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub mod factory;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct UniverseImpl {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub interval: Interval,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub fn ti_to_ts(&self, ti: u128) -> u128 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     pub fn ts_to_ti(&self, ts: u128) -> u128 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub fn format_path(&self) -> String {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a macro
[INFO] [stdout]  --> crates/dataset/src/dataset/factory.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | macro_rules! register_datasource {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:30:1
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn make_dataset(cfg: DatasetConfig) -> Option<Box<dyn Dataset>> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:37:1
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub fn build_datasource_from_xml(xml_str: &str) -> anyhow::Result<Box<dyn Dataset>> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/persistence/mod.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod error;
[INFO] [stdout]   | ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/persistence/mod.rs:3:1
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub mod kline_repos;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]  --> crates/dataset/src/persistence/error.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 |     Database(#[from] SqlxError),
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     DuplicateKey {
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 12 |         symbol: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |         interval: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |         time: DateTime<Utc>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     PoolExhausted,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     InvalidData(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Config(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct FuturesTradeRepo {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | /     pub async fn upsert_from_exchange(
[INFO] [stdout] 33 | |         &self,
[INFO] [stdout] 34 | |         user_id: &str,
[INFO] [stdout] 35 | |         trades: &[NewFuturesTrade],
[INFO] [stdout] 36 | |     ) -> Result<u64, DatasetError> {
[INFO] [stdout]    | |__________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:94:5
[INFO] [stdout]    |
[INFO] [stdout] 94 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<FuturesTrade>, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/futures_trade_repo.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 110 | /     pub async fn get_last_trade_time(
[INFO] [stdout] 111 | |         &self,
[INFO] [stdout] 112 | |         user_id: &str,
[INFO] [stdout] 113 | |         exchange: &str,
[INFO] [stdout] 114 | |         symbol: &str,
[INFO] [stdout] 115 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stdout]     | |____________________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     pub time: DateTime<Utc>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     pub interval: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     pub open: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     pub high: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     pub low: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     pub close: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     pub volume: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:30:1
[INFO] [stdout]    |
[INFO] [stdout] 30 | / pub struct KlineRepo {
[INFO] [stdout] 31 | |     pool: PgPool,
[INFO] [stdout] 32 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/persistence/trade_repo.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/trade_repo.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub async fn insert(&self, user_id: &str, t: &NewTrade) -> Result<i64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:112:5
[INFO] [stdout]     |
[INFO] [stdout] 112 | /     pub async fn get_trades_for_symbol(
[INFO] [stdout] 113 | |         &self,
[INFO] [stdout] 114 | |         user_id: &str,
[INFO] [stdout] 115 | |         symbol: &str,
[INFO] [stdout] 116 | |     ) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stdout]     | |_________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:133:5
[INFO] [stdout]     |
[INFO] [stdout] 133 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:149:5
[INFO] [stdout]     |
[INFO] [stdout] 149 |     pub async fn list_symbols(&self, user_id: &str) -> Result<Vec<String>, DatasetError> {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:158:5
[INFO] [stdout]     |
[INFO] [stdout] 158 | /     pub async fn get_last_trade_time(
[INFO] [stdout] 159 | |         &self,
[INFO] [stdout] 160 | |         user_id: &str,
[INFO] [stdout] 161 | |         exchange: &str,
[INFO] [stdout] 162 | |         symbol: &str,
[INFO] [stdout] 163 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stdout]     | |____________________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | /     pub fn new(
[INFO] [stdout] 21 | |         api_key: &str,
[INFO] [stdout] 22 | |         secret_key: &str,
[INFO] [stdout] 23 | |         store: TradeRepo,
[INFO] [stdout] 24 | |         symbols: Vec<String>,
[INFO] [stdout] 25 | |         user_id: String,
[INFO] [stdout] 26 | |     ) -> Self {
[INFO] [stdout]    | |_____________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 46 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:11:1
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct FuturesTradeSync {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | /     pub fn new(
[INFO] [stdout] 20 | |         api_key: &str,
[INFO] [stdout] 21 | |         secret_key: &str,
[INFO] [stdout] 22 | |         store: FuturesTradeRepo,
[INFO] [stdout] 23 | |         symbols: Vec<String>,
[INFO] [stdout] 24 | |         user_id: String,
[INFO] [stdout] 25 | |     ) -> Self {
[INFO] [stdout]    | |_____________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `run_live_data` is never used
[INFO] [stdout]    --> crates/dataset/src/dataset/generic_kline.rs:104:14
[INFO] [stdout]     |
[INFO] [stdout]  89 | impl GenericKlineDataset {
[INFO] [stdout]     | ------------------------ associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 104 |     async fn run_live_data(_self: Arc<&Self>) -> anyhow::Result<u128> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEST_DATASOURCE_XML` is never used
[INFO] [stdout]    --> crates/dataset/src/dataset/generic_kline.rs:267:11
[INFO] [stdout]     |
[INFO] [stdout] 267 |     const TEST_DATASOURCE_XML: &str = r#"
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for the crate
[INFO] [stdout]  --> crates/dataset/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | / pub mod binance;
[INFO] [stdout] 2 | | pub mod dataset;
[INFO] [stdout] 3 | | pub mod domain;
[INFO] [stdout] 4 | | pub mod error;
[INFO] [stdout] 5 | | pub mod persistence;
[INFO] [stdout] 6 | | pub mod prelude;
[INFO] [stdout] 7 | | pub mod sync;
[INFO] [stdout]   | |_____________^
[INFO] [stdout]   |
[INFO] [stdout]   = note: requested on the command line with `-W missing-docs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod dataset;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub mod error;
[INFO] [stdout]   | ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:5:1
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub mod persistence;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/lib.rs:6:1
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub mod prelude;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/binance/mod.rs:5:1
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub mod market;
[INFO] [stdout]   | ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub order_id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub side: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub position_side: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub quote_qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 40 |     pub realized_pnl: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub commission: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub commission_asset: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub time: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 44 |     pub maker: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub buyer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:49:1
[INFO] [stdout]    |
[INFO] [stdout] 49 | / pub struct FuturesBinanceClient {
[INFO] [stdout] 50 | |     account: FuturesAccount,
[INFO] [stdout] 51 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout]    |
[INFO] [stdout]    = note: requested on the command line with `-W missing-debug-implementations`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/futures.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:16:1
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct OHLCVCandle(pub i64, pub f64, pub f64, pub f64, pub f64, pub f64);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:17:1
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub trait OHLCV {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     fn timestamp(&self) -> &i64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn open(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     fn high(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     fn low(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     fn close(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn volume(&self) -> &f64;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:53:1
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub trait KlineHistory: Send + Sync {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 | /     async fn get_hist<T: Send + Sync>(
[INFO] [stdout] 55 | |         &self,
[INFO] [stdout] 56 | |         symbol: &str,
[INFO] [stdout] 57 | |         interval: &Interval,
[INFO] [stdout] ...  |
[INFO] [stdout] 62 | |     where
[INFO] [stdout] 63 | |         T: Into<Option<u64>>;
[INFO] [stdout]    | |_____________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 65 |     fn kline_limit(&self) -> u16;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stdout]    |
[INFO] [stdout] 68 | / pub enum Exchange {
[INFO] [stdout] 69 | |     BINANCE(BinanceExchange),
[INFO] [stdout] 70 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an enum
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub enum Exchange {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/binance/kline.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     BINANCE(BinanceExchange),
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> crates/dataset/src/binance/market.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct BinanceExchange {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/market.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn new() -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     pub id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     pub order_id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 31 |     pub price: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub quote_qty: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub commission: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub commission_asset: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub time: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub is_buyer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub is_maker: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub is_best_match: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:43:1
[INFO] [stdout]    |
[INFO] [stdout] 43 | / pub struct BinanceClient {
[INFO] [stdout] 44 | |     account: Account,
[INFO] [stdout] 45 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/binance/spot.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/dataset/mod.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub mod factory;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct UniverseImpl {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub interval: Interval,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub fn ti_to_ts(&self, ti: u128) -> u128 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     pub fn ts_to_ti(&self, ts: u128) -> u128 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/dataset/mod.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub fn format_path(&self) -> String {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a macro
[INFO] [stdout]  --> crates/dataset/src/dataset/factory.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | macro_rules! register_datasource {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:30:1
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn make_dataset(cfg: DatasetConfig) -> Option<Box<dyn Dataset>> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]   --> crates/dataset/src/dataset/factory.rs:37:1
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub fn build_datasource_from_xml(xml_str: &str) -> anyhow::Result<Box<dyn Dataset>> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/persistence/mod.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod error;
[INFO] [stdout]   | ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/dataset/src/persistence/mod.rs:3:1
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub mod kline_repos;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]  --> crates/dataset/src/persistence/error.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 |     Database(#[from] SqlxError),
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     DuplicateKey {
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 12 |         symbol: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |         interval: String,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |         time: DateTime<Utc>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     PoolExhausted,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     InvalidData(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> crates/dataset/src/persistence/error.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Config(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct FuturesTradeRepo {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | /     pub async fn upsert_from_exchange(
[INFO] [stdout] 33 | |         &self,
[INFO] [stdout] 34 | |         user_id: &str,
[INFO] [stdout] 35 | |         trades: &[NewFuturesTrade],
[INFO] [stdout] 36 | |     ) -> Result<u64, DatasetError> {
[INFO] [stdout]    | |__________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/futures_trade_repo.rs:94:5
[INFO] [stdout]    |
[INFO] [stdout] 94 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<FuturesTrade>, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/futures_trade_repo.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 110 | /     pub async fn get_last_trade_time(
[INFO] [stdout] 111 | |         &self,
[INFO] [stdout] 112 | |         user_id: &str,
[INFO] [stdout] 113 | |         exchange: &str,
[INFO] [stdout] 114 | |         symbol: &str,
[INFO] [stdout] 115 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stdout]     | |____________________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     pub time: DateTime<Utc>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub symbol: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     pub interval: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     pub open: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     pub high: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     pub low: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     pub close: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     pub volume: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/dataset/src/persistence/kline_repos.rs:30:1
[INFO] [stdout]    |
[INFO] [stdout] 30 | / pub struct KlineRepo {
[INFO] [stdout] 31 | |     pool: PgPool,
[INFO] [stdout] 32 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/persistence/trade_repo.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/persistence/trade_repo.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub async fn insert(&self, user_id: &str, t: &NewTrade) -> Result<i64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:112:5
[INFO] [stdout]     |
[INFO] [stdout] 112 | /     pub async fn get_trades_for_symbol(
[INFO] [stdout] 113 | |         &self,
[INFO] [stdout] 114 | |         user_id: &str,
[INFO] [stdout] 115 | |         symbol: &str,
[INFO] [stdout] 116 | |     ) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stdout]     | |_________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:133:5
[INFO] [stdout]     |
[INFO] [stdout] 133 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:149:5
[INFO] [stdout]     |
[INFO] [stdout] 149 |     pub async fn list_symbols(&self, user_id: &str) -> Result<Vec<String>, DatasetError> {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> crates/dataset/src/persistence/trade_repo.rs:158:5
[INFO] [stdout]     |
[INFO] [stdout] 158 | /     pub async fn get_last_trade_time(
[INFO] [stdout] 159 | |         &self,
[INFO] [stdout] 160 | |         user_id: &str,
[INFO] [stdout] 161 | |         exchange: &str,
[INFO] [stdout] 162 | |         symbol: &str,
[INFO] [stdout] 163 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stdout]     | |____________________________________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | /     pub fn new(
[INFO] [stdout] 21 | |         api_key: &str,
[INFO] [stdout] 22 | |         secret_key: &str,
[INFO] [stdout] 23 | |         store: TradeRepo,
[INFO] [stdout] 24 | |         symbols: Vec<String>,
[INFO] [stdout] 25 | |         user_id: String,
[INFO] [stdout] 26 | |     ) -> Self {
[INFO] [stdout]    | |_____________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 46 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/binance_sync.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:11:1
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct FuturesTradeSync {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | /     pub fn new(
[INFO] [stdout] 20 | |         api_key: &str,
[INFO] [stdout] 21 | |         secret_key: &str,
[INFO] [stdout] 22 | |         store: FuturesTradeRepo,
[INFO] [stdout] 23 | |         symbols: Vec<String>,
[INFO] [stdout] 24 | |         user_id: String,
[INFO] [stdout] 25 | |     ) -> Self {
[INFO] [stdout]    | |_____________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> crates/dataset/src/sync/futures_sync.rs:65:5
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling portfolio v0.1.0 (/opt/rustwide/workdir/crates/portfolio)
[INFO] [stderr]    Compiling strategy v0.1.0 (/opt/rustwide/workdir/crates/strategy)
[INFO] [stdout] warning: function `crossover` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:551:4
[INFO] [stdout]     |
[INFO] [stdout] 551 | fn crossover(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossunder` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:565:4
[INFO] [stdout]     |
[INFO] [stdout] 565 | fn crossunder(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `export_tradingview_html` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/html_visualizer.rs:361:15
[INFO] [stdout]     |
[INFO] [stdout] 361 | pub(super) fn export_tradingview_html(
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for the crate
[INFO] [stdout]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | / pub mod indicator;
[INFO] [stdout] 2 | | pub mod strategy;
[INFO] [stdout]   | |_________________^
[INFO] [stdout]   |
[INFO] [stdout]   = note: requested on the command line with `-W missing-docs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod indicator;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/strategy/src/lib.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod strategy;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 67 |     pub open: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub high: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub low: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:70:5
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub close: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub volume: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:161:5
[INFO] [stdout]     |
[INFO] [stdout] 161 |     pub ma: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:162:5
[INFO] [stdout]     |
[INFO] [stdout] 162 |     pub ma_trend_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:163:5
[INFO] [stdout]     |
[INFO] [stdout] 163 |     pub ma_trend_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:166:5
[INFO] [stdout]     |
[INFO] [stdout] 166 |     pub top_fractals: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:167:5
[INFO] [stdout]     |
[INFO] [stdout] 167 |     pub bot_fractals: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:170:5
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub macd_line: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:171:5
[INFO] [stdout]     |
[INFO] [stdout] 171 |     pub macd_signal: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:172:5
[INFO] [stdout]     |
[INFO] [stdout] 172 |     pub macd_hist: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:173:5
[INFO] [stdout]     |
[INFO] [stdout] 173 |     pub macd_color_green: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:176:5
[INFO] [stdout]     |
[INFO] [stdout] 176 |     pub bearish_pinbar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:177:5
[INFO] [stdout]     |
[INFO] [stdout] 177 |     pub bullish_pinbar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:178:5
[INFO] [stdout]     |
[INFO] [stdout] 178 |     pub dark_cloud_cover: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:179:5
[INFO] [stdout]     |
[INFO] [stdout] 179 |     pub piercing_line: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:180:5
[INFO] [stdout]     |
[INFO] [stdout] 180 |     pub bearish_harami: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:181:5
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub bullish_harami: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:182:5
[INFO] [stdout]     |
[INFO] [stdout] 182 |     pub bearish_engulfing: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:183:5
[INFO] [stdout]     |
[INFO] [stdout] 183 |     pub bullish_engulfing: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:184:5
[INFO] [stdout]     |
[INFO] [stdout] 184 |     pub bearish_fractal_cross: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:185:5
[INFO] [stdout]     |
[INFO] [stdout] 185 |     pub bullish_fractal_cross: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:188:5
[INFO] [stdout]     |
[INFO] [stdout] 188 |     pub reversal_pinbar_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:189:5
[INFO] [stdout]     |
[INFO] [stdout] 189 |     pub reversal_pinbar_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:190:5
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub shaved_bar_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:191:5
[INFO] [stdout]     |
[INFO] [stdout] 191 |     pub shaved_bar_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:192:5
[INFO] [stdout]     |
[INFO] [stdout] 192 |     pub inside_bar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:193:5
[INFO] [stdout]     |
[INFO] [stdout] 193 |     pub outside_bar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:196:5
[INFO] [stdout]     |
[INFO] [stdout] 196 |     pub bar_color_up: Vec<bool>,   // Lime - confirmed bullish
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:197:5
[INFO] [stdout]     |
[INFO] [stdout] 197 |     pub bar_color_down: Vec<bool>, // Maroon - confirmed bearish
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:200:5
[INFO] [stdout]     |
[INFO] [stdout] 200 |     pub bar_alert: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:201:5
[INFO] [stdout]     |
[INFO] [stdout] 201 |     pub bar_alert_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:202:5
[INFO] [stdout]     |
[INFO] [stdout] 202 |     pub bar_alert_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]     --> crates/strategy/src/indicator/cds_trend.rs:1017:1
[INFO] [stdout]      |
[INFO] [stdout] 1017 | / pub fn write_html_visualization(
[INFO] [stdout] 1018 | |     path: &str,
[INFO] [stdout] 1019 | |     candles: &[Candle],
[INFO] [stdout] 1020 | |     out: &CdsTrendOutput,
[INFO] [stdout] 1021 | | ) -> std::io::Result<()> {
[INFO] [stdout]      | |________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]  --> crates/strategy/src/strategy.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub trait Strategy {}
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling api v0.1.0 (/opt/rustwide/workdir/crates/api)
[INFO] [stderr]    Compiling my_first_strategy v0.1.0 (/opt/rustwide/workdir/crates/my_first_strategy)
[INFO] [stdout] warning: function `crossover` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:551:4
[INFO] [stdout]     |
[INFO] [stdout] 551 | fn crossover(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossunder` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:565:4
[INFO] [stdout]     |
[INFO] [stdout] 565 | fn crossunder(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `export_tradingview_html` is never used
[INFO] [stdout]    --> crates/strategy/src/indicator/html_visualizer.rs:361:15
[INFO] [stdout]     |
[INFO] [stdout] 361 | pub(super) fn export_tradingview_html(
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for the crate
[INFO] [stdout]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | / pub mod indicator;
[INFO] [stdout] 2 | | pub mod strategy;
[INFO] [stdout]   | |_________________^
[INFO] [stdout]   |
[INFO] [stdout]   = note: requested on the command line with `-W missing-docs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod indicator;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> crates/strategy/src/lib.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod strategy;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 67 |     pub open: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub high: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub low: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:70:5
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub close: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> crates/strategy/src/indicator/cds_trend.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub volume: f64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:161:5
[INFO] [stdout]     |
[INFO] [stdout] 161 |     pub ma: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:162:5
[INFO] [stdout]     |
[INFO] [stdout] 162 |     pub ma_trend_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:163:5
[INFO] [stdout]     |
[INFO] [stdout] 163 |     pub ma_trend_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:166:5
[INFO] [stdout]     |
[INFO] [stdout] 166 |     pub top_fractals: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:167:5
[INFO] [stdout]     |
[INFO] [stdout] 167 |     pub bot_fractals: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:170:5
[INFO] [stdout]     |
[INFO] [stdout] 170 |     pub macd_line: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:171:5
[INFO] [stdout]     |
[INFO] [stdout] 171 |     pub macd_signal: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:172:5
[INFO] [stdout]     |
[INFO] [stdout] 172 |     pub macd_hist: Vec<Option<f64>>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:173:5
[INFO] [stdout]     |
[INFO] [stdout] 173 |     pub macd_color_green: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:176:5
[INFO] [stdout]     |
[INFO] [stdout] 176 |     pub bearish_pinbar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:177:5
[INFO] [stdout]     |
[INFO] [stdout] 177 |     pub bullish_pinbar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:178:5
[INFO] [stdout]     |
[INFO] [stdout] 178 |     pub dark_cloud_cover: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:179:5
[INFO] [stdout]     |
[INFO] [stdout] 179 |     pub piercing_line: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:180:5
[INFO] [stdout]     |
[INFO] [stdout] 180 |     pub bearish_harami: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:181:5
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub bullish_harami: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:182:5
[INFO] [stdout]     |
[INFO] [stdout] 182 |     pub bearish_engulfing: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:183:5
[INFO] [stdout]     |
[INFO] [stdout] 183 |     pub bullish_engulfing: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:184:5
[INFO] [stdout]     |
[INFO] [stdout] 184 |     pub bearish_fractal_cross: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:185:5
[INFO] [stdout]     |
[INFO] [stdout] 185 |     pub bullish_fractal_cross: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:188:5
[INFO] [stdout]     |
[INFO] [stdout] 188 |     pub reversal_pinbar_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:189:5
[INFO] [stdout]     |
[INFO] [stdout] 189 |     pub reversal_pinbar_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:190:5
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub shaved_bar_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:191:5
[INFO] [stdout]     |
[INFO] [stdout] 191 |     pub shaved_bar_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:192:5
[INFO] [stdout]     |
[INFO] [stdout] 192 |     pub inside_bar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:193:5
[INFO] [stdout]     |
[INFO] [stdout] 193 |     pub outside_bar: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:196:5
[INFO] [stdout]     |
[INFO] [stdout] 196 |     pub bar_color_up: Vec<bool>,   // Lime - confirmed bullish
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:197:5
[INFO] [stdout]     |
[INFO] [stdout] 197 |     pub bar_color_down: Vec<bool>, // Maroon - confirmed bearish
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:200:5
[INFO] [stdout]     |
[INFO] [stdout] 200 |     pub bar_alert: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:201:5
[INFO] [stdout]     |
[INFO] [stdout] 201 |     pub bar_alert_up: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> crates/strategy/src/indicator/cds_trend.rs:202:5
[INFO] [stdout]     |
[INFO] [stdout] 202 |     pub bar_alert_down: Vec<bool>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a function
[INFO] [stdout]     --> crates/strategy/src/indicator/cds_trend.rs:1017:1
[INFO] [stdout]      |
[INFO] [stdout] 1017 | / pub fn write_html_visualization(
[INFO] [stdout] 1018 | |     path: &str,
[INFO] [stdout] 1019 | |     candles: &[Candle],
[INFO] [stdout] 1020 | |     out: &CdsTrendOutput,
[INFO] [stdout] 1021 | | ) -> std::io::Result<()> {
[INFO] [stdout]      | |________________________^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]  --> crates/strategy/src/strategy.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub trait Strategy {}
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:10:33
[INFO] [stdout]    |
[INFO] [stdout] 10 |     let key = Key::<Aes256Gcm>::from_slice(key);
[INFO] [stdout]    |                                 ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossover` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:554:4
[INFO] [stdout]     |
[INFO] [stdout] 554 | fn crossover(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `crossunder` is never used
[INFO] [stdout]    --> crates/my_first_strategy/src/cds_trend.rs:568:4
[INFO] [stdout]     |
[INFO] [stdout] 568 | fn crossunder(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `length` is never read
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1023:5
[INFO] [stdout]      |
[INFO] [stdout] 1022 | struct EmaState {
[INFO] [stdout]      |        -------- field in this struct
[INFO] [stdout] 1023 |     length: usize,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `EmaState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `length` and `buffer` are never read
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1118:5
[INFO] [stdout]      |
[INFO] [stdout] 1117 | struct HullMaState {
[INFO] [stdout]      |        ----------- fields in this struct
[INFO] [stdout] 1118 |     length: usize,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1122 |     buffer: VecDeque<f64>,
[INFO] [stdout]      |     ^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `HullMaState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `reset` is never used
[INFO] [stdout]     --> crates/my_first_strategy/src/cds_trend.rs:1674:19
[INFO] [stdout]      |
[INFO] [stdout] 1294 | impl CdsTrendStream {
[INFO] [stdout]      | ------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1674 |     pub(crate) fn reset(&mut self) {
[INFO] [stdout]      |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:33:33
[INFO] [stdout]    |
[INFO] [stdout] 33 |     let key = Key::<Aes256Gcm>::from_slice(key);
[INFO] [stdout]    |                                 ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stdout]   --> crates/api/src/crypto.rs:35:24
[INFO] [stdout]    |
[INFO] [stdout] 35 |     let nonce = Nonce::from_slice(nonce_bytes);
[INFO] [stdout]    |                        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/my_first_strategy/src/main.rs:36:1
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct MyChannelHub {}
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: requested on the command line with `-W missing-debug-implementations`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stdout]   --> crates/my_first_strategy/src/main.rs:39:1
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct Payload {}
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `decrypt` is never used
[INFO] [stdout]   --> crates/api/src/crypto.rs:23:15
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub(crate) fn decrypt(encrypted: &str, key: &[u8]) -> Result<String, String> {
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 3m 12s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: binance-rs-async v1.3.3
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] running `Command { std: "docker" "inspect" "f6c0d23dadf93e6b05956f87b8060b1ba473c7cc1a5f99bebe6cc57f0a064a5c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f6c0d23dadf93e6b05956f87b8060b1ba473c7cc1a5f99bebe6cc57f0a064a5c", kill_on_drop: false }`
[INFO] [stdout] f6c0d23dadf93e6b05956f87b8060b1ba473c7cc1a5f99bebe6cc57f0a064a5c
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 237fca0daef38aac75c677025a643c48595589e227bbf35f0004616dbb12295f
[INFO] running `Command { std: "docker" "start" "-a" "237fca0daef38aac75c677025a643c48595589e227bbf35f0004616dbb12295f", kill_on_drop: false }`
[INFO] [stderr] warning: /opt/rustwide/workdir/crates/dataset/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr] warning: /opt/rustwide/workdir/crates/tradeon-core/Cargo.toml: version requirement `1.0.2+spec-1.1.0` for dependency `toml` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr] warning: unused import: `oneshot`
[INFO] [stderr]   --> crates/dataset/src/dataset/generic_kline.rs:14:27
[INFO] [stderr]    |
[INFO] [stderr] 14 | use tokio::sync::{RwLock, oneshot};
[INFO] [stderr]    |                           ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `run_live_data` is never used
[INFO] [stderr]    --> crates/dataset/src/dataset/generic_kline.rs:104:14
[INFO] [stderr]     |
[INFO] [stderr]  89 | impl GenericKlineDataset {
[INFO] [stderr]     | ------------------------ associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 104 |     async fn run_live_data(_self: Arc<&Self>) -> anyhow::Result<u128> {
[INFO] [stderr]     |              ^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for the crate
[INFO] [stderr]  --> crates/dataset/src/lib.rs:1:1
[INFO] [stderr]   |
[INFO] [stderr] 1 | / pub mod binance;
[INFO] [stderr] 2 | | pub mod dataset;
[INFO] [stderr] 3 | | pub mod domain;
[INFO] [stderr] 4 | | pub mod error;
[INFO] [stderr] 5 | | pub mod persistence;
[INFO] [stderr] 6 | | pub mod prelude;
[INFO] [stderr] 7 | | pub mod sync;
[INFO] [stderr]   | |_____________^
[INFO] [stderr]   |
[INFO] [stderr]   = note: requested on the command line with `-W missing-docs`
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a module
[INFO] [stderr]  --> crates/dataset/src/lib.rs:2:1
[INFO] [stderr]   |
[INFO] [stderr] 2 | pub mod dataset;
[INFO] [stderr]   | ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a module
[INFO] [stderr]  --> crates/dataset/src/lib.rs:4:1
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub mod error;
[INFO] [stderr]   | ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a module
[INFO] [stderr]  --> crates/dataset/src/lib.rs:5:1
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub mod persistence;
[INFO] [stderr]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a module
[INFO] [stderr]  --> crates/dataset/src/lib.rs:6:1
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub mod prelude;
[INFO] [stderr]   | ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a module
[INFO] [stderr]  --> crates/dataset/src/binance/mod.rs:5:1
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub mod market;
[INFO] [stderr]   | ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:32:5
[INFO] [stderr]    |
[INFO] [stderr] 32 |     pub id: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:33:5
[INFO] [stderr]    |
[INFO] [stderr] 33 |     pub symbol: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:34:5
[INFO] [stderr]    |
[INFO] [stderr] 34 |     pub order_id: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:35:5
[INFO] [stderr]    |
[INFO] [stderr] 35 |     pub side: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:36:5
[INFO] [stderr]    |
[INFO] [stderr] 36 |     pub position_side: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:37:5
[INFO] [stderr]    |
[INFO] [stderr] 37 |     pub price: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:38:5
[INFO] [stderr]    |
[INFO] [stderr] 38 |     pub qty: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:39:5
[INFO] [stderr]    |
[INFO] [stderr] 39 |     pub quote_qty: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:40:5
[INFO] [stderr]    |
[INFO] [stderr] 40 |     pub realized_pnl: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:41:5
[INFO] [stderr]    |
[INFO] [stderr] 41 |     pub commission: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:42:5
[INFO] [stderr]    |
[INFO] [stderr] 42 |     pub commission_asset: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:43:5
[INFO] [stderr]    |
[INFO] [stderr] 43 |     pub time: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:44:5
[INFO] [stderr]    |
[INFO] [stderr] 44 |     pub maker: bool,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:45:5
[INFO] [stderr]    |
[INFO] [stderr] 45 |     pub buyer: bool,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:49:1
[INFO] [stderr]    |
[INFO] [stderr] 49 | / pub struct FuturesBinanceClient {
[INFO] [stderr] 50 | |     account: FuturesAccount,
[INFO] [stderr] 51 | | }
[INFO] [stderr]    | |_^
[INFO] [stderr]    |
[INFO] [stderr]    = note: requested on the command line with `-W missing-debug-implementations`
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for an associated function
[INFO] [stderr]   --> crates/dataset/src/binance/futures.rs:54:5
[INFO] [stderr]    |
[INFO] [stderr] 54 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:16:1
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub struct OHLCVCandle(pub i64, pub f64, pub f64, pub f64, pub f64, pub f64);
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a trait
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:17:1
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub trait OHLCV {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 |     fn timestamp(&self) -> &i64;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:19:5
[INFO] [stderr]    |
[INFO] [stderr] 19 |     fn open(&self) -> &f64;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 20 |     fn high(&self) -> &f64;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:21:5
[INFO] [stderr]    |
[INFO] [stderr] 21 |     fn low(&self) -> &f64;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:22:5
[INFO] [stderr]    |
[INFO] [stderr] 22 |     fn close(&self) -> &f64;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:23:5
[INFO] [stderr]    |
[INFO] [stderr] 23 |     fn volume(&self) -> &f64;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a trait
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:53:1
[INFO] [stderr]    |
[INFO] [stderr] 53 | pub trait KlineHistory: Send + Sync {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:54:5
[INFO] [stderr]    |
[INFO] [stderr] 54 | /     async fn get_hist<T: Send + Sync>(
[INFO] [stderr] 55 | |         &self,
[INFO] [stderr] 56 | |         symbol: &str,
[INFO] [stderr] 57 | |         interval: &Interval,
[INFO] [stderr] ...  |
[INFO] [stderr] 62 | |     where
[INFO] [stderr] 63 | |         T: Into<Option<u64>>;
[INFO] [stderr]    | |_____________________________^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:65:5
[INFO] [stderr]    |
[INFO] [stderr] 65 |     fn kline_limit(&self) -> u16;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stderr]    |
[INFO] [stderr] 68 | / pub enum Exchange {
[INFO] [stderr] 69 | |     BINANCE(BinanceExchange),
[INFO] [stderr] 70 | | }
[INFO] [stderr]    | |_^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for an enum
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:68:1
[INFO] [stderr]    |
[INFO] [stderr] 68 | pub enum Exchange {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a variant
[INFO] [stderr]   --> crates/dataset/src/binance/kline.rs:69:5
[INFO] [stderr]    |
[INFO] [stderr] 69 |     BINANCE(BinanceExchange),
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct
[INFO] [stderr]  --> crates/dataset/src/binance/market.rs:9:1
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub struct BinanceExchange {
[INFO] [stderr]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for an associated function
[INFO] [stderr]   --> crates/dataset/src/binance/market.rs:19:5
[INFO] [stderr]    |
[INFO] [stderr] 19 |     pub fn new() -> Self {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:28:5
[INFO] [stderr]    |
[INFO] [stderr] 28 |     pub id: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:29:5
[INFO] [stderr]    |
[INFO] [stderr] 29 |     pub symbol: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:30:5
[INFO] [stderr]    |
[INFO] [stderr] 30 |     pub order_id: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:31:5
[INFO] [stderr]    |
[INFO] [stderr] 31 |     pub price: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:32:5
[INFO] [stderr]    |
[INFO] [stderr] 32 |     pub qty: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:33:5
[INFO] [stderr]    |
[INFO] [stderr] 33 |     pub quote_qty: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:34:5
[INFO] [stderr]    |
[INFO] [stderr] 34 |     pub commission: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:35:5
[INFO] [stderr]    |
[INFO] [stderr] 35 |     pub commission_asset: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:36:5
[INFO] [stderr]    |
[INFO] [stderr] 36 |     pub time: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:37:5
[INFO] [stderr]    |
[INFO] [stderr] 37 |     pub is_buyer: bool,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:38:5
[INFO] [stderr]    |
[INFO] [stderr] 38 |     pub is_maker: bool,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:39:5
[INFO] [stderr]    |
[INFO] [stderr] 39 |     pub is_best_match: bool,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:43:1
[INFO] [stderr]    |
[INFO] [stderr] 43 | / pub struct BinanceClient {
[INFO] [stderr] 44 | |     account: Account,
[INFO] [stderr] 45 | | }
[INFO] [stderr]    | |_^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for an associated function
[INFO] [stderr]   --> crates/dataset/src/binance/spot.rs:48:5
[INFO] [stderr]    |
[INFO] [stderr] 48 |     pub fn new(api_key: &str, secret_key: &str) -> Self {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a module
[INFO] [stderr]  --> crates/dataset/src/dataset/mod.rs:4:1
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub mod factory;
[INFO] [stderr]   | ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct
[INFO] [stderr]   --> crates/dataset/src/dataset/mod.rs:10:1
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub struct UniverseImpl {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/dataset/mod.rs:11:5
[INFO] [stderr]    |
[INFO] [stderr] 11 |     pub interval: Interval,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/dataset/mod.rs:14:5
[INFO] [stderr]    |
[INFO] [stderr] 14 |     pub fn ti_to_ts(&self, ti: u128) -> u128 {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/dataset/mod.rs:26:5
[INFO] [stderr]    |
[INFO] [stderr] 26 |     pub fn ts_to_ti(&self, ts: u128) -> u128 {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/dataset/mod.rs:38:5
[INFO] [stderr]    |
[INFO] [stderr] 38 |     pub fn format_path(&self) -> String {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a macro
[INFO] [stderr]  --> crates/dataset/src/dataset/factory.rs:8:1
[INFO] [stderr]   |
[INFO] [stderr] 8 | macro_rules! register_datasource {
[INFO] [stderr]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stderr]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct
[INFO] [stderr]   --> crates/dataset/src/dataset/factory.rs:18:1
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub struct DatasourceRegistration(pub &'static str, pub DatasetFactory);
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a function
[INFO] [stderr]   --> crates/dataset/src/dataset/factory.rs:30:1
[INFO] [stderr]    |
[INFO] [stderr] 30 | pub fn make_dataset(cfg: DatasetConfig) -> Option<Box<dyn Dataset>> {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a function
[INFO] [stderr]   --> crates/dataset/src/dataset/factory.rs:37:1
[INFO] [stderr]    |
[INFO] [stderr] 37 | pub fn build_datasource_from_xml(xml_str: &str) -> anyhow::Result<Box<dyn Dataset>> {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a module
[INFO] [stderr]  --> crates/dataset/src/persistence/mod.rs:1:1
[INFO] [stderr]   |
[INFO] [stderr] 1 | pub mod error;
[INFO] [stderr]   | ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a module
[INFO] [stderr]  --> crates/dataset/src/persistence/mod.rs:3:1
[INFO] [stderr]   |
[INFO] [stderr] 3 | pub mod kline_repos;
[INFO] [stderr]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a variant
[INFO] [stderr]  --> crates/dataset/src/persistence/error.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 |     Database(#[from] SqlxError),
[INFO] [stderr]   |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a variant
[INFO] [stderr]   --> crates/dataset/src/persistence/error.rs:11:5
[INFO] [stderr]    |
[INFO] [stderr] 11 |     DuplicateKey {
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/persistence/error.rs:12:9
[INFO] [stderr]    |
[INFO] [stderr] 12 |         symbol: String,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/persistence/error.rs:13:9
[INFO] [stderr]    |
[INFO] [stderr] 13 |         interval: String,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/persistence/error.rs:14:9
[INFO] [stderr]    |
[INFO] [stderr] 14 |         time: DateTime<Utc>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a variant
[INFO] [stderr]   --> crates/dataset/src/persistence/error.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 |     PoolExhausted,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a variant
[INFO] [stderr]   --> crates/dataset/src/persistence/error.rs:21:5
[INFO] [stderr]    |
[INFO] [stderr] 21 |     InvalidData(String),
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a variant
[INFO] [stderr]   --> crates/dataset/src/persistence/error.rs:24:5
[INFO] [stderr]    |
[INFO] [stderr] 24 |     Config(String),
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct
[INFO] [stderr]   --> crates/dataset/src/persistence/futures_trade_repo.rs:10:1
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub struct FuturesTradeRepo {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for an associated function
[INFO] [stderr]   --> crates/dataset/src/persistence/futures_trade_repo.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/persistence/futures_trade_repo.rs:32:5
[INFO] [stderr]    |
[INFO] [stderr] 32 | /     pub async fn upsert_from_exchange(
[INFO] [stderr] 33 | |         &self,
[INFO] [stderr] 34 | |         user_id: &str,
[INFO] [stderr] 35 | |         trades: &[NewFuturesTrade],
[INFO] [stderr] 36 | |     ) -> Result<u64, DatasetError> {
[INFO] [stderr]    | |__________________________________^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/persistence/futures_trade_repo.rs:94:5
[INFO] [stderr]    |
[INFO] [stderr] 94 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<FuturesTrade>, DatasetError> {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]    --> crates/dataset/src/persistence/futures_trade_repo.rs:110:5
[INFO] [stderr]     |
[INFO] [stderr] 110 | /     pub async fn get_last_trade_time(
[INFO] [stderr] 111 | |         &self,
[INFO] [stderr] 112 | |         user_id: &str,
[INFO] [stderr] 113 | |         exchange: &str,
[INFO] [stderr] 114 | |         symbol: &str,
[INFO] [stderr] 115 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stderr]     | |____________________________________________________^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/persistence/kline_repos.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 |     pub time: DateTime<Utc>,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/persistence/kline_repos.rs:19:5
[INFO] [stderr]    |
[INFO] [stderr] 19 |     pub symbol: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/persistence/kline_repos.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 20 |     pub interval: String,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/persistence/kline_repos.rs:21:5
[INFO] [stderr]    |
[INFO] [stderr] 21 |     pub open: f64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/persistence/kline_repos.rs:22:5
[INFO] [stderr]    |
[INFO] [stderr] 22 |     pub high: f64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/persistence/kline_repos.rs:23:5
[INFO] [stderr]    |
[INFO] [stderr] 23 |     pub low: f64,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/persistence/kline_repos.rs:24:5
[INFO] [stderr]    |
[INFO] [stderr] 24 |     pub close: f64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/dataset/src/persistence/kline_repos.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 |     pub volume: f64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stderr]   --> crates/dataset/src/persistence/kline_repos.rs:30:1
[INFO] [stderr]    |
[INFO] [stderr] 30 | / pub struct KlineRepo {
[INFO] [stderr] 31 | |     pool: PgPool,
[INFO] [stderr] 32 | | }
[INFO] [stderr]    | |_^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for an associated function
[INFO] [stderr]   --> crates/dataset/src/persistence/trade_repo.rs:16:5
[INFO] [stderr]    |
[INFO] [stderr] 16 |     pub fn new(pool: PgPool) -> Self {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/persistence/trade_repo.rs:33:5
[INFO] [stderr]    |
[INFO] [stderr] 33 |     pub async fn insert(&self, user_id: &str, t: &NewTrade) -> Result<i64, DatasetError> {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]    --> crates/dataset/src/persistence/trade_repo.rs:112:5
[INFO] [stderr]     |
[INFO] [stderr] 112 | /     pub async fn get_trades_for_symbol(
[INFO] [stderr] 113 | |         &self,
[INFO] [stderr] 114 | |         user_id: &str,
[INFO] [stderr] 115 | |         symbol: &str,
[INFO] [stderr] 116 | |     ) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stderr]     | |_________________________________________^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]    --> crates/dataset/src/persistence/trade_repo.rs:133:5
[INFO] [stderr]     |
[INFO] [stderr] 133 |     pub async fn get_all_trades(&self, user_id: &str) -> Result<Vec<Trade>, DatasetError> {
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]    --> crates/dataset/src/persistence/trade_repo.rs:149:5
[INFO] [stderr]     |
[INFO] [stderr] 149 |     pub async fn list_symbols(&self, user_id: &str) -> Result<Vec<String>, DatasetError> {
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]    --> crates/dataset/src/persistence/trade_repo.rs:158:5
[INFO] [stderr]     |
[INFO] [stderr] 158 | /     pub async fn get_last_trade_time(
[INFO] [stderr] 159 | |         &self,
[INFO] [stderr] 160 | |         user_id: &str,
[INFO] [stderr] 161 | |         exchange: &str,
[INFO] [stderr] 162 | |         symbol: &str,
[INFO] [stderr] 163 | |     ) -> Result<Option<DateTime<Utc>>, DatasetError> {
[INFO] [stderr]     | |____________________________________________________^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for an associated function
[INFO] [stderr]   --> crates/dataset/src/sync/binance_sync.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 20 | /     pub fn new(
[INFO] [stderr] 21 | |         api_key: &str,
[INFO] [stderr] 22 | |         secret_key: &str,
[INFO] [stderr] 23 | |         store: TradeRepo,
[INFO] [stderr] 24 | |         symbols: Vec<String>,
[INFO] [stderr] 25 | |         user_id: String,
[INFO] [stderr] 26 | |     ) -> Self {
[INFO] [stderr]    | |_____________^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/sync/binance_sync.rs:36:5
[INFO] [stderr]    |
[INFO] [stderr] 36 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/sync/binance_sync.rs:46:5
[INFO] [stderr]    |
[INFO] [stderr] 46 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/sync/binance_sync.rs:68:5
[INFO] [stderr]    |
[INFO] [stderr] 68 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct
[INFO] [stderr]   --> crates/dataset/src/sync/futures_sync.rs:11:1
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub struct FuturesTradeSync {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for an associated function
[INFO] [stderr]   --> crates/dataset/src/sync/futures_sync.rs:19:5
[INFO] [stderr]    |
[INFO] [stderr] 19 | /     pub fn new(
[INFO] [stderr] 20 | |         api_key: &str,
[INFO] [stderr] 21 | |         secret_key: &str,
[INFO] [stderr] 22 | |         store: FuturesTradeRepo,
[INFO] [stderr] 23 | |         symbols: Vec<String>,
[INFO] [stderr] 24 | |         user_id: String,
[INFO] [stderr] 25 | |     ) -> Self {
[INFO] [stderr]    | |_____________^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/sync/futures_sync.rs:35:5
[INFO] [stderr]    |
[INFO] [stderr] 35 |     pub async fn sync_all(&self) -> Result<u64, DatasetError> {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/sync/futures_sync.rs:45:5
[INFO] [stderr]    |
[INFO] [stderr] 45 |     pub async fn sync_symbol(&self, symbol: &str) -> Result<u64, DatasetError> {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a method
[INFO] [stderr]   --> crates/dataset/src/sync/futures_sync.rs:65:5
[INFO] [stderr]    |
[INFO] [stderr] 65 |     pub async fn run_periodic(self: std::sync::Arc<Self>, interval: Duration) {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `dataset` (lib) generated 104 warnings (run `cargo fix --lib -p dataset` to apply 1 suggestion)
[INFO] [stderr] warning: function `crossover` is never used
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:551:4
[INFO] [stderr]     |
[INFO] [stderr] 551 | fn crossover(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stderr]     |    ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `crossunder` is never used
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:565:4
[INFO] [stderr]     |
[INFO] [stderr] 565 | fn crossunder(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stderr]     |    ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `export_tradingview_html` is never used
[INFO] [stderr]    --> crates/strategy/src/indicator/html_visualizer.rs:361:15
[INFO] [stderr]     |
[INFO] [stderr] 361 | pub(super) fn export_tradingview_html(
[INFO] [stderr]     |               ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for the crate
[INFO] [stderr]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stderr]   |
[INFO] [stderr] 1 | / pub mod indicator;
[INFO] [stderr] 2 | | pub mod strategy;
[INFO] [stderr]   | |_________________^
[INFO] [stderr]   |
[INFO] [stderr]   = note: requested on the command line with `-W missing-docs`
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a module
[INFO] [stderr]  --> crates/strategy/src/lib.rs:1:1
[INFO] [stderr]   |
[INFO] [stderr] 1 | pub mod indicator;
[INFO] [stderr]   | ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a module
[INFO] [stderr]  --> crates/strategy/src/lib.rs:2:1
[INFO] [stderr]   |
[INFO] [stderr] 2 | pub mod strategy;
[INFO] [stderr]   | ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/strategy/src/indicator/cds_trend.rs:67:5
[INFO] [stderr]    |
[INFO] [stderr] 67 |     pub open: f64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/strategy/src/indicator/cds_trend.rs:68:5
[INFO] [stderr]    |
[INFO] [stderr] 68 |     pub high: f64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/strategy/src/indicator/cds_trend.rs:69:5
[INFO] [stderr]    |
[INFO] [stderr] 69 |     pub low: f64,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/strategy/src/indicator/cds_trend.rs:70:5
[INFO] [stderr]    |
[INFO] [stderr] 70 |     pub close: f64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]   --> crates/strategy/src/indicator/cds_trend.rs:71:5
[INFO] [stderr]    |
[INFO] [stderr] 71 |     pub volume: f64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:161:5
[INFO] [stderr]     |
[INFO] [stderr] 161 |     pub ma: Vec<Option<f64>>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:162:5
[INFO] [stderr]     |
[INFO] [stderr] 162 |     pub ma_trend_up: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:163:5
[INFO] [stderr]     |
[INFO] [stderr] 163 |     pub ma_trend_down: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:166:5
[INFO] [stderr]     |
[INFO] [stderr] 166 |     pub top_fractals: Vec<Option<f64>>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:167:5
[INFO] [stderr]     |
[INFO] [stderr] 167 |     pub bot_fractals: Vec<Option<f64>>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:170:5
[INFO] [stderr]     |
[INFO] [stderr] 170 |     pub macd_line: Vec<Option<f64>>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:171:5
[INFO] [stderr]     |
[INFO] [stderr] 171 |     pub macd_signal: Vec<Option<f64>>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:172:5
[INFO] [stderr]     |
[INFO] [stderr] 172 |     pub macd_hist: Vec<Option<f64>>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:173:5
[INFO] [stderr]     |
[INFO] [stderr] 173 |     pub macd_color_green: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:176:5
[INFO] [stderr]     |
[INFO] [stderr] 176 |     pub bearish_pinbar: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:177:5
[INFO] [stderr]     |
[INFO] [stderr] 177 |     pub bullish_pinbar: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:178:5
[INFO] [stderr]     |
[INFO] [stderr] 178 |     pub dark_cloud_cover: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:179:5
[INFO] [stderr]     |
[INFO] [stderr] 179 |     pub piercing_line: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:180:5
[INFO] [stderr]     |
[INFO] [stderr] 180 |     pub bearish_harami: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:181:5
[INFO] [stderr]     |
[INFO] [stderr] 181 |     pub bullish_harami: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:182:5
[INFO] [stderr]     |
[INFO] [stderr] 182 |     pub bearish_engulfing: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:183:5
[INFO] [stderr]     |
[INFO] [stderr] 183 |     pub bullish_engulfing: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:184:5
[INFO] [stderr]     |
[INFO] [stderr] 184 |     pub bearish_fractal_cross: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:185:5
[INFO] [stderr]     |
[INFO] [stderr] 185 |     pub bullish_fractal_cross: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:188:5
[INFO] [stderr]     |
[INFO] [stderr] 188 |     pub reversal_pinbar_up: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:189:5
[INFO] [stderr]     |
[INFO] [stderr] 189 |     pub reversal_pinbar_down: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:190:5
[INFO] [stderr]     |
[INFO] [stderr] 190 |     pub shaved_bar_up: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:191:5
[INFO] [stderr]     |
[INFO] [stderr] 191 |     pub shaved_bar_down: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:192:5
[INFO] [stderr]     |
[INFO] [stderr] 192 |     pub inside_bar: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:193:5
[INFO] [stderr]     |
[INFO] [stderr] 193 |     pub outside_bar: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:196:5
[INFO] [stderr]     |
[INFO] [stderr] 196 |     pub bar_color_up: Vec<bool>,   // Lime - confirmed bullish
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:197:5
[INFO] [stderr]     |
[INFO] [stderr] 197 |     pub bar_color_down: Vec<bool>, // Maroon - confirmed bearish
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:200:5
[INFO] [stderr]     |
[INFO] [stderr] 200 |     pub bar_alert: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:201:5
[INFO] [stderr]     |
[INFO] [stderr] 201 |     pub bar_alert_up: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a struct field
[INFO] [stderr]    --> crates/strategy/src/indicator/cds_trend.rs:202:5
[INFO] [stderr]     |
[INFO] [stderr] 202 |     pub bar_alert_down: Vec<bool>,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a function
[INFO] [stderr]     --> crates/strategy/src/indicator/cds_trend.rs:1017:1
[INFO] [stderr]      |
[INFO] [stderr] 1017 | / pub fn write_html_visualization(
[INFO] [stderr] 1018 | |     path: &str,
[INFO] [stderr] 1019 | |     candles: &[Candle],
[INFO] [stderr] 1020 | |     out: &CdsTrendOutput,
[INFO] [stderr] 1021 | | ) -> std::io::Result<()> {
[INFO] [stderr]      | |________________________^
[INFO] [stderr] 
[INFO] [stderr] warning: missing documentation for a trait
[INFO] [stderr]  --> crates/strategy/src/strategy.rs:1:1
[INFO] [stderr]   |
[INFO] [stderr] 1 | pub trait Strategy {}
[INFO] [stderr]   | ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `strategy` (lib) generated 43 warnings
[INFO] [stderr] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stderr]   --> crates/api/src/crypto.rs:10:33
[INFO] [stderr]    |
[INFO] [stderr] 10 |     let key = Key::<Aes256Gcm>::from_slice(key);
[INFO] [stderr]    |                                 ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stderr]   --> crates/api/src/crypto.rs:33:33
[INFO] [stderr]    |
[INFO] [stderr] 33 |     let key = Key::<Aes256Gcm>::from_slice(key);
[INFO] [stderr]    |                                 ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::<T, N>::from_slice`: please upgrade to generic-array 1.x
[INFO] [stderr]   --> crates/api/src/crypto.rs:35:24
[INFO] [stderr]    |
[INFO] [stderr] 35 |     let nonce = Nonce::from_slice(nonce_bytes);
[INFO] [stderr]    |                        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `decrypt` is never used
[INFO] [stderr]   --> crates/api/src/crypto.rs:23:15
[INFO] [stderr]    |
[INFO] [stderr] 23 | pub(crate) fn decrypt(encrypted: &str, key: &[u8]) -> Result<String, String> {
[INFO] [stderr]    |               ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `TEST_DATASOURCE_XML` is never used
[INFO] [stderr]    --> crates/dataset/src/dataset/generic_kline.rs:267:11
[INFO] [stderr]     |
[INFO] [stderr] 267 |     const TEST_DATASOURCE_XML: &str = r#"
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `crossover` is never used
[INFO] [stderr]    --> crates/my_first_strategy/src/cds_trend.rs:554:4
[INFO] [stderr]     |
[INFO] [stderr] 554 | fn crossover(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stderr]     |    ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `crossunder` is never used
[INFO] [stderr]    --> crates/my_first_strategy/src/cds_trend.rs:568:4
[INFO] [stderr]     |
[INFO] [stderr] 568 | fn crossunder(a: &[Option<f64>], b: &[Option<f64>]) -> Vec<bool> {
[INFO] [stderr]     |    ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `length` is never read
[INFO] [stderr]     --> crates/my_first_strategy/src/cds_trend.rs:1023:5
[INFO] [stderr]      |
[INFO] [stderr] 1022 | struct EmaState {
[INFO] [stderr]      |        -------- field in this struct
[INFO] [stderr] 1023 |     length: usize,
[INFO] [stderr]      |     ^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: `EmaState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `length` and `buffer` are never read
[INFO] [stderr]     --> crates/my_first_strategy/src/cds_trend.rs:1118:5
[INFO] [stderr]      |
[INFO] [stderr] 1117 | struct HullMaState {
[INFO] [stderr]      |        ----------- fields in this struct
[INFO] [stderr] 1118 |     length: usize,
[INFO] [stderr]      |     ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1122 |     buffer: VecDeque<f64>,
[INFO] [stderr]      |     ^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: `HullMaState` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: method `reset` is never used
[INFO] [stderr]     --> crates/my_first_strategy/src/cds_trend.rs:1674:19
[INFO] [stderr]      |
[INFO] [stderr] 1294 | impl CdsTrendStream {
[INFO] [stderr]      | ------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 1674 |     pub(crate) fn reset(&mut self) {
[INFO] [stderr]      |                   ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stderr]   --> crates/my_first_strategy/src/main.rs:36:1
[INFO] [stderr]    |
[INFO] [stderr] 36 | pub struct MyChannelHub {}
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: requested on the command line with `-W missing-debug-implementations`
[INFO] [stderr] 
[INFO] [stderr] warning: type does not implement `std::fmt::Debug`; consider adding `#[derive(Debug)]` or a manual implementation
[INFO] [stderr]   --> crates/my_first_strategy/src/main.rs:39:1
[INFO] [stderr]    |
[INFO] [stderr] 39 | pub struct Payload {}
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `api` (bin "api" test) generated 4 warnings
[INFO] [stderr] warning: `dataset` (lib test) generated 105 warnings (104 duplicates)
[INFO] [stderr] warning: `strategy` (lib test) generated 43 warnings (43 duplicates)
[INFO] [stderr] warning: `my_first_strategy` (bin "my_first_strategy" test) generated 7 warnings
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.10s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: binance-rs-async v1.3.3
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/api-b98f2781a8902a36)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/dataset-e488b07e7ac6eff0)
[INFO] [stdout] 
[INFO] [stdout] running 5 tests
[INFO] [stdout] test persistence::kline_repos::tests::test_insert_batch ... ignored
[INFO] [stdout] test persistence::kline_repos::tests::test_upsert_handles_duplicates ... ignored
[INFO] [stdout] test binance::market::tests::test_binance_kline::case_1 ... FAILED
[INFO] [stdout] test binance::market::tests::test_binance_kline::case_2 ... FAILED
[INFO] [stdout] test binance::market::tests::test_binance ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- binance::market::tests::test_binance_kline::case_1 stdout ----
[INFO] [stdout] Error: Binance kline error sending request for url (https://api.binance.com/api/v3/klines?symbol=BTCUSDT&interval=5m&limit=10&startTime=1761978600000000&endTime=1761980340000000): error trying to connect: dns error: failed to lookup address information: Temporary failure in name resolution
[INFO] [stdout] 
[INFO] [stdout] Stack backtrace:
[INFO] [stdout]    0: <anyhow::Error>::msg::<alloc::string::String>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/anyhow-1.0.100/src/backtrace.rs:27:14
[INFO] [stdout]    1: <dataset::binance::market::BinanceExchange as dataset::binance::kline::KlineHistory>::get_hist::<u64>::{closure#0}::{closure#3}
[INFO] [stdout]              at ./src/binance/market.rs:97:26
[INFO] [stdout]    2: <core::result::Result<alloc::vec::Vec<dataset::binance::kline::OHLCVCandle>, binance::errors::Error>>::map_err::<anyhow::Error, <dataset::binance::market::BinanceExchange as dataset::binance::kline::KlineHistory>::get_hist<u64>::{closure#0}::{closure#3}>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/result.rs:968:27
[INFO] [stdout]    3: <dataset::binance::market::BinanceExchange as dataset::binance::kline::KlineHistory>::get_hist::<u64>::{closure#0}
[INFO] [stdout]              at ./src/binance/market.rs:97:14
[INFO] [stdout]    4: <core::pin::Pin<alloc::boxed::Box<dyn core::future::future::Future<Output = core::result::Result<alloc::vec::Vec<dataset::binance::kline::OHLCVCandle>, anyhow::Error>> + core::marker::Send>> as core::future::future::Future>::poll
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/future/future.rs:133:9
[INFO] [stdout]    5: dataset::binance::market::tests::test_binance_kline::{closure#0}
[INFO] [stdout]              at ./src/binance/market.rs:141:14
[INFO] [stdout]    6: <core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>> as core::future::future::Future>::poll
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/future/future.rs:133:9
[INFO] [stdout]    7: <core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>> as core::future::future::Future>::poll
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/future/future.rs:133:9
[INFO] [stdout]    8: <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on::<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}::{closure#0}::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:742:70
[INFO] [stdout]    9: tokio::task::coop::with_budget::<core::task::poll::Poll<core::result::Result<(), anyhow::Error>>, <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/task/coop/mod.rs:167:5
[INFO] [stdout]   10: tokio::task::coop::budget::<core::task::poll::Poll<core::result::Result<(), anyhow::Error>>, <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/task/coop/mod.rs:133:5
[INFO] [stdout]   11: <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on::<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:742:25
[INFO] [stdout]   12: <tokio::runtime::scheduler::current_thread::Context>::enter::<core::task::poll::Poll<core::result::Result<(), anyhow::Error>>, <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}::{closure#0}>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:432:19
[INFO] [stdout]   13: <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on::<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:741:44
[INFO] [stdout]   14: <tokio::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:829:68
[INFO] [stdout]   15: <tokio::runtime::context::scoped::Scoped<tokio::runtime::scheduler::Context>>::set::<<tokio::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}, (alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>)>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   16: tokio::runtime::context::set_scheduler::<(alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>), <tokio::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}>::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/context.rs:176:38
[INFO] [stdout]   17: <std::thread::local::LocalKey<tokio::runtime::context::Context>>::try_with::<tokio::runtime::context::set_scheduler<(alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>), <tokio::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}>::{closure#0}, (alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>)>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/local.rs:462:12
[INFO] [stdout]   18: <std::thread::local::LocalKey<tokio::runtime::context::Context>>::with::<tokio::runtime::context::set_scheduler<(alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>), <tokio::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}>::{closure#0}, (alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>)>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/local.rs:426:20
[INFO] [stdout]   19: tokio::runtime::context::set_scheduler::<(alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>), <tokio::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/context.rs:176:17
[INFO] [stdout]   20: <tokio::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:829:27
[INFO] [stdout]   21: <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on::<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:729:24
[INFO] [stdout]   22: <tokio::runtime::scheduler::current_thread::CurrentThread>::block_on::<core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:200:33
[INFO] [stdout]   23: tokio::runtime::context::runtime::enter_runtime::<<tokio::runtime::scheduler::current_thread::CurrentThread>::block_on<core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>::{closure#0}, core::result::Result<(), anyhow::Error>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   24: <tokio::runtime::scheduler::current_thread::CurrentThread>::block_on::<core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:188:9
[INFO] [stdout]   25: <tokio::runtime::runtime::Runtime>::block_on_inner::<core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/runtime.rs:368:52
[INFO] [stdout]   26: <tokio::runtime::runtime::Runtime>::block_on::<core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/runtime.rs:342:18
[INFO] [stdout]   27: dataset::binance::market::tests::test_binance_kline
[INFO] [stdout]              at ./src/binance/market.rs:161:11
[INFO] [stdout]   28: dataset::binance::market::tests::test_binance_kline::case_1
[INFO] [stdout]              at ./src/binance/market.rs:114:5
[INFO] [stdout]   29: dataset::binance::market::tests::test_binance_kline::case_1::{closure#0}
[INFO] [stdout]              at ./src/binance/market.rs:131:10
[INFO] [stdout]   30: <dataset::binance::market::tests::test_binance_kline::case_1::{closure#0} as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   31: <fn() -> core::result::Result<(), alloc::string::String> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   32: test::__rust_begin_short_backtrace::<core::result::Result<(), alloc::string::String>, fn() -> core::result::Result<(), alloc::string::String>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:724:18
[INFO] [stdout]   33: test::run_test_in_process::{closure#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:74
[INFO] [stdout]   34: <core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   35: std::panicking::catch_unwind::do_call::<core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}>, core::result::Result<(), alloc::string::String>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   36: std::panicking::catch_unwind::<core::result::Result<(), alloc::string::String>, core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   37: std::panic::catch_unwind::<core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}>, core::result::Result<(), alloc::string::String>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   38: test::run_test_in_process
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:27
[INFO] [stdout]   39: test::run_test::{closure#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:668:43
[INFO] [stdout]   40: test::run_test::{closure#1}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:698:41
[INFO] [stdout]   41: std::sys::backtrace::__rust_begin_short_backtrace::<test::run_test::{closure#1}, ()>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   42: std::thread::lifecycle::spawn_unchecked::<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:70:13
[INFO] [stdout]   43: <core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   44: std::panicking::catch_unwind::do_call::<core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   45: std::panicking::catch_unwind::<(), core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   46: std::panic::catch_unwind::<core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   47: std::thread::lifecycle::spawn_unchecked::<test::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:68:26
[INFO] [stdout]   48: <std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1} as core::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   49: <alloc::boxed::Box<dyn core::ops::function::FnOnce<(), Output = ()> + core::marker::Send> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2271:9
[INFO] [stdout]   50: <std::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   51: <unknown>
[INFO] [stdout]   52: clone
[INFO] [stdout] 
[INFO] [stdout] ---- binance::market::tests::test_binance_kline::case_2 stdout ----
[INFO] [stdout] Error: Binance kline error sending request for url (https://api.binance.com/api/v3/klines?symbol=BTCUSDT&interval=1h&limit=24&startTime=1502924400000000&endTime=1503010800000000): error trying to connect: dns error: failed to lookup address information: Temporary failure in name resolution
[INFO] [stdout] 
[INFO] [stdout] Stack backtrace:
[INFO] [stdout]    0: <anyhow::Error>::msg::<alloc::string::String>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/anyhow-1.0.100/src/backtrace.rs:27:14
[INFO] [stdout]    1: <dataset::binance::market::BinanceExchange as dataset::binance::kline::KlineHistory>::get_hist::<u64>::{closure#0}::{closure#3}
[INFO] [stdout]              at ./src/binance/market.rs:97:26
[INFO] [stdout]    2: <core::result::Result<alloc::vec::Vec<dataset::binance::kline::OHLCVCandle>, binance::errors::Error>>::map_err::<anyhow::Error, <dataset::binance::market::BinanceExchange as dataset::binance::kline::KlineHistory>::get_hist<u64>::{closure#0}::{closure#3}>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/result.rs:968:27
[INFO] [stdout]    3: <dataset::binance::market::BinanceExchange as dataset::binance::kline::KlineHistory>::get_hist::<u64>::{closure#0}
[INFO] [stdout]              at ./src/binance/market.rs:97:14
[INFO] [stdout]    4: <core::pin::Pin<alloc::boxed::Box<dyn core::future::future::Future<Output = core::result::Result<alloc::vec::Vec<dataset::binance::kline::OHLCVCandle>, anyhow::Error>> + core::marker::Send>> as core::future::future::Future>::poll
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/future/future.rs:133:9
[INFO] [stdout]    5: dataset::binance::market::tests::test_binance_kline::{closure#0}
[INFO] [stdout]              at ./src/binance/market.rs:141:14
[INFO] [stdout]    6: <core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>> as core::future::future::Future>::poll
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/future/future.rs:133:9
[INFO] [stdout]    7: <core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>> as core::future::future::Future>::poll
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/future/future.rs:133:9
[INFO] [stdout]    8: <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on::<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}::{closure#0}::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:742:70
[INFO] [stdout]    9: tokio::task::coop::with_budget::<core::task::poll::Poll<core::result::Result<(), anyhow::Error>>, <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/task/coop/mod.rs:167:5
[INFO] [stdout]   10: tokio::task::coop::budget::<core::task::poll::Poll<core::result::Result<(), anyhow::Error>>, <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}::{closure#0}::{closure#0}>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/task/coop/mod.rs:133:5
[INFO] [stdout]   11: <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on::<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:742:25
[INFO] [stdout]   12: <tokio::runtime::scheduler::current_thread::Context>::enter::<core::task::poll::Poll<core::result::Result<(), anyhow::Error>>, <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}::{closure#0}>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:432:19
[INFO] [stdout]   13: <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on::<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:741:44
[INFO] [stdout]   14: <tokio::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:829:68
[INFO] [stdout]   15: <tokio::runtime::context::scoped::Scoped<tokio::runtime::scheduler::Context>>::set::<<tokio::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}, (alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>)>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/context/scoped.rs:40:9
[INFO] [stdout]   16: tokio::runtime::context::set_scheduler::<(alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>), <tokio::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}>::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/context.rs:176:38
[INFO] [stdout]   17: <std::thread::local::LocalKey<tokio::runtime::context::Context>>::try_with::<tokio::runtime::context::set_scheduler<(alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>), <tokio::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}>::{closure#0}, (alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>)>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/local.rs:462:12
[INFO] [stdout]   18: <std::thread::local::LocalKey<tokio::runtime::context::Context>>::with::<tokio::runtime::context::set_scheduler<(alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>), <tokio::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}>::{closure#0}, (alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>)>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/local.rs:426:20
[INFO] [stdout]   19: tokio::runtime::context::set_scheduler::<(alloc::boxed::Box<tokio::runtime::scheduler::current_thread::Core>, core::option::Option<core::result::Result<(), anyhow::Error>>), <tokio::runtime::scheduler::current_thread::CoreGuard>::enter<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>::{closure#0}>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/context.rs:176:17
[INFO] [stdout]   20: <tokio::runtime::scheduler::current_thread::CoreGuard>::enter::<<tokio::runtime::scheduler::current_thread::CoreGuard>::block_on<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>::{closure#0}, core::option::Option<core::result::Result<(), anyhow::Error>>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:829:27
[INFO] [stdout]   21: <tokio::runtime::scheduler::current_thread::CoreGuard>::block_on::<core::pin::Pin<&mut core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:729:24
[INFO] [stdout]   22: <tokio::runtime::scheduler::current_thread::CurrentThread>::block_on::<core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>::{closure#0}
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:200:33
[INFO] [stdout]   23: tokio::runtime::context::runtime::enter_runtime::<<tokio::runtime::scheduler::current_thread::CurrentThread>::block_on<core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>::{closure#0}, core::result::Result<(), anyhow::Error>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/context/runtime.rs:65:16
[INFO] [stdout]   24: <tokio::runtime::scheduler::current_thread::CurrentThread>::block_on::<core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/scheduler/current_thread/mod.rs:188:9
[INFO] [stdout]   25: <tokio::runtime::runtime::Runtime>::block_on_inner::<core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/runtime.rs:368:52
[INFO] [stdout]   26: <tokio::runtime::runtime::Runtime>::block_on::<core::pin::Pin<&mut dyn core::future::future::Future<Output = core::result::Result<(), anyhow::Error>>>>
[INFO] [stdout]              at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.48.0/src/runtime/runtime.rs:342:18
[INFO] [stdout]   27: dataset::binance::market::tests::test_binance_kline
[INFO] [stdout]              at ./src/binance/market.rs:161:11
[INFO] [stdout]   28: dataset::binance::market::tests::test_binance_kline::case_2
[INFO] [stdout]              at ./src/binance/market.rs:114:5
[INFO] [stdout]   29: dataset::binance::market::tests::test_binance_kline::case_2::{closure#0}
[INFO] [stdout]              at ./src/binance/market.rs:131:10
[INFO] [stdout]   30: <dataset::binance::market::tests::test_binance_kline::case_2::{closure#0} as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   31: <fn() -> core::result::Result<(), alloc::string::String> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   32: test::__rust_begin_short_backtrace::<core::result::Result<(), alloc::string::String>, fn() -> core::result::Result<(), alloc::string::String>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:724:18
[INFO] [stdout]   33: test::run_test_in_process::{closure#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:74
[INFO] [stdout]   34: <core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   35: std::panicking::catch_unwind::do_call::<core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}>, core::result::Result<(), alloc::string::String>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   36: std::panicking::catch_unwind::<core::result::Result<(), alloc::string::String>, core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   37: std::panic::catch_unwind::<core::panic::unwind_safe::AssertUnwindSafe<test::run_test_in_process::{closure#0}>, core::result::Result<(), alloc::string::String>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   38: test::run_test_in_process
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:27
[INFO] [stdout]   39: test::run_test::{closure#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:668:43
[INFO] [stdout]   40: test::run_test::{closure#1}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:698:41
[INFO] [stdout]   41: std::sys::backtrace::__rust_begin_short_backtrace::<test::run_test::{closure#1}, ()>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   42: std::thread::lifecycle::spawn_unchecked::<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:70:13
[INFO] [stdout]   43: <core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   44: std::panicking::catch_unwind::do_call::<core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   45: std::panicking::catch_unwind::<(), core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   46: std::panic::catch_unwind::<core::panic::unwind_safe::AssertUnwindSafe<std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   47: std::thread::lifecycle::spawn_unchecked::<test::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:68:26
[INFO] [stdout]   48: <std::thread::lifecycle::spawn_unchecked<test::run_test::{closure#1}, ()>::{closure#1} as core::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   49: <alloc::boxed::Box<dyn core::ops::function::FnOnce<(), Output = ()> + core::marker::Send> as core::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2271:9
[INFO] [stdout]   50: <std::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]              at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   51: <unknown>
[INFO] [stdout]   52: clone
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     binance::market::tests::test_binance_kline::case_1
[INFO] [stdout]     binance::market::tests::test_binance_kline::case_2
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 1 passed; 2 failed; 2 ignored; 0 measured; 0 filtered out; finished in 0.33s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `-p dataset --lib`
[INFO] running `Command { std: "docker" "inspect" "237fca0daef38aac75c677025a643c48595589e227bbf35f0004616dbb12295f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "237fca0daef38aac75c677025a643c48595589e227bbf35f0004616dbb12295f", kill_on_drop: false }`
[INFO] [stdout] 237fca0daef38aac75c677025a643c48595589e227bbf35f0004616dbb12295f
