[INFO] cloning repository https://github.com/CharlesSampaio-CRS/kong-security-api
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/CharlesSampaio-CRS/kong-security-api" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FCharlesSampaio-CRS%2Fkong-security-api", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FCharlesSampaio-CRS%2Fkong-security-api'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] c40fd6ced95894720ee69aed867ea5cb8e731ae9
[INFO] checking CharlesSampaio-CRS/kong-security-api against master#a6acf0f07f0ed1c12e26dc0db3b9bf1d0504a0bb for pr-151109
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FCharlesSampaio-CRS%2Fkong-security-api" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/CharlesSampaio-CRS/kong-security-api
[INFO] finished tweaking git repo https://github.com/CharlesSampaio-CRS/kong-security-api
[INFO] tweaked toml for git repo https://github.com/CharlesSampaio-CRS/kong-security-api written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/CharlesSampaio-CRS/kong-security-api on toolchain a6acf0f07f0ed1c12e26dc0db3b9bf1d0504a0bb
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+a6acf0f07f0ed1c12e26dc0db3b9bf1d0504a0bb" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/CharlesSampaio-CRS/kong-security-api 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" "+a6acf0f07f0ed1c12e26dc0db3b9bf1d0504a0bb" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded rust-embed-utils v8.9.0
[INFO] [stderr]   Downloaded rust-embed-impl v8.9.0
[INFO] [stderr]   Downloaded deadpool-redis v0.14.0
[INFO] [stderr]   Downloaded actix-cors v0.7.1
[INFO] [stderr]   Downloaded resolv-conf v0.7.5
[INFO] [stderr]   Downloaded deadpool v0.10.0
[INFO] [stderr]   Downloaded bcrypt v0.15.1
[INFO] [stderr]   Downloaded serde_with_macros v3.15.1
[INFO] [stderr]   Downloaded utoipa v4.2.3
[INFO] [stderr]   Downloaded derive-where v1.6.0
[INFO] [stderr]   Downloaded tower-http v0.6.7
[INFO] [stderr]   Downloaded schemars v1.0.4
[INFO] [stderr]   Downloaded rustls-webpki v0.103.7
[INFO] [stderr]   Downloaded utoipa-gen v4.3.1
[INFO] [stderr]   Downloaded serde_with v3.15.1
[INFO] [stderr]   Downloaded webpki-roots v1.0.3
[INFO] [stderr]   Downloaded rustls v0.23.34
[INFO] [stderr]   Downloaded rust-embed v8.9.0
[INFO] [stderr]   Downloaded utoipa-swagger-ui v6.0.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+a6acf0f07f0ed1c12e26dc0db3b9bf1d0504a0bb" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] f0f95da8d037efeb4b3ec08e852116379bf21940f6226843497fc216591da18f
[INFO] running `Command { std: "docker" "start" "-a" "f0f95da8d037efeb4b3ec08e852116379bf21940f6226843497fc216591da18f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "f0f95da8d037efeb4b3ec08e852116379bf21940f6226843497fc216591da18f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f0f95da8d037efeb4b3ec08e852116379bf21940f6226843497fc216591da18f", kill_on_drop: false }`
[INFO] [stdout] f0f95da8d037efeb4b3ec08e852116379bf21940f6226843497fc216591da18f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+a6acf0f07f0ed1c12e26dc0db3b9bf1d0504a0bb" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 51c922a79d6c95dae288546a38398b9eeac7537e5c94dc89059dcc9ceba44a0d
[INFO] running `Command { std: "docker" "start" "-a" "51c922a79d6c95dae288546a38398b9eeac7537e5c94dc89059dcc9ceba44a0d", kill_on_drop: false }`
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling zerocopy v0.8.27
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]    Compiling zerocopy-derive v0.8.27
[INFO] [stderr]     Checking subtle v2.6.1
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]     Checking icu_normalizer v2.0.0
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]     Checking tokio v1.48.0
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]    Compiling crunchy v0.2.4
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]    Compiling time-macros v0.2.24
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]    Compiling tiny-keccak v2.0.2
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]     Checking time v0.3.44
[INFO] [stderr]     Checking http v1.4.0
[INFO] [stderr]     Checking socket2 v0.5.10
[INFO] [stderr]     Checking indexmap v2.12.0
[INFO] [stderr]    Compiling generic-array v0.14.9
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking url v2.5.7
[INFO] [stderr]     Checking rustls-pki-types v1.12.0
[INFO] [stderr]     Checking rand_chacha v0.9.0
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]    Compiling memchr v2.7.6
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling const-random-macro v0.1.16
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking tinyvec v1.10.0
[INFO] [stderr]     Checking rand v0.9.2
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]    Compiling regex-syntax v0.8.8
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]     Checking tokio-util v0.7.16
[INFO] [stderr]    Compiling const-random v0.1.18
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling macro_magic_core_macros v0.5.1
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling derive-syn-parse v0.2.0
[INFO] [stderr]    Compiling adler2 v2.0.1
[INFO] [stderr]    Compiling radium v0.7.0
[INFO] [stderr]     Checking h2 v0.3.27
[INFO] [stderr]    Compiling rustls v0.23.34
[INFO] [stderr]    Compiling simd-adler32 v0.3.7
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]     Checking h2 v0.4.12
[INFO] [stderr]    Compiling rustls v0.21.12
[INFO] [stderr]     Checking actix-rt v2.11.0
[INFO] [stderr]    Compiling macro_magic_core v0.5.1
[INFO] [stderr]     Checking sct v0.7.1
[INFO] [stderr]     Checking rustls-webpki v0.103.7
[INFO] [stderr]     Checking rustls-webpki v0.101.7
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking sha2 v0.10.9
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]    Compiling darling_core v0.21.3
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling semver v1.0.27
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling same-file v1.0.6
[INFO] [stderr]     Checking tap v1.0.1
[INFO] [stderr]    Compiling walkdir v2.5.0
[INFO] [stderr]     Checking wyz v0.5.1
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling actix-router v0.5.3
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]    Compiling rustc_version v0.4.1
[INFO] [stderr]    Compiling flate2 v1.1.4
[INFO] [stderr]     Checking crossbeam-epoch v0.9.18
[INFO] [stderr]    Compiling macro_magic_macros v0.5.1
[INFO] [stderr]     Checking actix-codec v0.5.2
[INFO] [stderr]     Checking hyper v1.8.1
[INFO] [stderr]     Checking unicode-normalization v0.1.24
[INFO] [stderr]     Checking webpki-roots v1.0.3
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling darling_macro v0.21.3
[INFO] [stderr]     Checking http-body v0.4.6
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling mongocrypt-sys v0.1.4+1.12.0
[INFO] [stderr]     Checking unicode-bidi v0.3.18
[INFO] [stderr]     Checking funty v2.0.0
[INFO] [stderr]     Checking tokio-rustls v0.24.1
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]     Checking hyper-util v0.1.18
[INFO] [stderr]     Checking bitvec v1.0.1
[INFO] [stderr]    Compiling zip v0.6.6
[INFO] [stderr]    Compiling enum-as-inner v0.6.1
[INFO] [stderr]     Checking actix-http v3.11.2
[INFO] [stderr]     Checking pin-project v1.1.10
[INFO] [stderr]     Checking hyper v0.14.32
[INFO] [stderr]    Compiling darling v0.21.3
[INFO] [stderr]    Compiling actix-web-codegen v4.3.0
[INFO] [stderr]    Compiling rustc_version_runtime v0.3.0
[INFO] [stderr]     Checking cookie v0.16.2
[INFO] [stderr]    Compiling rust-embed-utils v8.9.0
[INFO] [stderr]     Checking tokio-rustls v0.26.4
[INFO] [stderr]     Checking actix-server v2.6.0
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]    Compiling uuid v1.18.1
[INFO] [stderr]     Checking serde_bytes v0.11.19
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking inout v0.1.4
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]     Checking either v1.15.0
[INFO] [stderr]     Checking iana-time-zone v0.1.64
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]    Compiling parking_lot_core v0.8.6
[INFO] [stderr]     Checking lru-cache v0.1.2
[INFO] [stderr]     Checking chrono v0.4.42
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking hickory-proto v0.24.4
[INFO] [stderr]    Compiling utoipa-gen v4.3.1
[INFO] [stderr]     Checking bson v2.15.0
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking cipher v0.4.4
[INFO] [stderr]    Compiling rust-embed-impl v8.9.0
[INFO] [stderr]     Checking actix-web v4.11.0
[INFO] [stderr]    Compiling serde_with_macros v3.15.1
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling utoipa-swagger-ui v6.0.0
[INFO] [stderr]     Checking tokio-retry v0.3.0
[INFO] [stderr]    Compiling macro_magic v0.5.1
[INFO] [stderr]     Checking crossbeam-deque v0.8.6
[INFO] [stderr]     Checking combine v4.6.7
[INFO] [stderr]     Checking deadpool-runtime v0.1.4
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]     Checking hyper-rustls v0.24.2
[INFO] [stderr]     Checking half v2.7.1
[INFO] [stderr]    Compiling typed-builder-macro v0.20.1
[INFO] [stderr]     Checking num_cpus v1.17.0
[INFO] [stderr]     Checking socket2 v0.4.10
[INFO] [stderr]     Checking is-terminal v0.4.16
[INFO] [stderr]     Checking instant v0.1.13
[INFO] [stderr]     Checking resolv-conf v0.7.5
[INFO] [stderr]     Checking base64 v0.13.1
[INFO] [stderr]     Checking arc-swap v1.7.1
[INFO] [stderr]     Checking plotters-backend v0.3.7
[INFO] [stderr]     Checking unicode-properties v0.1.3
[INFO] [stderr]     Checking clap_lex v0.7.6
[INFO] [stderr]     Checking sha1_smol v1.0.1
[INFO] [stderr]     Checking clap_builder v4.5.53
[INFO] [stderr]     Checking hickory-resolver v0.24.4
[INFO] [stderr]     Checking plotters-svg v0.3.7
[INFO] [stderr]     Checking stringprep v0.1.5
[INFO] [stderr]     Checking tower-http v0.6.7
[INFO] [stderr]     Checking ciborium-ll v0.2.2
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking typed-builder v0.20.1
[INFO] [stderr]     Checking serde_with v3.15.1
[INFO] [stderr]     Checking deadpool v0.10.0
[INFO] [stderr]     Checking mongocrypt v0.3.1
[INFO] [stderr]     Checking hyper-tls v0.6.0
[INFO] [stderr]     Checking rust-embed v8.9.0
[INFO] [stderr]    Compiling mongodb-internal-macros v3.3.0
[INFO] [stderr]    Compiling validator_derive v0.18.2
[INFO] [stderr]     Checking blowfish v0.9.1
[INFO] [stderr]     Checking simple_asn1 v0.6.3
[INFO] [stderr]     Checking itertools v0.10.5
[INFO] [stderr]     Checking hyper-rustls v0.27.7
[INFO] [stderr]     Checking idna v0.5.0
[INFO] [stderr]     Checking webpki-roots v0.26.11
[INFO] [stderr]     Checking serde_path_to_error v0.1.20
[INFO] [stderr]     Checking pbkdf2 v0.11.0
[INFO] [stderr]     Checking md-5 v0.10.6
[INFO] [stderr]     Checking hmac v0.12.1
[INFO] [stderr]     Checking pem v3.0.6
[INFO] [stderr]    Compiling derive-where v1.6.0
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]     Checking humantime v2.3.0
[INFO] [stderr]     Checking take_mut v0.2.2
[INFO] [stderr]     Checking validator v0.18.1
[INFO] [stderr]     Checking env_logger v0.10.2
[INFO] [stderr]     Checking criterion-plot v0.5.0
[INFO] [stderr]     Checking utoipa v4.2.3
[INFO] [stderr]     Checking async-stream v0.3.6
[INFO] [stderr]     Checking jsonwebtoken v9.3.1
[INFO] [stderr]     Checking oauth2 v4.4.2
[INFO] [stderr]     Checking reqwest v0.12.24
[INFO] [stderr]     Checking rayon v1.11.0
[INFO] [stderr]     Checking bcrypt v0.15.1
[INFO] [stderr]     Checking clap v4.5.53
[INFO] [stderr]     Checking actix-cors v0.7.1
[INFO] [stderr]     Checking parking_lot v0.11.2
[INFO] [stderr]     Checking ciborium v0.2.2
[INFO] [stderr]     Checking plotters v0.3.7
[INFO] [stderr]     Checking fxhash v0.2.1
[INFO] [stderr]     Checking mongodb v3.3.0
[INFO] [stderr]     Checking tokio-stream v0.1.17
[INFO] [stderr]     Checking tinytemplate v1.2.1
[INFO] [stderr]     Checking redis v0.24.0
[INFO] [stderr]     Checking fs2 v0.4.3
[INFO] [stderr]     Checking urlencoding v2.1.3
[INFO] [stderr]     Checking oorandom v11.1.5
[INFO] [stderr]     Checking colored v2.2.0
[INFO] [stderr]     Checking sled v0.34.7
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]     Checking tokio-test v0.4.4
[INFO] [stderr]     Checking criterion v0.5.1
[INFO] [stderr]     Checking deadpool-redis v0.14.0
[INFO] [stderr]     Checking kong-security-api v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: struct `TestPasswordResetToken` is never constructed
[INFO] [stdout]   --> tests/test_helpers.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct TestPasswordResetToken {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_valid` is never used
[INFO] [stdout]   --> tests/test_helpers.rs:30:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl TestPasswordResetToken {
[INFO] [stdout]    | --------------------------- method in this implementation
[INFO] [stdout] 29 |     /// Verifica se o token é válido (não expirado e não usado)
[INFO] [stdout] 30 |     pub fn is_valid(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> tests/test_helpers.rs:137:12
[INFO] [stdout]     |
[INFO] [stdout]  47 | impl TestDatabase {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub fn create_password_reset_token(&self, email: &str, ip_address: Option<String>) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 165 |     pub fn create_expired_password_reset_token(&self, email: &str) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 193 |     pub fn validate_password_reset_token(&self, token: &str) -> Result<TestPasswordResetToken, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 213 |     pub fn mark_token_as_used(&self, token: &str) -> Result<(), String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 238 |     pub fn update_user_password(&self, email: &str, new_password_hash: &str) -> Result<(), String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     pub fn invalidate_all_tokens_for_email(&self, email: &str) -> Result<(), String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 274 |     pub fn get_tokens_by_email(&self, email: &str) -> Result<Vec<TestPasswordResetToken>, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 295 |     pub fn get_token_by_value(&self, token_value: &str) -> Result<TestPasswordResetToken, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 310 |     pub fn cleanup_expired_tokens(&self) -> Result<(), String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> src/services/password_reset_service.rs:133:9
[INFO] [stdout]     |
[INFO] [stdout] 133 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this function takes 5 arguments but 4 arguments were supplied
[INFO] [stdout]   --> src/models/password_reset.rs:78:21
[INFO] [stdout]    |
[INFO] [stdout] 78 |         let token = PasswordResetToken::new(
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 81 |             1,
[INFO] [stdout]    |             - argument #3 of type `std::string::String` is missing
[INFO] [stdout]    |
[INFO] [stdout] note: associated function defined here
[INFO] [stdout]   --> src/models/password_reset.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub fn new(tenant_id: String, email: String, token: String, expiration_hours: i64, ip_address: Option<String>) -> Self {
[INFO] [stdout]    |            ^^^                                   -------------
[INFO] [stdout] help: provide the argument
[INFO] [stdout]    |
[INFO] [stdout] 78 ~         let token = PasswordResetToken::new(
[INFO] [stdout] 79 +             "test@example.com".to_string(),
[INFO] [stdout] 80 +             "test-token-123".to_string(),
[INFO] [stdout] 81 +             /* std::string::String */,
[INFO] [stdout] 82 +             1,
[INFO] [stdout] 83 +             Some("127.0.0.1".to_string()),
[INFO] [stdout] 84 ~         );
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this function takes 5 arguments but 4 arguments were supplied
[INFO] [stdout]   --> src/models/password_reset.rs:93:21
[INFO] [stdout]    |
[INFO] [stdout] 93 |         let token = PasswordResetToken::new(
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 96 |             1,
[INFO] [stdout]    |             - argument #3 of type `std::string::String` is missing
[INFO] [stdout]    |
[INFO] [stdout] note: associated function defined here
[INFO] [stdout]   --> src/models/password_reset.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub fn new(tenant_id: String, email: String, token: String, expiration_hours: i64, ip_address: Option<String>) -> Self {
[INFO] [stdout]    |            ^^^                                   -------------
[INFO] [stdout] help: provide the argument
[INFO] [stdout]    |
[INFO] [stdout] 93 ~         let token = PasswordResetToken::new(
[INFO] [stdout] 94 +             "test@example.com".to_string(),
[INFO] [stdout] 95 +             "test-token-123".to_string(),
[INFO] [stdout] 96 +             /* std::string::String */,
[INFO] [stdout] 97 +             1,
[INFO] [stdout] 98 +             None,
[INFO] [stdout] 99 ~         );
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this function takes 5 arguments but 4 arguments were supplied
[INFO] [stdout]    --> src/models/password_reset.rs:105:25
[INFO] [stdout]     |
[INFO] [stdout] 105 |         let mut token = PasswordResetToken::new(
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 108 |             1,
[INFO] [stdout]     |             - argument #3 of type `std::string::String` is missing
[INFO] [stdout]     |
[INFO] [stdout] note: associated function defined here
[INFO] [stdout]    --> src/models/password_reset.rs:35:12
[INFO] [stdout]     |
[INFO] [stdout]  35 |     pub fn new(tenant_id: String, email: String, token: String, expiration_hours: i64, ip_address: Option<String>) -> Self {
[INFO] [stdout]     |            ^^^                                   -------------
[INFO] [stdout] help: provide the argument
[INFO] [stdout]     |
[INFO] [stdout] 105 ~         let mut token = PasswordResetToken::new(
[INFO] [stdout] 106 +             "test@example.com".to_string(),
[INFO] [stdout] 107 +             "test-token-123".to_string(),
[INFO] [stdout] 108 +             /* std::string::String */,
[INFO] [stdout] 109 +             1,
[INFO] [stdout] 110 +             None,
[INFO] [stdout] 111 ~         );
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `has_role`, `add_role`, and `remove_role` are never used
[INFO] [stdout]    --> src/models/user.rs:127:12
[INFO] [stdout]     |
[INFO] [stdout]  67 | impl User {
[INFO] [stdout]     | --------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 127 |     pub fn has_role(&self, role: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 133 |     pub fn add_role(&mut self, role: String) {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 143 |     pub fn remove_role(&mut self, role: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `mark_as_used` is never used
[INFO] [stdout]   --> src/models/password_reset.rs:67:12
[INFO] [stdout]    |
[INFO] [stdout] 33 | impl PasswordResetToken {
[INFO] [stdout]    | ----------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 67 |     pub fn mark_as_used(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `verify_password` is never used
[INFO] [stdout]   --> src/auth/password.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub fn verify_password(password: &str, hash: &str) -> Result<bool, Box<dyn Error>> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_log_indexes` is never used
[INFO] [stdout]    --> src/database/indexes.rs:140:14
[INFO] [stdout]     |
[INFO] [stdout] 140 | pub async fn create_log_indexes(db: &Database) -> Result<(), String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_password_reset_indexes` is never used
[INFO] [stdout]    --> src/database/indexes.rs:172:14
[INFO] [stdout]     |
[INFO] [stdout] 172 | pub async fn create_password_reset_indexes(db: &Database) -> Result<(), String> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `delete_user` and `list_users` are never used
[INFO] [stdout]    --> src/services/user_service.rs:127:18
[INFO] [stdout]     |
[INFO] [stdout]  10 | impl UserService {
[INFO] [stdout]     | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 127 |     pub async fn delete_user(&self, id: &ObjectId) -> Result<bool, Box<dyn Error + Send + Sync>> {
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub async fn list_users(&self, limit: Option<i64>) -> Result<Vec<User>, Box<dyn Error + Send + Sync>> {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_logs_by_email` is never used
[INFO] [stdout]    --> src/services/log_service.rs:164:18
[INFO] [stdout]     |
[INFO] [stdout]  12 | impl LogService {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 164 |     pub async fn get_logs_by_email(&self, email: &str, limit: Option<i64>) -> Result<Vec<LoginLog>, Box<dyn Error + Send + Sync>> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `cleanup_expired_tokens` and `get_tokens_by_email` are never used
[INFO] [stdout]    --> src/services/password_reset_service.rs:76:18
[INFO] [stdout]     |
[INFO] [stdout]  11 | impl PasswordResetService {
[INFO] [stdout]     | ------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub async fn cleanup_expired_tokens(&self) -> Result<u64, Box<dyn Error + Send + Sync>> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub async fn get_tokens_by_email(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SuccessResponse` is never constructed
[INFO] [stdout]   --> src/api/handlers/password_reset.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct SuccessResponse {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `configure_tenant_routes` is never used
[INFO] [stdout]    --> src/api/handlers/tenant_handlers.rs:285:8
[INFO] [stdout]     |
[INFO] [stdout] 285 | pub fn configure_tenant_routes(cfg: &mut web::ServiceConfig) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `state` is never read
[INFO] [stdout]   --> src/api/handlers/oauth_handlers.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct OAuthCallbackQuery {
[INFO] [stdout]    |            ------------------ field in this struct
[INFO] [stdout] 14 |     code: String,
[INFO] [stdout] 15 |     state: Option<String>, // CSRF token
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AuthResponse` is never constructed
[INFO] [stdout]   --> src/api/handlers/oauth_handlers.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct AuthResponse {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UserResponse` is never constructed
[INFO] [stdout]   --> src/api/handlers/oauth_handlers.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub struct UserResponse {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `configure_oauth_routes` is never used
[INFO] [stdout]    --> src/api/handlers/oauth_handlers.rs:405:8
[INFO] [stdout]     |
[INFO] [stdout] 405 | pub fn configure_oauth_routes(cfg: &mut web::ServiceConfig) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AppConfig` is never constructed
[INFO] [stdout]  --> src/config/mod.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct AppConfig {
[INFO] [stdout]   |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DatabaseConfig` is never constructed
[INFO] [stdout]   --> src/config/mod.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct DatabaseConfig {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ServerConfig` is never constructed
[INFO] [stdout]   --> src/config/mod.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct ServerConfig {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `JwtConfig` is never constructed
[INFO] [stdout]   --> src/config/mod.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct JwtConfig {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LoggingConfig` is never constructed
[INFO] [stdout]   --> src/config/mod.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub struct LoggingConfig {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_env` is never used
[INFO] [stdout]   --> src/config/mod.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 37 | impl AppConfig {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 38 |     pub fn from_env() -> Result<Self, env::VarError> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SecurityHeaders` is never constructed
[INFO] [stdout]   --> src/middleware/security.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct SecurityHeaders;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SecurityHeadersMiddleware` is never constructed
[INFO] [stdout]   --> src/middleware/security.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct SecurityHeadersMiddleware<S> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RequestLogger` is never constructed
[INFO] [stdout]    --> src/middleware/security.rs:107:12
[INFO] [stdout]     |
[INFO] [stdout] 107 | pub struct RequestLogger;
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RequestLoggerMiddleware` is never constructed
[INFO] [stdout]    --> src/middleware/security.rs:127:12
[INFO] [stdout]     |
[INFO] [stdout] 127 | pub struct RequestLoggerMiddleware<S> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RateLimiter` is never constructed
[INFO] [stdout]   --> src/middleware/rate_limit.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct RateLimiter {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RequestCounter` is never constructed
[INFO] [stdout]   --> src/middleware/rate_limit.rs:24:8
[INFO] [stdout]    |
[INFO] [stdout] 24 | struct RequestCounter {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `default`, `strict`, `login`, `check_rate_limit`, and `cleanup` are never used
[INFO] [stdout]   --> src/middleware/rate_limit.rs:30:12
[INFO] [stdout]    |
[INFO] [stdout] 29 | impl RateLimiter {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout] 30 |     pub fn new(max_requests: u32, window_secs: u64) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 39 |     pub fn default() -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub fn strict() -> Self {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn login() -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     async fn check_rate_limit(&self, key: &str) -> Result<(), String> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 85 |     pub async fn cleanup(&self) {
[INFO] [stdout]    |                  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RateLimiterMiddleware` is never constructed
[INFO] [stdout]    --> src/middleware/rate_limit.rs:114:12
[INFO] [stdout]     |
[INFO] [stdout] 114 | pub struct RateLimiterMiddleware<S> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UserRateLimiter` is never constructed
[INFO] [stdout]    --> src/middleware/rate_limit.rs:166:12
[INFO] [stdout]     |
[INFO] [stdout] 166 | pub struct UserRateLimiter {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `new` and `default` are never used
[INFO] [stdout]    --> src/middleware/rate_limit.rs:171:12
[INFO] [stdout]     |
[INFO] [stdout] 170 | impl UserRateLimiter {
[INFO] [stdout]     | -------------------- associated functions in this implementation
[INFO] [stdout] 171 |     pub fn new(max_requests: u32, window_secs: u64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 177 |     pub fn default() -> Self {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `UserRateLimiterMiddleware` is never constructed
[INFO] [stdout]    --> src/middleware/rate_limit.rs:201:12
[INFO] [stdout]     |
[INFO] [stdout] 201 | pub struct UserRateLimiterMiddleware<S> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sanitize_string` is never used
[INFO] [stdout]   --> src/middleware/validation.rs:85:8
[INFO] [stdout]    |
[INFO] [stdout] 85 | pub fn sanitize_string(input: &str) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `validate_object_id` is never used
[INFO] [stdout]    --> src/middleware/validation.rs:101:8
[INFO] [stdout]     |
[INFO] [stdout] 101 | pub fn validate_object_id(id: &str) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `max_connections` and `connection_timeout` are never read
[INFO] [stdout]   --> src/cache/redis_cache.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct CacheConfig {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout]  9 |     pub redis_url: String,
[INFO] [stdout] 10 |     pub max_connections: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 11 |     pub connection_timeout: Duration,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CacheConfig` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `default_ttl` is never read
[INFO] [stdout]   --> src/cache/redis_cache.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub struct RedisCache {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] 30 |     pool: Pool,
[INFO] [stdout] 31 |     default_ttl: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RedisCache` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set`, `exists`, `increment_with_ttl`, `ttl`, and `pool_status` are never used
[INFO] [stdout]    --> src/cache/redis_cache.rs:85:18
[INFO] [stdout]     |
[INFO] [stdout]  34 | impl RedisCache {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  85 |     pub async fn set<T: Serialize>(&self, key: &str, value: &T) -> Result<(), String> {
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 124 |     pub async fn exists(&self, key: &str) -> Result<bool, String> {
[INFO] [stdout]     |                  ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 136 |     pub async fn increment_with_ttl(&self, key: &str, ttl_seconds: u64) -> Result<i64, String> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 155 |     pub async fn ttl(&self, key: &str) -> Result<i64, String> {
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn pool_status(&self) -> (usize, usize) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tenant_logs` is never used
[INFO] [stdout]    --> src/cache/redis_cache.rs:199:12
[INFO] [stdout]     |
[INFO] [stdout] 199 |     pub fn tenant_logs(tenant_id: &str, page: u32) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tenant_pattern` is never used
[INFO] [stdout]    --> src/cache/redis_cache.rs:209:12
[INFO] [stdout]     |
[INFO] [stdout] 209 |     pub fn tenant_pattern(tenant_id: &str) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0061`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `kong-security-api` (bin "kong-security-api" test) due to 3 previous errors; 1 warning emitted
[INFO] running `Command { std: "docker" "inspect" "51c922a79d6c95dae288546a38398b9eeac7537e5c94dc89059dcc9ceba44a0d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "51c922a79d6c95dae288546a38398b9eeac7537e5c94dc89059dcc9ceba44a0d", kill_on_drop: false }`
[INFO] [stdout] 51c922a79d6c95dae288546a38398b9eeac7537e5c94dc89059dcc9ceba44a0d
