[INFO] fetching crate omni-llm-kit 0.1.1... [INFO] testing omni-llm-kit-0.1.1 against beta-2025-10-28 for beta-1.92-2 [INFO] extracting crate omni-llm-kit 0.1.1 into /workspace/builds/worker-6-tc2/source [INFO] started tweaking crates.io crate omni-llm-kit 0.1.1 [INFO] finished tweaking crates.io crate omni-llm-kit 0.1.1 [INFO] tweaked toml for crates.io crate omni-llm-kit 0.1.1 written to /workspace/builds/worker-6-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate omni-llm-kit 0.1.1 on toolchain beta-2025-10-28 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-10-28" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate omni-llm-kit 0.1.1 already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-10-28" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-10-28" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 4437bd860eb440712aff090d2c660e82c61a014a2e7249eb4bf6ced307f5516f [INFO] running `Command { std: "docker" "start" "-a" "4437bd860eb440712aff090d2c660e82c61a014a2e7249eb4bf6ced307f5516f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "4437bd860eb440712aff090d2c660e82c61a014a2e7249eb4bf6ced307f5516f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4437bd860eb440712aff090d2c660e82c61a014a2e7249eb4bf6ced307f5516f", kill_on_drop: false }` [INFO] [stdout] 4437bd860eb440712aff090d2c660e82c61a014a2e7249eb4bf6ced307f5516f [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-10-28" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 25a04bb929dfd811fc31b575b590d9885600330afba9d441704b71d65d67565d [INFO] running `Command { std: "docker" "start" "-a" "25a04bb929dfd811fc31b575b590d9885600330afba9d441704b71d65d67565d", kill_on_drop: false }` [INFO] [stderr] Compiling syn v2.0.106 [INFO] [stderr] Compiling dunce v1.0.5 [INFO] [stderr] Compiling zeroize v1.8.1 [INFO] [stderr] Compiling aws-lc-rs v1.13.3 [INFO] [stderr] Compiling jobserver v0.1.33 [INFO] [stderr] Compiling parking_lot_core v0.9.11 [INFO] [stderr] Compiling mio v1.0.4 [INFO] [stderr] Compiling signal-hook-registry v1.4.6 [INFO] [stderr] Compiling socket2 v0.6.0 [INFO] [stderr] Compiling getrandom v0.2.16 [INFO] [stderr] Compiling serde v1.0.219 [INFO] [stderr] Compiling rustls v0.23.31 [INFO] [stderr] Compiling bitflags v2.9.2 [INFO] [stderr] Compiling regex-syntax v0.8.5 [INFO] [stderr] Compiling getrandom v0.3.3 [INFO] [stderr] Compiling serde_json v1.0.142 [INFO] [stderr] Compiling bit-vec v0.6.3 [INFO] [stderr] Compiling convert_case v0.7.1 [INFO] [stderr] Compiling unicode-xid v0.2.6 [INFO] [stderr] Compiling parking_lot v0.12.4 [INFO] [stderr] Compiling rustls-pki-types v1.12.0 [INFO] [stderr] Compiling bit-set v0.5.3 [INFO] [stderr] Compiling cc v1.2.33 [INFO] [stderr] Compiling thiserror v2.0.15 [INFO] [stderr] Compiling anyhow v1.0.99 [INFO] [stderr] Compiling dyn-clone v1.0.20 [INFO] [stderr] Compiling global-registry v0.1.0 [INFO] [stderr] Compiling partial-json-fixer v0.5.3 [INFO] [stderr] Compiling rustc-hash v2.1.1 [INFO] [stderr] Compiling dotenvy v0.15.7 [INFO] [stderr] Compiling arc-cow v0.1.0 [INFO] [stderr] Compiling webpki-roots v1.0.2 [INFO] [stderr] Compiling rustls-native-certs v0.8.1 [INFO] [stderr] Compiling cmake v0.1.54 [INFO] [stderr] Compiling aws-lc-sys v0.30.0 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling openssl-sys v0.9.109 [INFO] [stderr] Compiling openssl v0.10.73 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling regex-automata v0.4.9 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling serde_derive_internals v0.29.1 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.0 [INFO] [stderr] Compiling zerovec-derive v0.11.1 [INFO] [stderr] Compiling tokio-macros v2.5.0 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling ref-cast-impl v1.0.24 [INFO] [stderr] Compiling schemars_derive v1.0.4 [INFO] [stderr] Compiling tokio v1.47.1 [INFO] [stderr] Compiling derive_more-impl v2.0.1 [INFO] [stderr] Compiling strum_macros v0.27.2 [INFO] [stderr] Compiling ref-cast v1.0.24 [INFO] [stderr] Compiling thiserror-impl v2.0.15 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling fancy-regex v0.13.0 [INFO] [stderr] Compiling bstr v1.12.0 [INFO] [stderr] Compiling yoke v0.8.0 [INFO] [stderr] Compiling zerotrie v0.2.2 [INFO] [stderr] Compiling zerovec v0.11.4 [INFO] [stderr] Compiling regex v1.11.1 [INFO] [stderr] Compiling tiktoken-rs v0.7.0 [INFO] [stderr] Compiling strum v0.27.2 [INFO] [stderr] Compiling tinystr v0.8.1 [INFO] [stderr] Compiling potential_utf v0.1.2 [INFO] [stderr] Compiling icu_collections v2.0.0 [INFO] [stderr] Compiling icu_locale_core v2.0.0 [INFO] [stderr] Compiling icu_provider v2.0.0 [INFO] [stderr] Compiling futures-executor v0.3.31 [INFO] [stderr] Compiling futures v0.3.31 [INFO] [stderr] Compiling icu_normalizer v2.0.0 [INFO] [stderr] Compiling icu_properties v2.0.1 [INFO] [stderr] Compiling derive_more v2.0.1 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling idna v1.0.3 [INFO] [stderr] Compiling rustls-webpki v0.103.4 [INFO] [stderr] Compiling url v2.5.4 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling uuid v1.18.0 [INFO] [stderr] Compiling schemars v1.0.4 [INFO] [stderr] Compiling tokio-util v0.7.16 [INFO] [stderr] Compiling tower v0.5.2 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling tower-http v0.6.6 [INFO] [stderr] Compiling h2 v0.4.12 [INFO] [stderr] Compiling tokio-rustls v0.26.2 [INFO] [stderr] Compiling hyper v1.6.0 [INFO] [stderr] Compiling hyper-util v0.1.16 [INFO] [stderr] Compiling rustls-platform-verifier v0.5.3 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling hyper-rustls v0.27.7 [INFO] [stderr] Compiling reqwest v0.12.23 [INFO] [stderr] Compiling omni-llm-kit v0.1.1 (/opt/rustwide/workdir) [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/anthropic/anthropic.rs:17:12 [INFO] [stdout] | [INFO] [stdout] 17 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: `#[warn(unexpected_cfgs)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/anthropic/anthropic.rs:25:12 [INFO] [stdout] | [INFO] [stdout] 25 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/anthropic/anthropic.rs:35:12 [INFO] [stdout] | [INFO] [stdout] 35 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/openai/openai.rs:49:12 [INFO] [stdout] | [INFO] [stdout] 49 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `utils::*` [INFO] [stdout] --> src/common/mod.rs:6:9 [INFO] [stdout] | [INFO] [stdout] 6 | pub use utils::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:8:7 [INFO] [stdout] | [INFO] [stdout] 8 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:293:7 [INFO] [stdout] | [INFO] [stdout] 293 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:301:7 [INFO] [stdout] | [INFO] [stdout] 301 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:306:7 [INFO] [stdout] | [INFO] [stdout] 306 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:343:7 [INFO] [stdout] | [INFO] [stdout] 343 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:350:7 [INFO] [stdout] | [INFO] [stdout] 350 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `de::DeserializeOwned` [INFO] [stdout] --> src/model/types.rs:5:37 [INFO] [stdout] | [INFO] [stdout] 5 | use serde::{Deserialize, Serialize, de::DeserializeOwned}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ToolResultPart` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | ToolResultPart, Usage, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Context as _` and `anyhow` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:5:14 [INFO] [stdout] | [INFO] [stdout] 5 | use anyhow::{Context as _, anyhow}; [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `BTreeMap` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:8:24 [INFO] [stdout] | [INFO] [stdout] 8 | use std::collections::{BTreeMap, HashMap}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `strum::IntoEnumIterator` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | use strum::IntoEnumIterator; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Mutex` [INFO] [stdout] --> src/models/openai_provider/provider.rs:8:22 [INFO] [stdout] | [INFO] [stdout] 8 | use std::sync::{Arc, Mutex}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `anyhow::anyhow` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use anyhow::anyhow; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `futures_core::Stream` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use futures_core::Stream; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `futures_core::future::BoxFuture` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use futures_core::future::BoxFuture; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::pin::Pin` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::pin::Pin; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::info` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 21 | use log::info; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `strum::EnumIter` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | use strum::EnumIter; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `future::BoxFuture` [INFO] [stdout] --> src/models/openai_provider/event_mapper.rs:6:37 [INFO] [stdout] | [INFO] [stdout] 6 | use futures::{FutureExt, StreamExt, future::BoxFuture}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: ambiguous glob re-exports [INFO] [stdout] --> src/models/mod.rs:6:9 [INFO] [stdout] | [INFO] [stdout] 5 | pub use openai_provider::*; [INFO] [stdout] | ------------------ but the name `AvailableModel` in the type namespace is also re-exported here [INFO] [stdout] 6 | pub use anthropic_provider::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ the name `AvailableModel` in the type namespace is first re-exported here [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(ambiguous_glob_reexports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `LazyLock` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use std::sync::{LazyLock, OnceLock}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `borrow::Cow` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:3:27 [INFO] [stdout] | [INFO] [stdout] 3 | use std::{any::type_name, borrow::Cow, mem, pin::Pin, task::Poll, time::Duration}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `redirect` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | redirect, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `LanguageModelRequest` [INFO] [stdout] --> src/tool/tool.rs:3:40 [INFO] [stdout] | [INFO] [stdout] 3 | LanguageModel, LanguageModelImage, LanguageModelRequest, LanguageModelToolSchemaFormat, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `async_trait::async_trait` [INFO] [stdout] --> src/tool/tool.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use async_trait::async_trait; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt` [INFO] [stdout] --> src/tool/tool.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::fmt; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Formatter` [INFO] [stdout] --> src/tool/tool.rs:7:23 [INFO] [stdout] | [INFO] [stdout] 7 | use std::fmt::{Debug, Formatter}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Deref` [INFO] [stdout] --> src/tool/tool.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::ops::Deref; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::sync::Arc` [INFO] [stdout] --> src/tool/tool.rs:10:5 [INFO] [stdout] | [INFO] [stdout] 10 | use std::sync::Arc; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::task::JoinHandle` [INFO] [stdout] --> src/tool/tool.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use tokio::task::JoinHandle; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DerefMut` and `Deref` [INFO] [stdout] --> src/tool/tool_registry.rs:2:19 [INFO] [stdout] | [INFO] [stdout] 2 | use derive_more::{Deref, DerefMut}; [INFO] [stdout] | ^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: ambiguous glob re-exports [INFO] [stdout] --> src/lib.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 11 | pub use models::*; [INFO] [stdout] | ^^^^^^^^^ the name `OPEN_AI_PROVIDER_ID` in the value namespace is first re-exported here [INFO] [stdout] 12 | pub use model::*; [INFO] [stdout] | -------- but the name `OPEN_AI_PROVIDER_ID` in the value namespace is also re-exported here [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: ambiguous glob re-exports [INFO] [stdout] --> src/lib.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 11 | pub use models::*; [INFO] [stdout] | ^^^^^^^^^ the name `OPEN_AI_PROVIDER_NAME` in the value namespace is first re-exported here [INFO] [stdout] 12 | pub use model::*; [INFO] [stdout] | -------- but the name `OPEN_AI_PROVIDER_NAME` in the value namespace is also re-exported here [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Tool` [INFO] [stdout] --> src/tool/tool_registry.rs:1:13 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::{Tool, ToolDyn}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `LanguageModel` [INFO] [stdout] --> src/tool/tool.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | LanguageModel, LanguageModelImage, LanguageModelRequest, LanguageModelToolSchemaFormat, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `FutureExt` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:20:20 [INFO] [stdout] | [INFO] [stdout] 20 | use futures_util::{FutureExt, StreamExt}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `FutureExt` [INFO] [stdout] --> src/models/openai_provider/event_mapper.rs:6:15 [INFO] [stdout] | [INFO] [stdout] 6 | use futures::{FutureExt, StreamExt, future::BoxFuture}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `image_obj` [INFO] [stdout] --> src/model/types.rs:157:33 [INFO] [stdout] | [INFO] [stdout] 157 | if let Some(image_obj) = value.as_object() { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_image_obj` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `image` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:220:43 [INFO] [stdout] | [INFO] [stdout] 220 | MessageContent::Image(image) => { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_image` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `stop_reason` [INFO] [stdout] --> src/models/openai_provider/event_mapper.rs:104:18 [INFO] [stdout] | [INFO] [stdout] 104 | Some(stop_reason) => { [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stop_reason` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `redirect_policy` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:220:21 [INFO] [stdout] | [INFO] [stdout] 220 | if let Some(redirect_policy) = parts.extensions.get::() { [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_redirect_policy` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `default_true` is never used [INFO] [stdout] --> src/common/serde_utils.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | pub const fn default_true() -> 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 `post_inc` is never used [INFO] [stdout] --> src/common/utils.rs:3:8 [INFO] [stdout] | [INFO] [stdout] 3 | pub fn post_inc + AddAssign + Copy>(value: &mut T) -> T { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `truncate_lines_to_byte_limit` is never used [INFO] [stdout] --> src/common/utils.rs:10:8 [INFO] [stdout] | [INFO] [stdout] 10 | pub fn truncate_lines_to_byte_limit(s: &str, max_bytes: usize) -> &str { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `truncate_to_byte_limit` is never used [INFO] [stdout] --> src/common/utils.rs:29:8 [INFO] [stdout] | [INFO] [stdout] 29 | pub fn truncate_to_byte_limit(s: &str, max_bytes: usize) -> &str { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `ANTHROPIC_API_KEY_VAR` is never used [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:91:7 [INFO] [stdout] | [INFO] [stdout] 91 | const ANTHROPIC_API_KEY_VAR: &str = "ANTHROPIC_API_KEY"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AvailableModel` is never constructed [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:246:12 [INFO] [stdout] | [INFO] [stdout] 246 | pub struct AvailableModel { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `ANTHROPIC_API_URL` is never used [INFO] [stdout] --> src/anthropic/anthropic.rs:15:11 [INFO] [stdout] | [INFO] [stdout] 15 | pub const ANTHROPIC_API_URL: &str = "https://api.anthropic.com"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `complete` is never used [INFO] [stdout] --> src/anthropic/anthropic.rs:362:14 [INFO] [stdout] | [INFO] [stdout] 362 | pub async fn complete( [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `limit`, `remaining`, and `reset` are never read [INFO] [stdout] --> src/anthropic/anthropic.rs:422:9 [INFO] [stdout] | [INFO] [stdout] 421 | pub struct RateLimit { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] 422 | pub limit: usize, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 423 | pub remaining: usize, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 424 | pub reset: DateTime, [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `RateLimit` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `requests`, `tokens`, `input_tokens`, and `output_tokens` are never read [INFO] [stdout] --> src/anthropic/anthropic.rs:454:9 [INFO] [stdout] | [INFO] [stdout] 452 | pub struct RateLimitInfo { [INFO] [stdout] | ------------- fields in this struct [INFO] [stdout] 453 | pub retry_after: Option, [INFO] [stdout] 454 | pub requests: Option, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 455 | pub tokens: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 456 | pub input_tokens: Option, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 457 | pub output_tokens: Option, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `RateLimitInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `OPEN_AI_API_URL` is never used [INFO] [stdout] --> src/openai/openai.rs:9:11 [INFO] [stdout] | [INFO] [stdout] 9 | pub const OPEN_AI_API_URL: &str = "https://api.openai.com/v1"; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `OpenAiEmbeddingModel` is never used [INFO] [stdout] --> src/openai/openai.rs:465:10 [INFO] [stdout] | [INFO] [stdout] 465 | pub enum OpenAiEmbeddingModel { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `OpenAiEmbeddingRequest` is never constructed [INFO] [stdout] --> src/openai/openai.rs:473:8 [INFO] [stdout] | [INFO] [stdout] 473 | struct OpenAiEmbeddingRequest<'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `OpenAiEmbeddingResponse` is never constructed [INFO] [stdout] --> src/openai/openai.rs:479:12 [INFO] [stdout] | [INFO] [stdout] 479 | pub struct OpenAiEmbeddingResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `OpenAiEmbedding` is never constructed [INFO] [stdout] --> src/openai/openai.rs:484:12 [INFO] [stdout] | [INFO] [stdout] 484 | pub struct OpenAiEmbedding { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `embed` is never used [INFO] [stdout] --> src/openai/openai.rs:488:8 [INFO] [stdout] | [INFO] [stdout] 488 | pub fn embed<'a>( [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 38s [INFO] running `Command { std: "docker" "inspect" "25a04bb929dfd811fc31b575b590d9885600330afba9d441704b71d65d67565d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "25a04bb929dfd811fc31b575b590d9885600330afba9d441704b71d65d67565d", kill_on_drop: false }` [INFO] [stdout] 25a04bb929dfd811fc31b575b590d9885600330afba9d441704b71d65d67565d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-10-28" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 858bac8a732d8aa14fd61637cc06e23b94fcf24d63eed8a8a4d999113acbf695 [INFO] running `Command { std: "docker" "start" "-a" "858bac8a732d8aa14fd61637cc06e23b94fcf24d63eed8a8a4d999113acbf695", kill_on_drop: false }` [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/anthropic/anthropic.rs:17:12 [INFO] [stdout] | [INFO] [stdout] 17 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: `#[warn(unexpected_cfgs)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/anthropic/anthropic.rs:25:12 [INFO] [stdout] | [INFO] [stdout] 25 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/anthropic/anthropic.rs:35:12 [INFO] [stdout] | [INFO] [stdout] 35 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/openai/openai.rs:49:12 [INFO] [stdout] | [INFO] [stdout] 49 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `utils::*` [INFO] [stdout] --> src/common/mod.rs:6:9 [INFO] [stdout] | [INFO] [stdout] 6 | pub use utils::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:8:7 [INFO] [stdout] | [INFO] [stdout] 8 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:293:7 [INFO] [stdout] | [INFO] [stdout] 293 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:301:7 [INFO] [stdout] | [INFO] [stdout] 301 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:306:7 [INFO] [stdout] | [INFO] [stdout] 306 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:343:7 [INFO] [stdout] | [INFO] [stdout] 343 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:350:7 [INFO] [stdout] | [INFO] [stdout] 350 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `de::DeserializeOwned` [INFO] [stdout] --> src/model/types.rs:5:37 [INFO] [stdout] | [INFO] [stdout] 5 | use serde::{Deserialize, Serialize, de::DeserializeOwned}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ToolResultPart` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | ToolResultPart, Usage, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Context as _` and `anyhow` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:5:14 [INFO] [stdout] | [INFO] [stdout] 5 | use anyhow::{Context as _, anyhow}; [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `BTreeMap` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:8:24 [INFO] [stdout] | [INFO] [stdout] 8 | use std::collections::{BTreeMap, HashMap}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `strum::IntoEnumIterator` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | use strum::IntoEnumIterator; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Mutex` [INFO] [stdout] --> src/models/openai_provider/provider.rs:8:22 [INFO] [stdout] | [INFO] [stdout] 8 | use std::sync::{Arc, Mutex}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `anyhow::anyhow` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use anyhow::anyhow; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `futures_core::Stream` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use futures_core::Stream; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `futures_core::future::BoxFuture` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use futures_core::future::BoxFuture; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::pin::Pin` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::pin::Pin; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::info` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 21 | use log::info; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `strum::EnumIter` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | use strum::EnumIter; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `future::BoxFuture` [INFO] [stdout] --> src/models/openai_provider/event_mapper.rs:6:37 [INFO] [stdout] | [INFO] [stdout] 6 | use futures::{FutureExt, StreamExt, future::BoxFuture}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: ambiguous glob re-exports [INFO] [stdout] --> src/models/mod.rs:6:9 [INFO] [stdout] | [INFO] [stdout] 5 | pub use openai_provider::*; [INFO] [stdout] | ------------------ but the name `AvailableModel` in the type namespace is also re-exported here [INFO] [stdout] 6 | pub use anthropic_provider::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ the name `AvailableModel` in the type namespace is first re-exported here [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(ambiguous_glob_reexports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `LazyLock` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use std::sync::{LazyLock, OnceLock}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `borrow::Cow` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:3:27 [INFO] [stdout] | [INFO] [stdout] 3 | use std::{any::type_name, borrow::Cow, mem, pin::Pin, task::Poll, time::Duration}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `redirect` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | redirect, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `LanguageModelRequest` [INFO] [stdout] --> src/tool/tool.rs:3:40 [INFO] [stdout] | [INFO] [stdout] 3 | LanguageModel, LanguageModelImage, LanguageModelRequest, LanguageModelToolSchemaFormat, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `async_trait::async_trait` [INFO] [stdout] --> src/tool/tool.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use async_trait::async_trait; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt` [INFO] [stdout] --> src/tool/tool.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::fmt; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Formatter` [INFO] [stdout] --> src/tool/tool.rs:7:23 [INFO] [stdout] | [INFO] [stdout] 7 | use std::fmt::{Debug, Formatter}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Deref` [INFO] [stdout] --> src/tool/tool.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::ops::Deref; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::sync::Arc` [INFO] [stdout] --> src/tool/tool.rs:10:5 [INFO] [stdout] | [INFO] [stdout] 10 | use std::sync::Arc; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::task::JoinHandle` [INFO] [stdout] --> src/tool/tool.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use tokio::task::JoinHandle; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DerefMut` and `Deref` [INFO] [stdout] --> src/tool/tool_registry.rs:2:19 [INFO] [stdout] | [INFO] [stdout] 2 | use derive_more::{Deref, DerefMut}; [INFO] [stdout] | ^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: ambiguous glob re-exports [INFO] [stdout] --> src/lib.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 11 | pub use models::*; [INFO] [stdout] | ^^^^^^^^^ the name `OPEN_AI_PROVIDER_ID` in the value namespace is first re-exported here [INFO] [stdout] 12 | pub use model::*; [INFO] [stdout] | -------- but the name `OPEN_AI_PROVIDER_ID` in the value namespace is also re-exported here [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: ambiguous glob re-exports [INFO] [stdout] --> src/lib.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 11 | pub use models::*; [INFO] [stdout] | ^^^^^^^^^ the name `OPEN_AI_PROVIDER_NAME` in the value namespace is first re-exported here [INFO] [stdout] 12 | pub use model::*; [INFO] [stdout] | -------- but the name `OPEN_AI_PROVIDER_NAME` in the value namespace is also re-exported here [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Tool` [INFO] [stdout] --> src/tool/tool_registry.rs:1:13 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::{Tool, ToolDyn}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `LanguageModel` [INFO] [stdout] --> src/tool/tool.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | LanguageModel, LanguageModelImage, LanguageModelRequest, LanguageModelToolSchemaFormat, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `FutureExt` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:20:20 [INFO] [stdout] | [INFO] [stdout] 20 | use futures_util::{FutureExt, StreamExt}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `FutureExt` [INFO] [stdout] --> src/models/openai_provider/event_mapper.rs:6:15 [INFO] [stdout] | [INFO] [stdout] 6 | use futures::{FutureExt, StreamExt, future::BoxFuture}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `image_obj` [INFO] [stdout] --> src/model/types.rs:157:33 [INFO] [stdout] | [INFO] [stdout] 157 | if let Some(image_obj) = value.as_object() { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_image_obj` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `image` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:220:43 [INFO] [stdout] | [INFO] [stdout] 220 | MessageContent::Image(image) => { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_image` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `stop_reason` [INFO] [stdout] --> src/models/openai_provider/event_mapper.rs:104:18 [INFO] [stdout] | [INFO] [stdout] 104 | Some(stop_reason) => { [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stop_reason` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `redirect_policy` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:220:21 [INFO] [stdout] | [INFO] [stdout] 220 | if let Some(redirect_policy) = parts.extensions.get::() { [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_redirect_policy` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `default_true` is never used [INFO] [stdout] --> src/common/serde_utils.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | pub const fn default_true() -> 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 `post_inc` is never used [INFO] [stdout] --> src/common/utils.rs:3:8 [INFO] [stdout] | [INFO] [stdout] 3 | pub fn post_inc + AddAssign + Copy>(value: &mut T) -> T { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `truncate_lines_to_byte_limit` is never used [INFO] [stdout] --> src/common/utils.rs:10:8 [INFO] [stdout] | [INFO] [stdout] 10 | pub fn truncate_lines_to_byte_limit(s: &str, max_bytes: usize) -> &str { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `truncate_to_byte_limit` is never used [INFO] [stdout] --> src/common/utils.rs:29:8 [INFO] [stdout] | [INFO] [stdout] 29 | pub fn truncate_to_byte_limit(s: &str, max_bytes: usize) -> &str { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `ANTHROPIC_API_KEY_VAR` is never used [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:91:7 [INFO] [stdout] | [INFO] [stdout] 91 | const ANTHROPIC_API_KEY_VAR: &str = "ANTHROPIC_API_KEY"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AvailableModel` is never constructed [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:246:12 [INFO] [stdout] | [INFO] [stdout] 246 | pub struct AvailableModel { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `ANTHROPIC_API_URL` is never used [INFO] [stdout] --> src/anthropic/anthropic.rs:15:11 [INFO] [stdout] | [INFO] [stdout] 15 | pub const ANTHROPIC_API_URL: &str = "https://api.anthropic.com"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `complete` is never used [INFO] [stdout] --> src/anthropic/anthropic.rs:362:14 [INFO] [stdout] | [INFO] [stdout] 362 | pub async fn complete( [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `limit`, `remaining`, and `reset` are never read [INFO] [stdout] --> src/anthropic/anthropic.rs:422:9 [INFO] [stdout] | [INFO] [stdout] 421 | pub struct RateLimit { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] 422 | pub limit: usize, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 423 | pub remaining: usize, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 424 | pub reset: DateTime, [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `RateLimit` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `requests`, `tokens`, `input_tokens`, and `output_tokens` are never read [INFO] [stdout] --> src/anthropic/anthropic.rs:454:9 [INFO] [stdout] | [INFO] [stdout] 452 | pub struct RateLimitInfo { [INFO] [stdout] | ------------- fields in this struct [INFO] [stdout] 453 | pub retry_after: Option, [INFO] [stdout] 454 | pub requests: Option, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 455 | pub tokens: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 456 | pub input_tokens: Option, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 457 | pub output_tokens: Option, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `RateLimitInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `OPEN_AI_API_URL` is never used [INFO] [stdout] --> src/openai/openai.rs:9:11 [INFO] [stdout] | [INFO] [stdout] 9 | pub const OPEN_AI_API_URL: &str = "https://api.openai.com/v1"; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `OpenAiEmbeddingModel` is never used [INFO] [stdout] --> src/openai/openai.rs:465:10 [INFO] [stdout] | [INFO] [stdout] 465 | pub enum OpenAiEmbeddingModel { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling omni-llm-kit v0.1.1 (/opt/rustwide/workdir) [INFO] [stdout] warning: struct `OpenAiEmbeddingRequest` is never constructed [INFO] [stdout] --> src/openai/openai.rs:473:8 [INFO] [stdout] | [INFO] [stdout] 473 | struct OpenAiEmbeddingRequest<'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `OpenAiEmbeddingResponse` is never constructed [INFO] [stdout] --> src/openai/openai.rs:479:12 [INFO] [stdout] | [INFO] [stdout] 479 | pub struct OpenAiEmbeddingResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `OpenAiEmbedding` is never constructed [INFO] [stdout] --> src/openai/openai.rs:484:12 [INFO] [stdout] | [INFO] [stdout] 484 | pub struct OpenAiEmbedding { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `embed` is never used [INFO] [stdout] --> src/openai/openai.rs:488:8 [INFO] [stdout] | [INFO] [stdout] 488 | pub fn embed<'a>( [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/anthropic/anthropic.rs:17:12 [INFO] [stdout] | [INFO] [stdout] 17 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: `#[warn(unexpected_cfgs)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/anthropic/anthropic.rs:25:12 [INFO] [stdout] | [INFO] [stdout] 25 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/anthropic/anthropic.rs:35:12 [INFO] [stdout] | [INFO] [stdout] 35 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `schemars` [INFO] [stdout] --> src/openai/openai.rs:49:12 [INFO] [stdout] | [INFO] [stdout] 49 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `utils::*` [INFO] [stdout] --> src/common/mod.rs:6:9 [INFO] [stdout] | [INFO] [stdout] 6 | pub use utils::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:8:7 [INFO] [stdout] | [INFO] [stdout] 8 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:293:7 [INFO] [stdout] | [INFO] [stdout] 293 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:301:7 [INFO] [stdout] | [INFO] [stdout] 301 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:306:7 [INFO] [stdout] | [INFO] [stdout] 306 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:343:7 [INFO] [stdout] | [INFO] [stdout] 343 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition value: `test-support` [INFO] [stdout] --> src/http_client/http_client.rs:350:7 [INFO] [stdout] | [INFO] [stdout] 350 | #[cfg(feature = "test-support")] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stdout] | [INFO] [stdout] = note: no expected values for `feature` [INFO] [stdout] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `de::DeserializeOwned` [INFO] [stdout] --> src/model/types.rs:5:37 [INFO] [stdout] | [INFO] [stdout] 5 | use serde::{Deserialize, Serialize, de::DeserializeOwned}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ToolResultPart` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | ToolResultPart, Usage, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Context as _` and `anyhow` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:5:14 [INFO] [stdout] | [INFO] [stdout] 5 | use anyhow::{Context as _, anyhow}; [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `BTreeMap` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:8:24 [INFO] [stdout] | [INFO] [stdout] 8 | use std::collections::{BTreeMap, HashMap}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `strum::IntoEnumIterator` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | use strum::IntoEnumIterator; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Mutex` [INFO] [stdout] --> src/models/openai_provider/provider.rs:8:22 [INFO] [stdout] | [INFO] [stdout] 8 | use std::sync::{Arc, Mutex}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `anyhow::anyhow` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use anyhow::anyhow; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `futures_core::Stream` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use futures_core::Stream; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `futures_core::future::BoxFuture` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use futures_core::future::BoxFuture; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::pin::Pin` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::pin::Pin; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::info` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 21 | use log::info; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `strum::EnumIter` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | use strum::EnumIter; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `future::BoxFuture` [INFO] [stdout] --> src/models/openai_provider/event_mapper.rs:6:37 [INFO] [stdout] | [INFO] [stdout] 6 | use futures::{FutureExt, StreamExt, future::BoxFuture}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: ambiguous glob re-exports [INFO] [stdout] --> src/models/mod.rs:6:9 [INFO] [stdout] | [INFO] [stdout] 5 | pub use openai_provider::*; [INFO] [stdout] | ------------------ but the name `AvailableModel` in the type namespace is also re-exported here [INFO] [stdout] 6 | pub use anthropic_provider::*; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ the name `AvailableModel` in the type namespace is first re-exported here [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(ambiguous_glob_reexports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `LazyLock` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:2:17 [INFO] [stdout] | [INFO] [stdout] 2 | use std::sync::{LazyLock, OnceLock}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `borrow::Cow` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:3:27 [INFO] [stdout] | [INFO] [stdout] 3 | use std::{any::type_name, borrow::Cow, mem, pin::Pin, task::Poll, time::Duration}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `redirect` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | redirect, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `LanguageModelRequest` [INFO] [stdout] --> src/tool/tool.rs:3:40 [INFO] [stdout] | [INFO] [stdout] 3 | LanguageModel, LanguageModelImage, LanguageModelRequest, LanguageModelToolSchemaFormat, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `async_trait::async_trait` [INFO] [stdout] --> src/tool/tool.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use async_trait::async_trait; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fmt` [INFO] [stdout] --> src/tool/tool.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use std::fmt; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Formatter` [INFO] [stdout] --> src/tool/tool.rs:7:23 [INFO] [stdout] | [INFO] [stdout] 7 | use std::fmt::{Debug, Formatter}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Deref` [INFO] [stdout] --> src/tool/tool.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::ops::Deref; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::sync::Arc` [INFO] [stdout] --> src/tool/tool.rs:10:5 [INFO] [stdout] | [INFO] [stdout] 10 | use std::sync::Arc; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `tokio::task::JoinHandle` [INFO] [stdout] --> src/tool/tool.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use tokio::task::JoinHandle; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DerefMut` and `Deref` [INFO] [stdout] --> src/tool/tool_registry.rs:2:19 [INFO] [stdout] | [INFO] [stdout] 2 | use derive_more::{Deref, DerefMut}; [INFO] [stdout] | ^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: ambiguous glob re-exports [INFO] [stdout] --> src/lib.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 11 | pub use models::*; [INFO] [stdout] | ^^^^^^^^^ the name `OPEN_AI_PROVIDER_ID` in the value namespace is first re-exported here [INFO] [stdout] 12 | pub use model::*; [INFO] [stdout] | -------- but the name `OPEN_AI_PROVIDER_ID` in the value namespace is also re-exported here [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: ambiguous glob re-exports [INFO] [stdout] --> src/lib.rs:11:9 [INFO] [stdout] | [INFO] [stdout] 11 | pub use models::*; [INFO] [stdout] | ^^^^^^^^^ the name `OPEN_AI_PROVIDER_NAME` in the value namespace is first re-exported here [INFO] [stdout] 12 | pub use model::*; [INFO] [stdout] | -------- but the name `OPEN_AI_PROVIDER_NAME` in the value namespace is also re-exported here [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Tool` [INFO] [stdout] --> src/tool/tool_registry.rs:1:13 [INFO] [stdout] | [INFO] [stdout] 1 | use crate::{Tool, ToolDyn}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `LanguageModel` [INFO] [stdout] --> src/tool/tool.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | LanguageModel, LanguageModelImage, LanguageModelRequest, LanguageModelToolSchemaFormat, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `FutureExt` [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:20:20 [INFO] [stdout] | [INFO] [stdout] 20 | use futures_util::{FutureExt, StreamExt}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `FutureExt` [INFO] [stdout] --> src/models/openai_provider/event_mapper.rs:6:15 [INFO] [stdout] | [INFO] [stdout] 6 | use futures::{FutureExt, StreamExt, future::BoxFuture}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `image_obj` [INFO] [stdout] --> src/model/types.rs:157:33 [INFO] [stdout] | [INFO] [stdout] 157 | if let Some(image_obj) = value.as_object() { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_image_obj` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `image` [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:220:43 [INFO] [stdout] | [INFO] [stdout] 220 | MessageContent::Image(image) => { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_image` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `stop_reason` [INFO] [stdout] --> src/models/openai_provider/event_mapper.rs:104:18 [INFO] [stdout] | [INFO] [stdout] 104 | Some(stop_reason) => { [INFO] [stdout] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stop_reason` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `redirect_policy` [INFO] [stdout] --> src/reqwest_client/reqwest_client.rs:220:21 [INFO] [stdout] | [INFO] [stdout] 220 | if let Some(redirect_policy) = parts.extensions.get::() { [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_redirect_policy` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `default_true` is never used [INFO] [stdout] --> src/common/serde_utils.rs:1:14 [INFO] [stdout] | [INFO] [stdout] 1 | pub const fn default_true() -> 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 `post_inc` is never used [INFO] [stdout] --> src/common/utils.rs:3:8 [INFO] [stdout] | [INFO] [stdout] 3 | pub fn post_inc + AddAssign + Copy>(value: &mut T) -> T { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `truncate_lines_to_byte_limit` is never used [INFO] [stdout] --> src/common/utils.rs:10:8 [INFO] [stdout] | [INFO] [stdout] 10 | pub fn truncate_lines_to_byte_limit(s: &str, max_bytes: usize) -> &str { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `truncate_to_byte_limit` is never used [INFO] [stdout] --> src/common/utils.rs:29:8 [INFO] [stdout] | [INFO] [stdout] 29 | pub fn truncate_to_byte_limit(s: &str, max_bytes: usize) -> &str { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `ANTHROPIC_API_KEY_VAR` is never used [INFO] [stdout] --> src/models/anthropic_provider/anthropic.rs:91:7 [INFO] [stdout] | [INFO] [stdout] 91 | const ANTHROPIC_API_KEY_VAR: &str = "ANTHROPIC_API_KEY"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AvailableModel` is never constructed [INFO] [stdout] --> src/models/openai_provider/openai_model.rs:246:12 [INFO] [stdout] | [INFO] [stdout] 246 | pub struct AvailableModel { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `ANTHROPIC_API_URL` is never used [INFO] [stdout] --> src/anthropic/anthropic.rs:15:11 [INFO] [stdout] | [INFO] [stdout] 15 | pub const ANTHROPIC_API_URL: &str = "https://api.anthropic.com"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `complete` is never used [INFO] [stdout] --> src/anthropic/anthropic.rs:362:14 [INFO] [stdout] | [INFO] [stdout] 362 | pub async fn complete( [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `limit`, `remaining`, and `reset` are never read [INFO] [stdout] --> src/anthropic/anthropic.rs:422:9 [INFO] [stdout] | [INFO] [stdout] 421 | pub struct RateLimit { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] 422 | pub limit: usize, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 423 | pub remaining: usize, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 424 | pub reset: DateTime, [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `RateLimit` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `requests`, `tokens`, `input_tokens`, and `output_tokens` are never read [INFO] [stdout] --> src/anthropic/anthropic.rs:454:9 [INFO] [stdout] | [INFO] [stdout] 452 | pub struct RateLimitInfo { [INFO] [stdout] | ------------- fields in this struct [INFO] [stdout] 453 | pub retry_after: Option, [INFO] [stdout] 454 | pub requests: Option, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 455 | pub tokens: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 456 | pub input_tokens: Option, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 457 | pub output_tokens: Option, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `RateLimitInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `OPEN_AI_API_URL` is never used [INFO] [stdout] --> src/openai/openai.rs:9:11 [INFO] [stdout] | [INFO] [stdout] 9 | pub const OPEN_AI_API_URL: &str = "https://api.openai.com/v1"; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `OpenAiEmbeddingModel` is never used [INFO] [stdout] --> src/openai/openai.rs:465:10 [INFO] [stdout] | [INFO] [stdout] 465 | pub enum OpenAiEmbeddingModel { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `OpenAiEmbeddingRequest` is never constructed [INFO] [stdout] --> src/openai/openai.rs:473:8 [INFO] [stdout] | [INFO] [stdout] 473 | struct OpenAiEmbeddingRequest<'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `OpenAiEmbeddingResponse` is never constructed [INFO] [stdout] --> src/openai/openai.rs:479:12 [INFO] [stdout] | [INFO] [stdout] 479 | pub struct OpenAiEmbeddingResponse { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `OpenAiEmbedding` is never constructed [INFO] [stdout] --> src/openai/openai.rs:484:12 [INFO] [stdout] | [INFO] [stdout] 484 | pub struct OpenAiEmbedding { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `embed` is never used [INFO] [stdout] --> src/openai/openai.rs:488:8 [INFO] [stdout] | [INFO] [stdout] 488 | pub fn embed<'a>( [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `Result` that must be used [INFO] [stdout] --> src/lib.rs:70:9 [INFO] [stdout] | [INFO] [stdout] 70 | global_registry::register_arc!(AnthropicSettings, anthropic_settings); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 70 | let _ = global_registry::register_arc!(AnthropicSettings, anthropic_settings);; [INFO] [stdout] | +++++++ + [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 7.91s [INFO] running `Command { std: "docker" "inspect" "858bac8a732d8aa14fd61637cc06e23b94fcf24d63eed8a8a4d999113acbf695", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "858bac8a732d8aa14fd61637cc06e23b94fcf24d63eed8a8a4d999113acbf695", kill_on_drop: false }` [INFO] [stdout] 858bac8a732d8aa14fd61637cc06e23b94fcf24d63eed8a8a4d999113acbf695 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-10-28" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 5befe12077acc8bee493e22cee97ffcf9140f2c43852b04ee88acfdc064c0ef7 [INFO] running `Command { std: "docker" "start" "-a" "5befe12077acc8bee493e22cee97ffcf9140f2c43852b04ee88acfdc064c0ef7", kill_on_drop: false }` [INFO] [stderr] warning: unexpected `cfg` condition value: `schemars` [INFO] [stderr] --> src/anthropic/anthropic.rs:17:12 [INFO] [stderr] | [INFO] [stderr] 17 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stderr] | [INFO] [stderr] = note: no expected values for `feature` [INFO] [stderr] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] = note: `#[warn(unexpected_cfgs)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition value: `schemars` [INFO] [stderr] --> src/anthropic/anthropic.rs:25:12 [INFO] [stderr] | [INFO] [stderr] 25 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stderr] | [INFO] [stderr] = note: no expected values for `feature` [INFO] [stderr] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition value: `schemars` [INFO] [stderr] --> src/anthropic/anthropic.rs:35:12 [INFO] [stderr] | [INFO] [stderr] 35 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stderr] | [INFO] [stderr] = note: no expected values for `feature` [INFO] [stderr] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition value: `schemars` [INFO] [stderr] --> src/openai/openai.rs:49:12 [INFO] [stderr] | [INFO] [stderr] 49 | #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stderr] | [INFO] [stderr] = note: no expected values for `feature` [INFO] [stderr] = help: consider adding `schemars` as a feature in `Cargo.toml` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] [INFO] [stderr] warning: unused import: `utils::*` [INFO] [stderr] --> src/common/mod.rs:6:9 [INFO] [stderr] | [INFO] [stderr] 6 | pub use utils::*; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition value: `test-support` [INFO] [stderr] --> src/http_client/http_client.rs:8:7 [INFO] [stderr] | [INFO] [stderr] 8 | #[cfg(feature = "test-support")] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stderr] | [INFO] [stderr] = note: no expected values for `feature` [INFO] [stderr] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition value: `test-support` [INFO] [stderr] --> src/http_client/http_client.rs:293:7 [INFO] [stderr] | [INFO] [stderr] 293 | #[cfg(feature = "test-support")] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stderr] | [INFO] [stderr] = note: no expected values for `feature` [INFO] [stderr] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition value: `test-support` [INFO] [stderr] --> src/http_client/http_client.rs:301:7 [INFO] [stderr] | [INFO] [stderr] 301 | #[cfg(feature = "test-support")] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stderr] | [INFO] [stderr] = note: no expected values for `feature` [INFO] [stderr] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition value: `test-support` [INFO] [stderr] --> src/http_client/http_client.rs:306:7 [INFO] [stderr] | [INFO] [stderr] 306 | #[cfg(feature = "test-support")] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stderr] | [INFO] [stderr] = note: no expected values for `feature` [INFO] [stderr] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition value: `test-support` [INFO] [stderr] --> src/http_client/http_client.rs:343:7 [INFO] [stderr] | [INFO] [stderr] 343 | #[cfg(feature = "test-support")] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stderr] | [INFO] [stderr] = note: no expected values for `feature` [INFO] [stderr] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] [INFO] [stderr] warning: unexpected `cfg` condition value: `test-support` [INFO] [stderr] --> src/http_client/http_client.rs:350:7 [INFO] [stderr] | [INFO] [stderr] 350 | #[cfg(feature = "test-support")] [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition [INFO] [stderr] | [INFO] [stderr] = note: no expected values for `feature` [INFO] [stderr] = help: consider adding `test-support` as a feature in `Cargo.toml` [INFO] [stderr] = note: see for more information about checking conditional configuration [INFO] [stderr] [INFO] [stderr] warning: unused import: `de::DeserializeOwned` [INFO] [stderr] --> src/model/types.rs:5:37 [INFO] [stderr] | [INFO] [stderr] 5 | use serde::{Deserialize, Serialize, de::DeserializeOwned}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `ToolResultPart` [INFO] [stderr] --> src/models/anthropic_provider/anthropic.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | ToolResultPart, Usage, [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Context as _` and `anyhow` [INFO] [stderr] --> src/models/anthropic_provider/anthropic.rs:5:14 [INFO] [stderr] | [INFO] [stderr] 5 | use anyhow::{Context as _, anyhow}; [INFO] [stderr] | ^^^^^^^^^^^^ ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `BTreeMap` [INFO] [stderr] --> src/models/anthropic_provider/anthropic.rs:8:24 [INFO] [stderr] | [INFO] [stderr] 8 | use std::collections::{BTreeMap, HashMap}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `strum::IntoEnumIterator` [INFO] [stderr] --> src/models/anthropic_provider/anthropic.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | use strum::IntoEnumIterator; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Mutex` [INFO] [stderr] --> src/models/openai_provider/provider.rs:8:22 [INFO] [stderr] | [INFO] [stderr] 8 | use std::sync::{Arc, Mutex}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `anyhow::anyhow` [INFO] [stderr] --> src/models/openai_provider/openai_model.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use anyhow::anyhow; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `futures_core::Stream` [INFO] [stderr] --> src/models/openai_provider/openai_model.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use futures_core::Stream; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `futures_core::future::BoxFuture` [INFO] [stderr] --> src/models/openai_provider/openai_model.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use futures_core::future::BoxFuture; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::collections::HashMap` [INFO] [stderr] --> src/models/openai_provider/openai_model.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use std::collections::HashMap; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::pin::Pin` [INFO] [stderr] --> src/models/openai_provider/openai_model.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | use std::pin::Pin; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `log::info` [INFO] [stderr] --> src/models/openai_provider/openai_model.rs:21:5 [INFO] [stderr] | [INFO] [stderr] 21 | use log::info; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `strum::EnumIter` [INFO] [stderr] --> src/models/openai_provider/openai_model.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | use strum::EnumIter; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `future::BoxFuture` [INFO] [stderr] --> src/models/openai_provider/event_mapper.rs:6:37 [INFO] [stderr] | [INFO] [stderr] 6 | use futures::{FutureExt, StreamExt, future::BoxFuture}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: ambiguous glob re-exports [INFO] [stderr] --> src/models/mod.rs:6:9 [INFO] [stderr] | [INFO] [stderr] 5 | pub use openai_provider::*; [INFO] [stderr] | ------------------ but the name `AvailableModel` in the type namespace is also re-exported here [INFO] [stderr] 6 | pub use anthropic_provider::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ the name `AvailableModel` in the type namespace is first re-exported here [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(ambiguous_glob_reexports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `LazyLock` [INFO] [stderr] --> src/reqwest_client/reqwest_client.rs:2:17 [INFO] [stderr] | [INFO] [stderr] 2 | use std::sync::{LazyLock, OnceLock}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `borrow::Cow` [INFO] [stderr] --> src/reqwest_client/reqwest_client.rs:3:27 [INFO] [stderr] | [INFO] [stderr] 3 | use std::{any::type_name, borrow::Cow, mem, pin::Pin, task::Poll, time::Duration}; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `redirect` [INFO] [stderr] --> src/reqwest_client/reqwest_client.rs:11:5 [INFO] [stderr] | [INFO] [stderr] 11 | redirect, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `LanguageModelRequest` [INFO] [stderr] --> src/tool/tool.rs:3:40 [INFO] [stderr] | [INFO] [stderr] 3 | LanguageModel, LanguageModelImage, LanguageModelRequest, LanguageModelToolSchemaFormat, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `async_trait::async_trait` [INFO] [stderr] --> src/tool/tool.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use async_trait::async_trait; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fmt` [INFO] [stderr] --> src/tool/tool.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use std::fmt; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Formatter` [INFO] [stderr] --> src/tool/tool.rs:7:23 [INFO] [stderr] | [INFO] [stderr] 7 | use std::fmt::{Debug, Formatter}; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::ops::Deref` [INFO] [stderr] --> src/tool/tool.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | use std::ops::Deref; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::sync::Arc` [INFO] [stderr] --> src/tool/tool.rs:10:5 [INFO] [stderr] | [INFO] [stderr] 10 | use std::sync::Arc; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tokio::task::JoinHandle` [INFO] [stderr] --> src/tool/tool.rs:11:5 [INFO] [stderr] | [INFO] [stderr] 11 | use tokio::task::JoinHandle; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DerefMut` and `Deref` [INFO] [stderr] --> src/tool/tool_registry.rs:2:19 [INFO] [stderr] | [INFO] [stderr] 2 | use derive_more::{Deref, DerefMut}; [INFO] [stderr] | ^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: ambiguous glob re-exports [INFO] [stderr] --> src/lib.rs:11:9 [INFO] [stderr] | [INFO] [stderr] 11 | pub use models::*; [INFO] [stderr] | ^^^^^^^^^ the name `OPEN_AI_PROVIDER_ID` in the value namespace is first re-exported here [INFO] [stderr] 12 | pub use model::*; [INFO] [stderr] | -------- but the name `OPEN_AI_PROVIDER_ID` in the value namespace is also re-exported here [INFO] [stderr] [INFO] [stderr] warning: ambiguous glob re-exports [INFO] [stderr] --> src/lib.rs:11:9 [INFO] [stderr] | [INFO] [stderr] 11 | pub use models::*; [INFO] [stderr] | ^^^^^^^^^ the name `OPEN_AI_PROVIDER_NAME` in the value namespace is first re-exported here [INFO] [stderr] 12 | pub use model::*; [INFO] [stderr] | -------- but the name `OPEN_AI_PROVIDER_NAME` in the value namespace is also re-exported here [INFO] [stderr] [INFO] [stderr] warning: unused import: `Tool` [INFO] [stderr] --> src/tool/tool_registry.rs:1:13 [INFO] [stderr] | [INFO] [stderr] 1 | use crate::{Tool, ToolDyn}; [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `LanguageModel` [INFO] [stderr] --> src/tool/tool.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | LanguageModel, LanguageModelImage, LanguageModelRequest, LanguageModelToolSchemaFormat, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `FutureExt` [INFO] [stderr] --> src/models/openai_provider/openai_model.rs:20:20 [INFO] [stderr] | [INFO] [stderr] 20 | use futures_util::{FutureExt, StreamExt}; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `FutureExt` [INFO] [stderr] --> src/models/openai_provider/event_mapper.rs:6:15 [INFO] [stderr] | [INFO] [stderr] 6 | use futures::{FutureExt, StreamExt, future::BoxFuture}; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `image_obj` [INFO] [stderr] --> src/model/types.rs:157:33 [INFO] [stderr] | [INFO] [stderr] 157 | if let Some(image_obj) = value.as_object() { [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_image_obj` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `image` [INFO] [stderr] --> src/models/anthropic_provider/anthropic.rs:220:43 [INFO] [stderr] | [INFO] [stderr] 220 | MessageContent::Image(image) => { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_image` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `stop_reason` [INFO] [stderr] --> src/models/openai_provider/event_mapper.rs:104:18 [INFO] [stderr] | [INFO] [stderr] 104 | Some(stop_reason) => { [INFO] [stderr] | ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stop_reason` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `redirect_policy` [INFO] [stderr] --> src/reqwest_client/reqwest_client.rs:220:21 [INFO] [stderr] | [INFO] [stderr] 220 | if let Some(redirect_policy) = parts.extensions.get::() { [INFO] [stderr] | ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_redirect_policy` [INFO] [stderr] [INFO] [stderr] warning: function `default_true` is never used [INFO] [stderr] --> src/common/serde_utils.rs:1:14 [INFO] [stderr] | [INFO] [stderr] 1 | pub const fn default_true() -> bool { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: function `post_inc` is never used [INFO] [stderr] --> src/common/utils.rs:3:8 [INFO] [stderr] | [INFO] [stderr] 3 | pub fn post_inc + AddAssign + Copy>(value: &mut T) -> T { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `truncate_lines_to_byte_limit` is never used [INFO] [stderr] --> src/common/utils.rs:10:8 [INFO] [stderr] | [INFO] [stderr] 10 | pub fn truncate_lines_to_byte_limit(s: &str, max_bytes: usize) -> &str { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `truncate_to_byte_limit` is never used [INFO] [stderr] --> src/common/utils.rs:29:8 [INFO] [stderr] | [INFO] [stderr] 29 | pub fn truncate_to_byte_limit(s: &str, max_bytes: usize) -> &str { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: constant `ANTHROPIC_API_KEY_VAR` is never used [INFO] [stderr] --> src/models/anthropic_provider/anthropic.rs:91:7 [INFO] [stderr] | [INFO] [stderr] 91 | const ANTHROPIC_API_KEY_VAR: &str = "ANTHROPIC_API_KEY"; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `AvailableModel` is never constructed [INFO] [stderr] --> src/models/openai_provider/openai_model.rs:246:12 [INFO] [stderr] | [INFO] [stderr] 246 | pub struct AvailableModel { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: constant `ANTHROPIC_API_URL` is never used [INFO] [stderr] --> src/anthropic/anthropic.rs:15:11 [INFO] [stderr] | [INFO] [stderr] 15 | pub const ANTHROPIC_API_URL: &str = "https://api.anthropic.com"; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `complete` is never used [INFO] [stderr] --> src/anthropic/anthropic.rs:362:14 [INFO] [stderr] | [INFO] [stderr] 362 | pub async fn complete( [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `limit`, `remaining`, and `reset` are never read [INFO] [stderr] --> src/anthropic/anthropic.rs:422:9 [INFO] [stderr] | [INFO] [stderr] 421 | pub struct RateLimit { [INFO] [stderr] | --------- fields in this struct [INFO] [stderr] 422 | pub limit: usize, [INFO] [stderr] | ^^^^^ [INFO] [stderr] 423 | pub remaining: usize, [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] 424 | pub reset: DateTime, [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `RateLimit` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: fields `requests`, `tokens`, `input_tokens`, and `output_tokens` are never read [INFO] [stderr] --> src/anthropic/anthropic.rs:454:9 [INFO] [stderr] | [INFO] [stderr] 452 | pub struct RateLimitInfo { [INFO] [stderr] | ------------- fields in this struct [INFO] [stderr] 453 | pub retry_after: Option, [INFO] [stderr] 454 | pub requests: Option, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] 455 | pub tokens: Option, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] 456 | pub input_tokens: Option, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] 457 | pub output_tokens: Option, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `RateLimitInfo` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: constant `OPEN_AI_API_URL` is never used [INFO] [stderr] --> src/openai/openai.rs:9:11 [INFO] [stderr] | [INFO] [stderr] 9 | pub const OPEN_AI_API_URL: &str = "https://api.openai.com/v1"; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum `OpenAiEmbeddingModel` is never used [INFO] [stderr] --> src/openai/openai.rs:465:10 [INFO] [stderr] | [INFO] [stderr] 465 | pub enum OpenAiEmbeddingModel { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `OpenAiEmbeddingRequest` is never constructed [INFO] [stderr] --> src/openai/openai.rs:473:8 [INFO] [stderr] | [INFO] [stderr] 473 | struct OpenAiEmbeddingRequest<'a> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `OpenAiEmbeddingResponse` is never constructed [INFO] [stderr] --> src/openai/openai.rs:479:12 [INFO] [stderr] | [INFO] [stderr] 479 | pub struct OpenAiEmbeddingResponse { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `OpenAiEmbedding` is never constructed [INFO] [stderr] --> src/openai/openai.rs:484:12 [INFO] [stderr] | [INFO] [stderr] 484 | pub struct OpenAiEmbedding { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `embed` is never used [INFO] [stderr] --> src/openai/openai.rs:488:8 [INFO] [stderr] | [INFO] [stderr] 488 | pub fn embed<'a>( [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused `Result` that must be used [INFO] [stderr] --> src/lib.rs:70:9 [INFO] [stderr] | [INFO] [stderr] 70 | global_registry::register_arc!(AnthropicSettings, anthropic_settings); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] help: use `let _ = ...` to ignore the resulting value [INFO] [stderr] | [INFO] [stderr] 70 | let _ = global_registry::register_arc!(AnthropicSettings, anthropic_settings);; [INFO] [stderr] | +++++++ + [INFO] [stderr] [INFO] [stderr] warning: `omni-llm-kit` (lib) generated 63 warnings (run `cargo fix --lib -p omni-llm-kit` to apply 30 suggestions) [INFO] [stderr] warning: `omni-llm-kit` (lib test) generated 64 warnings (63 duplicates) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.35s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/omni_llm_kit-230b352243b5fa07) [INFO] [stdout] [INFO] [stdout] running 3 tests [INFO] [stdout] test anthropic::anthropic::test_match_window_exceeded ... ok [INFO] [stdout] test tests::test_anthropic_language_model ... FAILED [INFO] [stdout] test tests::test_openai_language_model ... FAILED [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- tests::test_anthropic_language_model stdout ---- [INFO] [stdout] [INFO] [stdout] thread 'tests::test_anthropic_language_model' (26) panicked at src/lib.rs:64:63: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: NotPresent [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x55e0cadd7bd2 - std::backtrace_rs::backtrace::libunwind::trace::h16acf28769fcd909 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x55e0cadd7bd2 - std::backtrace_rs::backtrace::trace_unsynchronized::hb5541aa5d4f92513 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x55e0cadd7bd2 - std::sys::backtrace::_print_fmt::h8ac8268cb667a306 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x55e0cadd7bd2 - ::fmt::h47627beda0767f4c [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x55e0cade93df - core::fmt::rt::Argument::fmt::h686a01ad57c1c92a [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x55e0cade93df - core::fmt::write::h8a63064c67176fd8 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x55e0cada26c3 - std::io::default_write_fmt::hd4797e693c0ec256 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x55e0cada26c3 - std::io::Write::write_fmt::h791e240ad2720c99 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x55e0cadaf8c2 - std::sys::backtrace::BacktraceLock::print::h4634d27c0afbaebb [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x55e0cadb51af - std::panicking::default_hook::{{closure}}::h23e0299d4738b766 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x55e0cadb5041 - std::panicking::default_hook::hfeec6294e8751b62 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55e0ca70edce - as core::ops::function::Fn>::call::h3f5a16438cee2b4e [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/alloc/src/boxed.rs:2019:9 [INFO] [stdout] 12: 0x55e0ca70edce - test::test_main_with_exit_callback::{{closure}}::h9214498cef9aafc5 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x55e0cadb586f - as core::ops::function::Fn>::call::hdb18da3e68df7464 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/alloc/src/boxed.rs:2019:9 [INFO] [stdout] 14: 0x55e0cadb586f - std::panicking::panic_with_hook::hd57cd463d793ed79 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x55e0cadb561a - std::panicking::panic_handler::{{closure}}::hddd6216c3fddee3b [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x55e0cadaf9f9 - std::sys::backtrace::__rust_end_short_backtrace::h5e7a56f283378525 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x55e0cad96d9d - __rustc[256c90bb7e548b45]::rust_begin_unwind [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x55e0cadf2800 - core::panicking::panic_fmt::hf19c198748ef6a95 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x55e0cadf1ab6 - core::result::unwrap_failed::he81173b5792ad6b0 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x55e0ca6bbbb5 - core::result::Result::unwrap::h75a59ec387460dd8 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x55e0ca6bbbb5 - omni_llm_kit::tests::test_anthropic_language_model::{{closure}}::h4a88f896ed5403ce [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:64:63 [INFO] [stdout] 22: 0x55e0ca691452 - as core::future::future::Future>::poll::ha34264ae6c31dfdf [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/future/future.rs:133:9 [INFO] [stdout] 23: 0x55e0ca69134d - as core::future::future::Future>::poll::h1ce3fc7d3da26e1a [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/future/future.rs:133:9 [INFO] [stdout] 24: 0x55e0ca66bfad - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::{{closure}}::h1a5fa8a8cc8911f3 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:70 [INFO] [stdout] 25: 0x55e0ca66beeb - tokio::task::coop::with_budget::h6c53bc92fca0c68d [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:167:5 [INFO] [stdout] 26: 0x55e0ca66beeb - tokio::task::coop::budget::hb966b5434825b07b [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:133:5 [INFO] [stdout] 27: 0x55e0ca66beeb - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::h743de556b1500b3c [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:25 [INFO] [stdout] 28: 0x55e0ca668d80 - tokio::runtime::scheduler::current_thread::Context::enter::h5e6455b611ad4559 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:432:19 [INFO] [stdout] 29: 0x55e0ca66b41d - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::h377e7dc7cbfefdbf [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:741:44 [INFO] [stdout] 30: 0x55e0ca66a634 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::{{closure}}::h4c3d2e8e458c8dbd [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:68 [INFO] [stdout] 31: 0x55e0ca6ccfbb - tokio::runtime::context::scoped::Scoped::set::h10393019985c771a [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/scoped.rs:40:9 [INFO] [stdout] 32: 0x55e0ca659939 - tokio::runtime::context::set_scheduler::{{closure}}::h15f5e3d766e3be8e [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:38 [INFO] [stdout] 33: 0x55e0ca657872 - std::thread::local::LocalKey::try_with::h563fcba06a36059c [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/thread/local.rs:508:12 [INFO] [stdout] 34: 0x55e0ca6572fe - std::thread::local::LocalKey::with::h9945ed7993a79d2b [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/thread/local.rs:472:20 [INFO] [stdout] 35: 0x55e0ca6598ad - tokio::runtime::context::set_scheduler::h9f9b28b4a6b54ab6 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:17 [INFO] [stdout] 36: 0x55e0ca669fc0 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::h1a175372e397d1e8 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:27 [INFO] [stdout] 37: 0x55e0ca66a6d3 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::hd70fb41499b15913 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:729:24 [INFO] [stdout] 38: 0x55e0ca668100 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::{{closure}}::hbb4d32de42e69265 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:200:33 [INFO] [stdout] 39: 0x55e0ca6675f0 - tokio::runtime::context::runtime::enter_runtime::he6f9003fc094cca2 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/runtime.rs:65:16 [INFO] [stdout] 40: 0x55e0ca667ec1 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::hc72d08050d2a2757 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:188:9 [INFO] [stdout] 41: 0x55e0ca678944 - tokio::runtime::runtime::Runtime::block_on_inner::h349529fc3c8bbf70 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:356:52 [INFO] [stdout] 42: 0x55e0ca678c1c - tokio::runtime::runtime::Runtime::block_on::ha74a6baedf1396fa [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:330:18 [INFO] [stdout] 43: 0x55e0ca6bb953 - omni_llm_kit::tests::test_anthropic_language_model::h4b5d13e555447a8d [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:94:50 [INFO] [stdout] 44: 0x55e0ca6bcd17 - omni_llm_kit::tests::test_anthropic_language_model::{{closure}}::h6491afc81d363ad8 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:61:45 [INFO] [stdout] 45: 0x55e0ca6bdfa6 - core::ops::function::FnOnce::call_once::hc80e9f1f4cf085bc [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 46: 0x55e0ca70ec1b - core::ops::function::FnOnce::call_once::h43f43c5185cf39c2 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 47: 0x55e0ca70ec1b - test::__rust_begin_short_backtrace::hc4fa634eb2764bdc [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:663:18 [INFO] [stdout] 48: 0x55e0ca723238 - test::run_test_in_process::{{closure}}::h9f4b799a5211b72a [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:686:74 [INFO] [stdout] 49: 0x55e0ca723238 - as core::ops::function::FnOnce<()>>::call_once::ha572bf7dc5230a8f [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 50: 0x55e0ca723238 - std::panicking::catch_unwind::do_call::hfd6ff51f25dd177b [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:590:40 [INFO] [stdout] 51: 0x55e0ca723238 - std::panicking::catch_unwind::h8609b446221def5f [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:553:19 [INFO] [stdout] 52: 0x55e0ca723238 - std::panic::catch_unwind::h362f73cc48531e26 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panic.rs:359:14 [INFO] [stdout] 53: 0x55e0ca723238 - test::run_test_in_process::hf52fd21d696aae67 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:686:27 [INFO] [stdout] 54: 0x55e0ca723238 - test::run_test::{{closure}}::h7e780b8354e6d007 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:607:43 [INFO] [stdout] 55: 0x55e0ca6fc004 - test::run_test::{{closure}}::hdc2695f2276aad3e [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:637:41 [INFO] [stdout] 56: 0x55e0ca6fc004 - std::sys::backtrace::__rust_begin_short_backtrace::h2555b2113ed90fc9 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 57: 0x55e0ca6ff93a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h99800d480987dfb6 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 58: 0x55e0ca6ff93a - as core::ops::function::FnOnce<()>>::call_once::hbbb69b5294b2221b [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 59: 0x55e0ca6ff93a - std::panicking::catch_unwind::do_call::h495689350c27df20 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:590:40 [INFO] [stdout] 60: 0x55e0ca6ff93a - std::panicking::catch_unwind::hf22437c51d1b3740 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:553:19 [INFO] [stdout] 61: 0x55e0ca6ff93a - std::panic::catch_unwind::habda1a57de8231f8 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panic.rs:359:14 [INFO] [stdout] 62: 0x55e0ca6ff93a - std::thread::Builder::spawn_unchecked_::{{closure}}::h5833d8dda8c7e80b [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 63: 0x55e0ca6ff93a - core::ops::function::FnOnce::call_once{{vtable.shim}}::ha2910283a5058402 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 64: 0x55e0cadaacef - as core::ops::function::FnOnce>::call_once::he4d85cb537521972 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/alloc/src/boxed.rs:2005:9 [INFO] [stdout] 65: 0x55e0cadaacef - std::sys::thread::unix::Thread::new::thread_start::hbaf586a9e50a98cd [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 66: 0x7991394f8aa4 - [INFO] [stdout] 67: 0x799139585a64 - clone [INFO] [stdout] 68: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- tests::test_openai_language_model stdout ---- [INFO] [stdout] [INFO] [stdout] thread 'tests::test_openai_language_model' (27) panicked at src/models/openai_provider/openai_model.rs:43:51: [INFO] [stdout] OpenAiSettings not found: TypeNotFound [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x55e0cadd7bd2 - std::backtrace_rs::backtrace::libunwind::trace::h16acf28769fcd909 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x55e0cadd7bd2 - std::backtrace_rs::backtrace::trace_unsynchronized::hb5541aa5d4f92513 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x55e0cadd7bd2 - std::sys::backtrace::_print_fmt::h8ac8268cb667a306 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x55e0cadd7bd2 - ::fmt::h47627beda0767f4c [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x55e0cade93df - core::fmt::rt::Argument::fmt::h686a01ad57c1c92a [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x55e0cade93df - core::fmt::write::h8a63064c67176fd8 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x55e0cada26c3 - std::io::default_write_fmt::hd4797e693c0ec256 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x55e0cada26c3 - std::io::Write::write_fmt::h791e240ad2720c99 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x55e0cadaf8c2 - std::sys::backtrace::BacktraceLock::print::h4634d27c0afbaebb [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x55e0cadb51af - std::panicking::default_hook::{{closure}}::h23e0299d4738b766 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x55e0cadb5041 - std::panicking::default_hook::hfeec6294e8751b62 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55e0ca70edce - as core::ops::function::Fn>::call::h3f5a16438cee2b4e [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/alloc/src/boxed.rs:2019:9 [INFO] [stdout] 12: 0x55e0ca70edce - test::test_main_with_exit_callback::{{closure}}::h9214498cef9aafc5 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x55e0cadb586f - as core::ops::function::Fn>::call::hdb18da3e68df7464 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/alloc/src/boxed.rs:2019:9 [INFO] [stdout] 14: 0x55e0cadb586f - std::panicking::panic_with_hook::hd57cd463d793ed79 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x55e0cadb561a - std::panicking::panic_handler::{{closure}}::hddd6216c3fddee3b [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x55e0cadaf9f9 - std::sys::backtrace::__rust_end_short_backtrace::h5e7a56f283378525 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x55e0cad96d9d - __rustc[256c90bb7e548b45]::rust_begin_unwind [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x55e0cadf2800 - core::panicking::panic_fmt::hf19c198748ef6a95 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x55e0cadf1ab6 - core::result::unwrap_failed::he81173b5792ad6b0 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x55e0ca6717d1 - core::result::Result::expect::habbd7d094616aa8f [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/result.rs:1185:23 [INFO] [stdout] 21: 0x55e0ca6630d2 - omni_llm_kit::models::openai_provider::openai_model::OpenAiLanguageModel::stream_completion::{{closure}}::hf9ddf73739a3b05d [INFO] [stdout] at /opt/rustwide/workdir/src/models/openai_provider/openai_model.rs:43:51 [INFO] [stdout] 22: 0x55e0ca6641c6 - ::stream_completion::{{closure}}::h3f29135c5b2ccfe6 [INFO] [stdout] at /opt/rustwide/workdir/src/models/openai_provider/openai_model.rs:95:58 [INFO] [stdout] 23: 0x55e0ca6913af - as core::future::future::Future>::poll::h4e682197475e652e [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/future/future.rs:133:9 [INFO] [stdout] 24: 0x55e0ca6bb1c8 - omni_llm_kit::tests::test_openai_language_model::{{closure}}::h1fb41cc0a6804c80 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:47:55 [INFO] [stdout] 25: 0x55e0ca691452 - as core::future::future::Future>::poll::ha34264ae6c31dfdf [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/future/future.rs:133:9 [INFO] [stdout] 26: 0x55e0ca69134d - as core::future::future::Future>::poll::h1ce3fc7d3da26e1a [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/future/future.rs:133:9 [INFO] [stdout] 27: 0x55e0ca66bfad - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::{{closure}}::h1a5fa8a8cc8911f3 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:70 [INFO] [stdout] 28: 0x55e0ca66beeb - tokio::task::coop::with_budget::h6c53bc92fca0c68d [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:167:5 [INFO] [stdout] 29: 0x55e0ca66beeb - tokio::task::coop::budget::hb966b5434825b07b [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/task/coop/mod.rs:133:5 [INFO] [stdout] 30: 0x55e0ca66beeb - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::{{closure}}::h743de556b1500b3c [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:742:25 [INFO] [stdout] 31: 0x55e0ca668d80 - tokio::runtime::scheduler::current_thread::Context::enter::h5e6455b611ad4559 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:432:19 [INFO] [stdout] 32: 0x55e0ca66b41d - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::{{closure}}::h377e7dc7cbfefdbf [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:741:44 [INFO] [stdout] 33: 0x55e0ca66a634 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::{{closure}}::h4c3d2e8e458c8dbd [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:68 [INFO] [stdout] 34: 0x55e0ca6ccfbb - tokio::runtime::context::scoped::Scoped::set::h10393019985c771a [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/scoped.rs:40:9 [INFO] [stdout] 35: 0x55e0ca659939 - tokio::runtime::context::set_scheduler::{{closure}}::h15f5e3d766e3be8e [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:38 [INFO] [stdout] 36: 0x55e0ca657872 - std::thread::local::LocalKey::try_with::h563fcba06a36059c [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/thread/local.rs:508:12 [INFO] [stdout] 37: 0x55e0ca6572fe - std::thread::local::LocalKey::with::h9945ed7993a79d2b [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/thread/local.rs:472:20 [INFO] [stdout] 38: 0x55e0ca6598ad - tokio::runtime::context::set_scheduler::h9f9b28b4a6b54ab6 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context.rs:176:17 [INFO] [stdout] 39: 0x55e0ca669fc0 - tokio::runtime::scheduler::current_thread::CoreGuard::enter::h1a175372e397d1e8 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:829:27 [INFO] [stdout] 40: 0x55e0ca66a6d3 - tokio::runtime::scheduler::current_thread::CoreGuard::block_on::hd70fb41499b15913 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:729:24 [INFO] [stdout] 41: 0x55e0ca668100 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::{{closure}}::hbb4d32de42e69265 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:200:33 [INFO] [stdout] 42: 0x55e0ca6675f0 - tokio::runtime::context::runtime::enter_runtime::he6f9003fc094cca2 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/context/runtime.rs:65:16 [INFO] [stdout] 43: 0x55e0ca667ec1 - tokio::runtime::scheduler::current_thread::CurrentThread::block_on::hc72d08050d2a2757 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/scheduler/current_thread/mod.rs:188:9 [INFO] [stdout] 44: 0x55e0ca678944 - tokio::runtime::runtime::Runtime::block_on_inner::h349529fc3c8bbf70 [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:356:52 [INFO] [stdout] 45: 0x55e0ca678c1c - tokio::runtime::runtime::Runtime::block_on::ha74a6baedf1396fa [INFO] [stdout] at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.47.1/src/runtime/runtime.rs:330:18 [INFO] [stdout] 46: 0x55e0ca6ba953 - omni_llm_kit::tests::test_openai_language_model::h5131477df00fd1b0 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:48:50 [INFO] [stdout] 47: 0x55e0ca6bb7f7 - omni_llm_kit::tests::test_openai_language_model::{{closure}}::hbdf5aa8ce8fa561f [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:26:42 [INFO] [stdout] 48: 0x55e0ca6bd1b6 - core::ops::function::FnOnce::call_once::h2135e1ec95161fa6 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 49: 0x55e0ca70ec1b - core::ops::function::FnOnce::call_once::h43f43c5185cf39c2 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 50: 0x55e0ca70ec1b - test::__rust_begin_short_backtrace::hc4fa634eb2764bdc [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:663:18 [INFO] [stdout] 51: 0x55e0ca723238 - test::run_test_in_process::{{closure}}::h9f4b799a5211b72a [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:686:74 [INFO] [stdout] 52: 0x55e0ca723238 - as core::ops::function::FnOnce<()>>::call_once::ha572bf7dc5230a8f [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 53: 0x55e0ca723238 - std::panicking::catch_unwind::do_call::hfd6ff51f25dd177b [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:590:40 [INFO] [stdout] 54: 0x55e0ca723238 - std::panicking::catch_unwind::h8609b446221def5f [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:553:19 [INFO] [stdout] 55: 0x55e0ca723238 - std::panic::catch_unwind::h362f73cc48531e26 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panic.rs:359:14 [INFO] [stdout] 56: 0x55e0ca723238 - test::run_test_in_process::hf52fd21d696aae67 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:686:27 [INFO] [stdout] 57: 0x55e0ca723238 - test::run_test::{{closure}}::h7e780b8354e6d007 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:607:43 [INFO] [stdout] 58: 0x55e0ca6fc004 - test::run_test::{{closure}}::hdc2695f2276aad3e [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/test/src/lib.rs:637:41 [INFO] [stdout] 59: 0x55e0ca6fc004 - std::sys::backtrace::__rust_begin_short_backtrace::h2555b2113ed90fc9 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 60: 0x55e0ca6ff93a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h99800d480987dfb6 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 61: 0x55e0ca6ff93a - as core::ops::function::FnOnce<()>>::call_once::hbbb69b5294b2221b [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 62: 0x55e0ca6ff93a - std::panicking::catch_unwind::do_call::h495689350c27df20 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:590:40 [INFO] [stdout] 63: 0x55e0ca6ff93a - std::panicking::catch_unwind::hf22437c51d1b3740 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panicking.rs:553:19 [INFO] [stdout] 64: 0x55e0ca6ff93a - std::panic::catch_unwind::habda1a57de8231f8 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/panic.rs:359:14 [INFO] [stdout] 65: 0x55e0ca6ff93a - std::thread::Builder::spawn_unchecked_::{{closure}}::h5833d8dda8c7e80b [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 66: 0x55e0ca6ff93a - core::ops::function::FnOnce::call_once{{vtable.shim}}::ha2910283a5058402 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 67: 0x55e0cadaacef - as core::ops::function::FnOnce>::call_once::he4d85cb537521972 [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/alloc/src/boxed.rs:2005:9 [INFO] [stdout] 68: 0x55e0cadaacef - std::sys::thread::unix::Thread::new::thread_start::hbaf586a9e50a98cd [INFO] [stdout] at /rustc/3b4dd9bf1410f8da6329baa36ce5e37673cbbd1f/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 69: 0x7991394f8aa4 - [INFO] [stdout] 70: 0x799139585a64 - clone [INFO] [stdout] 71: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] tests::test_anthropic_language_model [INFO] [stdout] tests::test_openai_language_model [INFO] [stdout] [INFO] [stdout] test result: FAILED. 1 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.09s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] running `Command { std: "docker" "inspect" "5befe12077acc8bee493e22cee97ffcf9140f2c43852b04ee88acfdc064c0ef7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5befe12077acc8bee493e22cee97ffcf9140f2c43852b04ee88acfdc064c0ef7", kill_on_drop: false }` [INFO] [stdout] 5befe12077acc8bee493e22cee97ffcf9140f2c43852b04ee88acfdc064c0ef7