[INFO] cloning repository https://github.com/mohamedfrix/backend-base-rust
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/mohamedfrix/backend-base-rust" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmohamedfrix%2Fbackend-base-rust", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmohamedfrix%2Fbackend-base-rust'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 3bd0d80f2570874648ee10143ad9a819ed672527
[INFO] testing mohamedfrix/backend-base-rust against try#db823df02fd0c2cf67b43025ac3fef3f2d743245 for pr-150681
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmohamedfrix%2Fbackend-base-rust" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/mohamedfrix/backend-base-rust
[INFO] finished tweaking git repo https://github.com/mohamedfrix/backend-base-rust
[INFO] tweaked toml for git repo https://github.com/mohamedfrix/backend-base-rust written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/mohamedfrix/backend-base-rust on toolchain db823df02fd0c2cf67b43025ac3fef3f2d743245
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/mohamedfrix/backend-base-rust 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" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 5125b49579d75373ff32a201c813094aa2247653412351766904623244c73ea9
[INFO] running `Command { std: "docker" "start" "-a" "5125b49579d75373ff32a201c813094aa2247653412351766904623244c73ea9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "5125b49579d75373ff32a201c813094aa2247653412351766904623244c73ea9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5125b49579d75373ff32a201c813094aa2247653412351766904623244c73ea9", kill_on_drop: false }`
[INFO] [stdout] 5125b49579d75373ff32a201c813094aa2247653412351766904623244c73ea9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 426e5f9e7fe383db30984eea2df565dee4c57eb6959a7611ed6490611aeb7cc4
[INFO] running `Command { std: "docker" "start" "-a" "426e5f9e7fe383db30984eea2df565dee4c57eb6959a7611ed6490611aeb7cc4", kill_on_drop: false }`
[INFO] [stderr]    Compiling cfg-if v1.0.1
[INFO] [stderr]    Compiling libc v0.2.174
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling syn v2.0.104
[INFO] [stderr]    Compiling slab v0.4.10
[INFO] [stderr]    Compiling cc v1.2.30
[INFO] [stderr]    Compiling value-bag v1.11.1
[INFO] [stderr]    Compiling zerocopy v0.8.26
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling hashbrown v0.15.4
[INFO] [stderr]    Compiling bitflags v2.9.1
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling log v0.4.27
[INFO] [stderr]    Compiling serde_json v1.0.141
[INFO] [stderr]    Compiling thiserror v2.0.12
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling crc v3.3.0
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling tinyvec v1.9.0
[INFO] [stderr]    Compiling indexmap v2.10.0
[INFO] [stderr]    Compiling socket2 v0.5.10
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling signal-hook-registry v1.4.5
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling hashlink v0.10.0
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling event-listener-strategy v0.5.4
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling rustix v1.0.8
[INFO] [stderr]    Compiling tokio v1.46.1
[INFO] [stderr]    Compiling unicode-normalization v0.1.24
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling form_urlencoded v1.2.1
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rustls v0.21.12
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling linux-raw-sys v0.9.4
[INFO] [stderr]    Compiling stringprep v0.1.5
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling http-body v0.4.6
[INFO] [stderr]    Compiling event-listener v5.4.0
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling psm v0.1.26
[INFO] [stderr]    Compiling hkdf v0.12.4
[INFO] [stderr]    Compiling chrono v0.4.41
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]    Compiling uuid v1.17.0
[INFO] [stderr]    Compiling time-core v0.1.4
[INFO] [stderr]    Compiling whoami v1.6.0
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling time-macros v0.2.22
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling sct v0.7.1
[INFO] [stderr]    Compiling rustls-webpki v0.101.7
[INFO] [stderr]    Compiling stacker v0.1.21
[INFO] [stderr]    Compiling async-lock v3.4.0
[INFO] [stderr]    Compiling serde_derive v1.0.219
[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 displaydoc v0.2.5
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling thiserror-impl v2.0.12
[INFO] [stderr]    Compiling yoke v0.8.0
[INFO] [stderr]    Compiling zerovec v0.11.2
[INFO] [stderr]    Compiling zerotrie v0.2.2
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling polling v3.9.0
[INFO] [stderr]    Compiling async-channel v2.5.0
[INFO] [stderr]    Compiling atoi v2.0.0
[INFO] [stderr]    Compiling encoding_rs v0.8.35
[INFO] [stderr]    Compiling tinystr v0.8.1
[INFO] [stderr]    Compiling potential_utf v0.1.2
[INFO] [stderr]    Compiling icu_locale_core v2.0.0
[INFO] [stderr]    Compiling icu_collections v2.0.0
[INFO] [stderr]    Compiling icu_provider v2.0.0
[INFO] [stderr]    Compiling icu_properties v2.0.1
[INFO] [stderr]    Compiling rustversion v1.0.21
[INFO] [stderr]    Compiling blocking v1.6.2
[INFO] [stderr]    Compiling async-io v2.5.0
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling async-executor v1.13.2
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling multer v3.1.0
[INFO] [stderr]    Compiling rustls-pemfile v1.0.4
[INFO] [stderr]    Compiling num-bigint v0.4.6
[INFO] [stderr]    Compiling async-channel v1.9.0
[INFO] [stderr]    Compiling pin-project v1.1.10
[INFO] [stderr]    Compiling async-attributes v1.1.2
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling async-trait v0.1.88
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling kv-log-macro v1.0.7
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling parking_lot v0.12.4
[INFO] [stderr]    Compiling icu_normalizer v2.0.0
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling futures-intrusive v0.5.0
[INFO] [stderr]    Compiling deranged v0.4.0
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling sqlx-core v0.8.6
[INFO] [stderr]    Compiling time v0.3.41
[INFO] [stderr]    Compiling tracing-serde v0.2.0
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]    Compiling webpki-roots v0.25.4
[INFO] [stderr]    Compiling base64ct v1.8.0
[INFO] [stderr]    Compiling sync_wrapper v0.1.2
[INFO] [stderr]    Compiling tracing-subscriber v0.3.19
[INFO] [stderr]    Compiling xmltree v0.10.3
[INFO] [stderr]    Compiling password-hash v0.5.0
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling dashmap v5.5.3
[INFO] [stderr]    Compiling serde_path_to_error v0.1.17
[INFO] [stderr]    Compiling multimap v0.9.1
[INFO] [stderr]    Compiling os_info v3.12.0
[INFO] [stderr]    Compiling axum-core v0.5.2
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling chumsky v0.9.3
[INFO] [stderr]    Compiling derivative v2.2.0
[INFO] [stderr]    Compiling async-recursion v1.1.1
[INFO] [stderr]    Compiling simple_asn1 v0.6.3
[INFO] [stderr]    Compiling email-encoding v0.4.1
[INFO] [stderr]    Compiling pem v3.0.5
[INFO] [stderr]    Compiling hostname v0.4.1
[INFO] [stderr]    Compiling socket2 v0.4.10
[INFO] [stderr]    Compiling sqlx-postgres v0.8.6
[INFO] [stderr]    Compiling blake2 v0.10.6
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling nom v8.0.0
[INFO] [stderr]    Compiling sha1_smol v1.0.1
[INFO] [stderr]    Compiling arc-swap v1.7.1
[INFO] [stderr]    Compiling utf8-width v0.1.7
[INFO] [stderr]    Compiling email_address v0.2.9
[INFO] [stderr]    Compiling tokio-util v0.7.15
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tokio-rustls v0.24.1
[INFO] [stderr]    Compiling async-global-executor v2.4.1
[INFO] [stderr]    Compiling hyper v1.6.0
[INFO] [stderr]    Compiling async-std v1.13.1
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling combine v4.6.7
[INFO] [stderr]    Compiling hyper-util v0.1.15
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling tokio-retry v0.3.0
[INFO] [stderr]    Compiling quoted_printable v0.5.1
[INFO] [stderr]    Compiling urlencoding v2.1.3
[INFO] [stderr]    Compiling md5 v0.7.0
[INFO] [stderr]    Compiling lettre v0.11.17
[INFO] [stderr]    Compiling axum v0.8.4
[INFO] [stderr]    Compiling sqlx-macros-core v0.8.6
[INFO] [stderr]    Compiling tracing-appender v0.2.3
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling html-escape v0.2.13
[INFO] [stderr]    Compiling redis v0.24.0
[INFO] [stderr]    Compiling argon2 v0.5.3
[INFO] [stderr]    Compiling sqlx-macros v0.8.6
[INFO] [stderr]    Compiling jsonwebtoken v9.3.1
[INFO] [stderr]    Compiling tower-http v0.6.6
[INFO] [stderr]    Compiling sqlx v0.8.6
[INFO] [stderr]    Compiling hyper-tls v0.5.0
[INFO] [stderr]    Compiling hyper-rustls v0.24.2
[INFO] [stderr]    Compiling reqwest v0.11.27
[INFO] [stderr]    Compiling minio v0.1.0
[INFO] [stderr]    Compiling elhaiba-backend v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `error`
[INFO] [stdout]  --> src/util/password_reset.rs:3:22
[INFO] [stdout]   |
[INFO] [stdout] 3 | use tracing::{debug, error, info, instrument, warn};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 4m 46s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: redis v0.24.0
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] running `Command { std: "docker" "inspect" "426e5f9e7fe383db30984eea2df565dee4c57eb6959a7611ed6490611aeb7cc4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "426e5f9e7fe383db30984eea2df565dee4c57eb6959a7611ed6490611aeb7cc4", kill_on_drop: false }`
[INFO] [stdout] 426e5f9e7fe383db30984eea2df565dee4c57eb6959a7611ed6490611aeb7cc4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6b5a1345118310351e54e1f7e978c5136543e27c15681746f3abe35481a657d1
[INFO] running `Command { std: "docker" "start" "-a" "6b5a1345118310351e54e1f7e978c5136543e27c15681746f3abe35481a657d1", kill_on_drop: false }`
[INFO] [stderr]    Compiling tokio v1.46.1
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling async-stream v0.3.6
[INFO] [stderr]    Compiling tokio-util v0.7.15
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling tokio-rustls v0.24.1
[INFO] [stderr]    Compiling hyper v1.6.0
[INFO] [stderr]    Compiling async-global-executor v2.4.1
[INFO] [stderr]    Compiling tokio-retry v0.3.0
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling lettre v0.11.17
[INFO] [stderr]    Compiling async-std v1.13.1
[INFO] [stderr]    Compiling sqlx-core v0.8.6
[INFO] [stderr]    Compiling h2 v0.3.27
[INFO] [stderr]    Compiling combine v4.6.7
[INFO] [stderr]    Compiling hyper-util v0.1.15
[INFO] [stderr]    Compiling axum v0.8.4
[INFO] [stderr]    Compiling tokio-test v0.4.4
[INFO] [stderr]    Compiling sqlx-postgres v0.8.6
[INFO] [stderr]    Compiling hyper v0.14.32
[INFO] [stderr]    Compiling redis v0.24.0
[INFO] [stderr]    Compiling sqlx v0.8.6
[INFO] [stderr]    Compiling hyper-tls v0.5.0
[INFO] [stderr]    Compiling hyper-rustls v0.24.2
[INFO] [stderr]    Compiling reqwest v0.11.27
[INFO] [stderr]    Compiling minio v0.1.0
[INFO] [stderr]    Compiling elhaiba-backend v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `error`
[INFO] [stdout]  --> src/util/password_reset.rs:3:22
[INFO] [stdout]   |
[INFO] [stdout] 3 | use tracing::{debug, error, info, instrument, warn};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error`
[INFO] [stdout]  --> src/util/password_reset.rs:3:22
[INFO] [stdout]   |
[INFO] [stdout] 3 | use tracing::{debug, error, info, instrument, warn};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]  --> examples/log_rotation_demo.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::thread;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> examples/log_rotation_demo.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `debug`
[INFO] [stdout]  --> examples/log_rotation_demo.rs:3:34
[INFO] [stdout]   |
[INFO] [stdout] 3 | use tracing::{info, warn, error, debug};
[INFO] [stdout]   |                                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `non_blocking`
[INFO] [stdout]   --> examples/log_rotation_demo.rs:59:10
[INFO] [stdout]    |
[INFO] [stdout] 59 |     let (non_blocking, _guard) = tracing_appender::non_blocking(file_appender);
[INFO] [stdout]    |          ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_non_blocking`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 2m 08s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: redis v0.24.0
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] running `Command { std: "docker" "inspect" "6b5a1345118310351e54e1f7e978c5136543e27c15681746f3abe35481a657d1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6b5a1345118310351e54e1f7e978c5136543e27c15681746f3abe35481a657d1", kill_on_drop: false }`
[INFO] [stdout] 6b5a1345118310351e54e1f7e978c5136543e27c15681746f3abe35481a657d1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 77ad0158bc69c052a096fa4256b1c20fdf44860eedb5ee1c5d93ea892da7f137
[INFO] running `Command { std: "docker" "start" "-a" "77ad0158bc69c052a096fa4256b1c20fdf44860eedb5ee1c5d93ea892da7f137", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `error`
[INFO] [stderr]  --> src/util/password_reset.rs:3:22
[INFO] [stderr]   |
[INFO] [stderr] 3 | use tracing::{debug, error, info, instrument, warn};
[INFO] [stderr]   |                      ^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `elhaiba-backend` (lib) generated 1 warning (run `cargo fix --lib -p elhaiba-backend` to apply 1 suggestion)
[INFO] [stderr] warning: unused import: `std::thread`
[INFO] [stderr]  --> examples/log_rotation_demo.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::thread;
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::time::Duration`
[INFO] [stderr]  --> examples/log_rotation_demo.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use std::time::Duration;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `debug`
[INFO] [stderr]  --> examples/log_rotation_demo.rs:3:34
[INFO] [stderr]   |
[INFO] [stderr] 3 | use tracing::{info, warn, error, debug};
[INFO] [stderr]   |                                  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `non_blocking`
[INFO] [stderr]   --> examples/log_rotation_demo.rs:59:10
[INFO] [stderr]    |
[INFO] [stderr] 59 |     let (non_blocking, _guard) = tracing_appender::non_blocking(file_appender);
[INFO] [stderr]    |          ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_non_blocking`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `elhaiba-backend` (example "log_rotation_demo") generated 4 warnings (run `cargo fix --example "log_rotation_demo" -p elhaiba-backend` to apply 4 suggestions)
[INFO] [stderr] warning: `elhaiba-backend` (lib test) generated 1 warning (1 duplicate)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.59s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: redis v0.24.0
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/elhaiba_backend-ada119214eee7a8f)
[INFO] [stdout] 
[INFO] [stdout] running 31 tests
[INFO] [stdout] test config::email_conf::tests::test_test_config ... ok
[INFO] [stdout] test config::email_conf::tests::test_validate_empty_host ... ok
[INFO] [stdout] test config::email_conf::tests::test_validate_invalid_email_format ... ok
[INFO] [stdout] test config::email_conf::tests::test_validate_empty_from_email ... ok
[INFO] [stdout] test config::email_conf::tests::test_validate_valid_config ... ok
[INFO] [stdout] test config::email_conf::tests::test_validate_zero_port ... ok
[INFO] [stdout] test config::minio_conf::tests::test_validate_empty_endpoint ... ok
[INFO] [stdout] test config::password_reset_conf::tests::test_default_config ... ok
[INFO] [stdout] test config::minio_conf::tests::test_validate_valid_config ... ok
[INFO] [stdout] test config::minio_conf::tests::test_get_endpoint_url ... ok
[INFO] [stdout] test config::minio_conf::tests::test_default_config ... ok
[INFO] [stdout] test config::minio_conf::tests::test_validate_invalid_bucket_name ... ok
[INFO] [stdout] test config::password_reset_conf::tests::test_generate_reset_url_with_trailing_slash ... ok
[INFO] [stdout] test config::password_reset_conf::tests::test_get_redis_key ... ok
[INFO] [stdout] test config::email_conf::tests::test_get_smtp_url ... ok
[INFO] [stdout] test config::password_reset_conf::tests::test_generate_reset_url ... ok
[INFO] [stdout] test config::password_reset_conf::tests::test_test_config ... ok
[INFO] [stdout] test config::password_reset_conf::tests::test_validate_empty_base_url ... ok
[INFO] [stdout] test config::password_reset_conf::tests::test_validate_invalid_base_url ... ok
[INFO] [stdout] test config::password_reset_conf::tests::test_validate_short_token_length ... ok
[INFO] [stdout] test config::password_reset_conf::tests::test_validate_invalid_reset_path ... ok
[INFO] [stdout] test config::password_reset_conf::tests::test_validate_valid_config ... ok
[INFO] [stdout] test config::redis_conf::tests::test_default_config ... ok
[INFO] [stdout] test config::redis_conf::tests::test_get_connection_url_no_auth ... ok
[INFO] [stdout] test config::redis_conf::tests::test_get_connection_url_tls ... ok
[INFO] [stdout] test config::redis_conf::tests::test_get_connection_url_with_password ... ok
[INFO] [stdout] test config::redis_conf::tests::test_validate_invalid_port ... ok
[INFO] [stdout] test config::redis_conf::tests::test_get_connection_url_with_username_password ... ok
[INFO] [stdout] test config::redis_conf::tests::test_validate_valid_config ... ok
[INFO] [stdout] test config::redis_conf::tests::test_validate_empty_host ... ok
[INFO] [stdout] test config::email_conf::tests::test_default_config ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 31 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.23s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/elhaiba_backend-420063162dd5ca38)
[INFO] [stdout] 
[INFO] [stderr]      Running unittests examples/jwt/generate_token.rs (/opt/rustwide/target/debug/deps/generate_token_example-22a355aaa7be3868)
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests examples/email/send_email.rs (/opt/rustwide/target/debug/deps/send_email_example-ce77a4b39bfcdbf4)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/email_tests.rs (/opt/rustwide/target/debug/deps/email_tests-0b0487bf9130319f)
[INFO] [stdout] 
[INFO] [stdout] running 14 tests
[INFO] [stdout] test config_tests::test_config_from_test_env ... ok
[INFO] [stdout] test config_tests::test_config_validation_invalid_email_format ... ok
[INFO] [stdout] test config_tests::test_config_validation_empty_host ... ok
[INFO] [stdout] test config_tests::test_config_validation ... ok
[INFO] [stdout] test config_tests::test_config_validation_empty_from_email ... ok
[INFO] [stdout] test integration_tests::test_send_email_integration ... ignored
[INFO] [stdout] test config_tests::test_config_validation_zero_port ... ok
[INFO] [stdout] test integration_tests::test_send_password_reset_email_integration ... ignored
[INFO] [stdout] test config_tests::test_get_smtp_url ... ok
[INFO] [stdout] test error_tests::test_invalid_config_creation ... ok
[INFO] [stdout] test unit_tests::test_email_message_creation ... ok
[INFO] [stdout] test unit_tests::test_email_message_with_bodies ... ok
[INFO] [stdout] test error_tests::test_email_error_types ... ok
[INFO] [stdout] test unit_tests::test_email_service_creation ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 12 passed; 0 failed; 2 ignored; 0 measured; 0 filtered out; finished in 0.05s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/jwt_tests.rs (/opt/rustwide/target/debug/deps/jwt_tests-d48cd8cef9378148)
[INFO] [stdout] 
[INFO] [stdout] running 34 tests
[INFO] [stdout] test test_check_role_permission_admin ... ok
[INFO] [stdout] test test_extract_token_from_header_invalid_format ... ok
[INFO] [stdout] test test_check_role_permission_user ... ok
[INFO] [stdout] test test_extract_token_from_header_empty_token ... ok
[INFO] [stdout] test test_extract_token_from_header_success ... ok
[INFO] [stdout] test test_check_role_permission_other_roles ... ok
[INFO] [stdout] test test_extract_token_from_header_with_extra_spaces ... ok
[INFO] [stdout] test test_claims_serialization ... ok
[INFO] [stdout] test test_get_user_id_from_token_invalid_token ... ok
[INFO] [stdout] test test_jwt_error_display ... ok
[INFO] [stdout] test test_generate_refresh_token_success ... ok
[INFO] [stdout] test test_get_user_id_from_token_success ... ok
[INFO] [stdout] test test_generate_access_token_success ... ok
[INFO] [stdout] test test_authentication_flow ... ok
[INFO] [stdout] test test_generate_token_pair_success ... ok
[INFO] [stdout] test test_jwt_role_based_access_comprehensive ... ok
[INFO] [stdout] test test_jwt_claims_boundary_values ... ok
[INFO] [stdout] test test_jwt_token_expiration_edge_cases ... ok
[INFO] [stdout] test test_jwt_header_extraction_comprehensive ... ok
[INFO] [stdout] test test_token_pair_serialization ... ok
[INFO] [stdout] test test_token_contains_jti ... ok
[INFO] [stdout] test test_jwt_token_tamper_detection ... ok
[INFO] [stdout] test test_jwt_error_types_comprehensive ... ok
[INFO] [stdout] test test_jwt_token_refresh_workflow ... ok
[INFO] [stdout] test test_validate_access_token_wrong_type ... ok
[INFO] [stdout] test test_validate_malformed_token ... ok
[INFO] [stdout] test test_validate_token_with_invalid_secret ... ok
[INFO] [stdout] test test_validate_refresh_token_wrong_type ... ok
[INFO] [stderr]      Running tests/minio_tests.rs (/opt/rustwide/target/debug/deps/minio_tests-aadfda23a815d3d9)
[INFO] [stdout] test test_jwt_utils_creation ... ok
[INFO] [stdout] test test_trait_implementation ... ok
[INFO] [stdout] test test_jwt_concurrent_token_generation ... ok
[INFO] [stdout] test test_jwt_jti_uniqueness ... ok
[INFO] [stdout] test test_token_timestamps ... ok
[INFO] [stdout] test test_token_type_as_str ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 34 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 23 tests
[INFO] [stdout] test benchmark_tests::test_object_info_content_types ... ok
[INFO] [stdout] test edge_case_tests::test_object_info_with_edge_cases ... ok
[INFO] [stdout] test error_tests::test_minio_error_debug_format ... ok
[INFO] [stdout] test error_tests::test_minio_error_from_string ... ok
[INFO] [stdout] test edge_case_tests::test_minio_error_chain ... ok
[INFO] [stdout] test benchmark_tests::test_minio_service_config_validation ... ok
[INFO] [stdout] test integration_edge_cases::test_minio_error_scenarios ... ignored
[INFO] [stdout] test integration_edge_cases::test_minio_large_object_operations ... ignored
[INFO] [stdout] test integration_edge_cases::test_minio_special_character_objects ... ignored
[INFO] [stdout] test integration_edge_cases::test_minio_stress_operations ... ignored
[INFO] [stdout] test integration_tests::test_minio_service_creation ... ignored
[INFO] [stdout] test integration_tests::test_object_not_exists ... ignored
[INFO] [stdout] test integration_tests::test_put_and_get_object ... ignored
[INFO] [stdout] test edge_case_tests::test_minio_config_url_building ... ok
[INFO] [stdout] test object_info_tests::test_object_info_creation ... ok
[INFO] [stdout] test benchmark_tests::test_object_info_size_types ... ok
[INFO] [stdout] test object_info_tests::test_object_info_with_timestamp ... ok
[INFO] [stdout] test benchmark_tests::test_presigned_url_not_implemented ... ok
[INFO] [stdout] test object_info_tests::test_object_info_clone ... ok
[INFO] [stdout] test edge_case_tests::test_minio_config_validation_comprehensive ... ok
[INFO] [stdout] test benchmark_tests::test_minio_service_config_access ... ok
[INFO] [stdout] test object_info_tests::test_object_info_debug_format ... ok
[INFO] [stdout] test error_tests::test_minio_error_types ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 16 passed; 0 failed; 7 ignored; 0 measured; 0 filtered out; finished in 0.04s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/password_reset_tests.rs (/opt/rustwide/target/debug/deps/password_reset_tests-e5bb605ed8e2f009)
[INFO] [stdout] 
[INFO] [stdout] running 31 tests
[INFO] [stdout] test config_tests::test_config_validation_empty_base_url ... ok
[INFO] [stdout] test config_tests::test_config_validation_invalid_base_url ... ok
[INFO] [stdout] test config_tests::test_config_validation ... ok
[INFO] [stdout] test config_tests::test_config_validation_invalid_reset_path ... ok
[INFO] [stdout] test config_tests::test_config_validation_short_token_length ... ok
[INFO] [stdout] test config_tests::test_config_generate_reset_url_with_trailing_slash ... ok
[INFO] [stdout] test config_tests::test_config_generate_reset_url ... ok
[INFO] [stdout] test edge_case_tests::test_generate_reset_token_empty_email ... ok
[INFO] [stdout] test edge_case_tests::test_revoke_non_existent_token ... ok
[INFO] [stdout] test edge_case_tests::test_validate_reset_token_invalid_length ... ok
[INFO] [stdout] test edge_case_tests::test_validate_reset_token_empty ... ok
[INFO] [stdout] test edge_case_tests::test_unicode_in_user_data ... ok
[INFO] [stdout] test edge_case_tests::test_very_long_user_data ... ok
[INFO] [stdout] test error_tests::test_invalid_config_creation ... ok
[INFO] [stdout] test config_tests::test_config_get_redis_key ... ok
[INFO] [stdout] test edge_case_tests::test_validate_reset_token_not_found ... ok
[INFO] [stdout] test edge_case_tests::test_generate_reset_token_empty_user_id ... ok
[INFO] [stdout] test error_tests::test_password_reset_error_types ... ok
[INFO] [stdout] test unit_tests::test_reset_token_info_creation ... ok
[INFO] [stdout] test unit_tests::test_reset_token_info_expiration ... ok
[INFO] [stdout] test unit_tests::test_reset_token_info_used ... ok
[INFO] [stdout] test config_tests::test_config_validation_zero_expiration ... ok
[INFO] [stdout] [2m2026-01-07T03:24:00.191134Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Validating password reset configuration
[INFO] [stdout] [2m2026-01-07T03:24:00.191191Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Password reset configuration validation successful
[INFO] [stdout] [2m2026-01-07T03:24:00.191346Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset token for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.191455Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generated secure token of length: 16
[INFO] [stdout] [2m2026-01-07T03:24:00.191539Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Stored token info in Redis with key: test_reset_token:BB1zLtiEc4UYs4cG
[INFO] [stdout] [2m2026-01-07T03:24:00.191566Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.192007Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"BB1zLtiEc4UYs4cG" [3mtoken_preview[0m[2m=[0mBB1zLtiE[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.192068Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"BB1zLtiEc4UYs4cG" [3mtoken_preview[0m[2m=[0mBB1zLtiE[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] test unit_tests::test_validate_reset_token ... ok
[INFO] [stdout] [2m2026-01-07T03:24:00.193470Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Validating password reset configuration
[INFO] [stdout] [2m2026-01-07T03:24:00.193502Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Password reset configuration validation successful
[INFO] [stdout] [2m2026-01-07T03:24:00.193498Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Validating password reset configuration
[INFO] [stdout] [2m2026-01-07T03:24:00.193518Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Password reset configuration validation successful
[INFO] [stdout] [2m2026-01-07T03:24:00.193551Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset token for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.193566Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset token for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.193614Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generated secure token of length: 16
[INFO] [stdout] [2m2026-01-07T03:24:00.193622Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generated secure token of length: 16
[INFO] [stdout] [2m2026-01-07T03:24:00.193630Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Validating password reset configuration
[INFO] [stdout] [2m2026-01-07T03:24:00.193649Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Password reset configuration validation successful
[INFO] [stdout] [2m2026-01-07T03:24:00.193673Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Stored token info in Redis with key: test_reset_token:LRRik53xzEEAdUwT
[INFO] [stdout] [2m2026-01-07T03:24:00.193688Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Stored token info in Redis with key: test_reset_token:nXjZRa76tQGHQlFa
[INFO] [stdout] [2m2026-01-07T03:24:00.193698Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.193712Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.193762Z[0m [32m INFO[0m [1mrevoke_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"LRRik53xzEEAdUwT" [3mtoken_preview[0m[2m=[0mLRRik53x[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Revoking reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.193716Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset token for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.193808Z[0m [32m INFO[0m [1mrevoke_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"LRRik53xzEEAdUwT" [3mtoken_preview[0m[2m=[0mLRRik53x[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token revoked successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.193854Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generated secure token of length: 16
[INFO] [stdout] [2m2026-01-07T03:24:00.193858Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"LRRik53xzEEAdUwT" [3mtoken_preview[0m[2m=[0mLRRik53x[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.193891Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Stored token info in Redis with key: test_reset_token:ncVZmQK6Uh81b1LK
[INFO] [stdout] [2m2026-01-07T03:24:00.193908Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.193959Z[0m [32m INFO[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"ncVZmQK6Uh81b1LK" [3mtoken_preview[0m[2m=[0mncVZmQK6[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Using reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.194003Z[0m [34mDEBUG[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"ncVZmQK6Uh81b1LK" [3mtoken_preview[0m[2m=[0mncVZmQK6[1m}[0m[2m:[0m[1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"ncVZmQK6Uh81b1LK" [3mtoken_preview[0m[2m=[0mncVZmQK6[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.194047Z[0m [34mDEBUG[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"ncVZmQK6Uh81b1LK" [3mtoken_preview[0m[2m=[0mncVZmQK6[1m}[0m[2m:[0m[1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"ncVZmQK6Uh81b1LK" [3mtoken_preview[0m[2m=[0mncVZmQK6[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.194102Z[0m [34mDEBUG[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"ncVZmQK6Uh81b1LK" [3mtoken_preview[0m[2m=[0mncVZmQK6[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Updated token info in Redis with key: test_reset_token:ncVZmQK6Uh81b1LK
[INFO] [stdout] [2m2026-01-07T03:24:00.194123Z[0m [32m INFO[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"ncVZmQK6Uh81b1LK" [3mtoken_preview[0m[2m=[0mncVZmQK6[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token used successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.194163Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"ncVZmQK6Uh81b1LK" [3mtoken_preview[0m[2m=[0mncVZmQK6[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.194232Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Validating password reset configuration
[INFO] [stdout] [2m2026-01-07T03:24:00.194252Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Password reset configuration validation successful
[INFO] [stdout] [2m2026-01-07T03:24:00.194286Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset token for user: user123
[INFO] [stderr]      Running tests/password_tests.rs (/opt/rustwide/target/debug/deps/password_tests-2f6951f32dbe956f)
[INFO] [stdout] [2m2026-01-07T03:24:00.194346Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generated secure token of length: 16
[INFO] [stdout] [2m2026-01-07T03:24:00.194393Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Stored token info in Redis with key: test_reset_token:41JTjWkf9CHFFvOe
[INFO] [stdout] [2m2026-01-07T03:24:00.194417Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.194493Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset token for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.194518Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generated secure token of length: 16
[INFO] [stdout] [2m2026-01-07T03:24:00.194556Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Stored token info in Redis with key: test_reset_token:k8flkXfuQaAQ2LwP
[INFO] [stdout] [2m2026-01-07T03:24:00.194578Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.194628Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset token for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.194649Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generated secure token of length: 16
[INFO] [stdout] [2m2026-01-07T03:24:00.194699Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Stored token info in Redis with key: test_reset_token:VNYoVkMXB9Yrvsf2
[INFO] [stdout] [2m2026-01-07T03:24:00.194720Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.194769Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"41JTjWkf9CHFFvOe" [3mtoken_preview[0m[2m=[0m41JTjWkf[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.194807Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"41JTjWkf9CHFFvOe" [3mtoken_preview[0m[2m=[0m41JTjWkf[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.194861Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"k8flkXfuQaAQ2LwP" [3mtoken_preview[0m[2m=[0mk8flkXfu[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.194899Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"k8flkXfuQaAQ2LwP" [3mtoken_preview[0m[2m=[0mk8flkXfu[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.194951Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"VNYoVkMXB9Yrvsf2" [3mtoken_preview[0m[2m=[0mVNYoVkMX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.194987Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"VNYoVkMXB9Yrvsf2" [3mtoken_preview[0m[2m=[0mVNYoVkMX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.195037Z[0m [32m INFO[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"41JTjWkf9CHFFvOe" [3mtoken_preview[0m[2m=[0m41JTjWkf[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Using reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.195073Z[0m [34mDEBUG[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"41JTjWkf9CHFFvOe" [3mtoken_preview[0m[2m=[0m41JTjWkf[1m}[0m[2m:[0m[1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"41JTjWkf9CHFFvOe" [3mtoken_preview[0m[2m=[0m41JTjWkf[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.195115Z[0m [34mDEBUG[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"41JTjWkf9CHFFvOe" [3mtoken_preview[0m[2m=[0m41JTjWkf[1m}[0m[2m:[0m[1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"41JTjWkf9CHFFvOe" [3mtoken_preview[0m[2m=[0m41JTjWkf[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.195181Z[0m [34mDEBUG[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"41JTjWkf9CHFFvOe" [3mtoken_preview[0m[2m=[0m41JTjWkf[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Updated token info in Redis with key: test_reset_token:41JTjWkf9CHFFvOe
[INFO] [stdout] [2m2026-01-07T03:24:00.195209Z[0m [32m INFO[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"41JTjWkf9CHFFvOe" [3mtoken_preview[0m[2m=[0m41JTjWkf[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token used successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.195259Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Validating password reset configuration
[INFO] [stdout] [2m2026-01-07T03:24:00.195260Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"k8flkXfuQaAQ2LwP" [3mtoken_preview[0m[2m=[0mk8flkXfu[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.195277Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Password reset configuration validation successful
[INFO] [stdout] [2m2026-01-07T03:24:00.195298Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"k8flkXfuQaAQ2LwP" [3mtoken_preview[0m[2m=[0mk8flkXfu[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.195323Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset token for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.195351Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"VNYoVkMXB9Yrvsf2" [3mtoken_preview[0m[2m=[0mVNYoVkMX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.195377Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generated secure token of length: 16
[INFO] [stdout] [2m2026-01-07T03:24:00.195388Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"VNYoVkMXB9Yrvsf2" [3mtoken_preview[0m[2m=[0mVNYoVkMX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.195416Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Stored token info in Redis with key: test_reset_token:2I5M01g4VpgluJnX
[INFO] [stdout] [2m2026-01-07T03:24:00.195435Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.195449Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"41JTjWkf9CHFFvOe" [3mtoken_preview[0m[2m=[0m41JTjWkf[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.195489Z[0m [33m WARN[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"41JTjWkf9CHFFvOe" [3mtoken_preview[0m[2m=[0m41JTjWkf[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Attempted to use already used token
[INFO] [stdout] test unit_tests::test_revoke_reset_token ... ok
[INFO] [stdout] test unit_tests::test_generate_reset_token ... ok
[INFO] [stdout] test workflow_tests::test_multiple_tokens_for_same_user ... ok
[INFO] [stdout] [2m2026-01-07T03:24:00.193763Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"nXjZRa76tQGHQlFa" [3mtoken_preview[0m[2m=[0mnXjZRa76[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.197728Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Validating password reset configuration
[INFO] [stdout] [2m2026-01-07T03:24:00.197751Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Password reset configuration validation successful
[INFO] [stdout] [2m2026-01-07T03:24:00.197772Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"nXjZRa76tQGHQlFa" [3mtoken_preview[0m[2m=[0mnXjZRa76[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] test unit_tests::test_password_reset_service_creation ... ok
[INFO] [stdout] [2m2026-01-07T03:24:00.197840Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Validating password reset configuration
[INFO] [stdout] [2m2026-01-07T03:24:00.197841Z[0m [32m INFO[0m [1mrevoke_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"nXjZRa76tQGHQlFa" [3mtoken_preview[0m[2m=[0mnXjZRa76[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Revoking reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.197855Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Password reset configuration validation successful
[INFO] [stdout] [2m2026-01-07T03:24:00.197864Z[0m [32m INFO[0m [1mrevoke_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"nXjZRa76tQGHQlFa" [3mtoken_preview[0m[2m=[0mnXjZRa76[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token revoked successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.197892Z[0m [32m INFO[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset URL for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.197900Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset token for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.197920Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generated secure token of length: 16
[INFO] [stdout] [2m2026-01-07T03:24:00.197930Z[0m [32m INFO[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m[1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset token for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.197951Z[0m [34mDEBUG[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Stored token info in Redis with key: test_reset_token:7Bt4EVZAkxhKhX25
[INFO] [stdout] [2m2026-01-07T03:24:00.197966Z[0m [32m INFO[0m [1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.197986Z[0m [34mDEBUG[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m[1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generated secure token of length: 16
[INFO] [stdout] [2m2026-01-07T03:24:00.198003Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"nXjZRa76tQGHQlFa" [3mtoken_preview[0m[2m=[0mnXjZRa76[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.198024Z[0m [34mDEBUG[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m[1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Stored token info in Redis with key: test_reset_token:KgOUyera4if8pI0c
[INFO] [stdout] [2m2026-01-07T03:24:00.198042Z[0m [32m INFO[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m[1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.198045Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"7Bt4EVZAkxhKhX25" [3mtoken_preview[0m[2m=[0m7Bt4EVZA[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.198076Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"7Bt4EVZAkxhKhX25" [3mtoken_preview[0m[2m=[0m7Bt4EVZA[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.198084Z[0m [32m INFO[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset URL generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.198102Z[0m [34mDEBUG[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset URL: http://localhost:3000/reset-password/KgOUyera4if8pI0c
[INFO] [stdout] test workflow_tests::test_revoke_and_regenerate_workflow ... ok
[INFO] [stdout] test unit_tests::test_generate_reset_url ... ok
[INFO] [stdout] [2m2026-01-07T03:24:00.198603Z[0m [33m WARN[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"ncVZmQK6Uh81b1LK" [3mtoken_preview[0m[2m=[0mncVZmQK6[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Attempted to use already used token
[INFO] [stdout] test unit_tests::test_use_reset_token ... ok
[INFO] [stdout] [2m2026-01-07T03:24:00.199722Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Validating password reset configuration
[INFO] [stdout] [2m2026-01-07T03:24:00.199753Z[0m [32m INFO[0m [2melhaiba_backend::config::password_reset_conf[0m[2m:[0m Password reset configuration validation successful
[INFO] [stdout] [2m2026-01-07T03:24:00.199788Z[0m [32m INFO[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset URL for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.201714Z[0m [32m INFO[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m[1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generating reset token for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.201837Z[0m [34mDEBUG[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m[1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Generated secure token of length: 16
[INFO] [stdout] [2m2026-01-07T03:24:00.201932Z[0m [34mDEBUG[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m[1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Stored token info in Redis with key: test_reset_token:stSGKRwX7sjNpdiR
[INFO] [stdout] [2m2026-01-07T03:24:00.201992Z[0m [32m INFO[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m[1mgenerate_reset_token[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.202064Z[0m [32m INFO[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset URL generated successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.202118Z[0m [34mDEBUG[0m [1mgenerate_reset_url[0m[1m{[0m[3muser_id[0m[2m=[0muser123 [3memail[0m[2m=[0muser@example.com[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset URL: http://localhost:3000/reset-password/stSGKRwX7sjNpdiR
[INFO] [stdout] [2m2026-01-07T03:24:00.202196Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"stSGKRwX7sjNpdiR" [3mtoken_preview[0m[2m=[0mstSGKRwX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.202278Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"stSGKRwX7sjNpdiR" [3mtoken_preview[0m[2m=[0mstSGKRwX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.202368Z[0m [32m INFO[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"stSGKRwX7sjNpdiR" [3mtoken_preview[0m[2m=[0mstSGKRwX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Using reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.202455Z[0m [34mDEBUG[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"stSGKRwX7sjNpdiR" [3mtoken_preview[0m[2m=[0mstSGKRwX[1m}[0m[2m:[0m[1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"stSGKRwX7sjNpdiR" [3mtoken_preview[0m[2m=[0mstSGKRwX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.202526Z[0m [34mDEBUG[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"stSGKRwX7sjNpdiR" [3mtoken_preview[0m[2m=[0mstSGKRwX[1m}[0m[2m:[0m[1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"stSGKRwX7sjNpdiR" [3mtoken_preview[0m[2m=[0mstSGKRwX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token validated successfully
[INFO] [stdout] [2m2026-01-07T03:24:00.202627Z[0m [34mDEBUG[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"stSGKRwX7sjNpdiR" [3mtoken_preview[0m[2m=[0mstSGKRwX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Updated token info in Redis with key: test_reset_token:stSGKRwX7sjNpdiR
[INFO] [stdout] [2m2026-01-07T03:24:00.204715Z[0m [32m INFO[0m [1muse_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"stSGKRwX7sjNpdiR" [3mtoken_preview[0m[2m=[0mstSGKRwX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Reset token used successfully for user: user123
[INFO] [stdout] [2m2026-01-07T03:24:00.204825Z[0m [34mDEBUG[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"stSGKRwX7sjNpdiR" [3mtoken_preview[0m[2m=[0mstSGKRwX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Validating reset token
[INFO] [stdout] [2m2026-01-07T03:24:00.204892Z[0m [33m WARN[0m [1mvalidate_reset_token[0m[1m{[0m[3mtoken[0m[2m=[0m"stSGKRwX7sjNpdiR" [3mtoken_preview[0m[2m=[0mstSGKRwX[1m}[0m[2m:[0m [2melhaiba_backend::util::password_reset[0m[2m:[0m Attempted to use already used token
[INFO] [stdout] test workflow_tests::test_complete_password_reset_workflow ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 31 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.08s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 44 tests
[INFO] [stdout] test test_generate_random_password_different_results ... ok
[INFO] [stdout] test test_generate_random_password_minimum_length ... ok
[INFO] [stdout] test test_generate_random_password_basic ... ok
[INFO] [stdout] test test_generate_random_password_character_distribution ... ok
[INFO] [stdout] test test_generate_random_password_large_length ... ok
[INFO] [stdout] test test_generate_random_password_default_length ... ok
[INFO] [stdout] test test_generate_random_password_uniqueness ... ok
[INFO] [stdout] test test_generate_random_password_various_lengths ... ok
[INFO] [stdout] test test_hash_password_very_long_password ... ok
[INFO] [stdout] test test_hash_password_unicode_characters ... ok
[INFO] [stdout] test test_hash_password_empty_password ... ok
[INFO] [stdout] test test_password_error_display ... ok
[INFO] [stdout] test test_hash_password_success ... ok
[INFO] [stdout] test test_boundary_conditions ... ok
[INFO] [stdout] test test_hash_password_different_results ... ok
[INFO] [stdout] test test_random_password_uniqueness ... ok
[INFO] [stdout] test test_hash_password_consistent_length_range ... ok
[INFO] [stdout] test test_validate_password_strength_all_special_chars ... ok
[INFO] [stdout] test test_validate_password_strength_comprehensive ... ok
[INFO] [stdout] test test_validate_password_strength_edge_cases ... ok
[INFO] [stdout] test test_validate_password_strength_multiple_errors ... ok
[INFO] [stdout] test test_validate_password_strength_no_digit ... ok
[INFO] [stdout] test test_validate_password_strength_no_lowercase ... ok
[INFO] [stdout] test test_validate_password_strength_no_special_char ... ok
[INFO] [stdout] test test_validate_password_strength_no_uppercase ... ok
[INFO] [stdout] test test_validate_password_strength_specific_errors ... ok
[INFO] [stdout] test test_validate_password_strength_too_short ... ok
[INFO] [stdout] test test_validate_password_strength_valid_password ... ok
[INFO] [stdout] test test_validate_password_strength_with_test_data ... ok
[INFO] [stdout] test test_password_workflow ... ok
[INFO] [stdout] test test_trait_implementation ... ok
[INFO] [stdout] test test_verify_password_empty_hash ... ok
[INFO] [stdout] test test_edge_case_passwords ... ok
[INFO] [stdout] test test_password_workflow_integration ... ok
[INFO] [stdout] test test_verify_password_invalid_hash_format ... ok
[INFO] [stdout] test test_verify_password_malformed_argon2_hash ... ok
[INFO] [stdout] test test_verify_password_correct ... ok
[INFO] [stdout] test test_verify_password_empty_password ... ok
[INFO] [stdout] test test_verify_password_incorrect ... ok
[INFO] [stdout] test test_password_timing_attack_resistance ... ok
[INFO] [stdout] test test_verify_password_case_sensitive ... ok
[INFO] [stdout] test test_verify_password_unicode ... ok
[INFO] [stdout] test test_password_hash_format_consistency ... ok
[INFO] [stdout] test test_hash_verification_consistency has been running for over 60 seconds
[INFO] [stdout] test test_hash_verification_consistency ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 44 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 77.44s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/redis_tests.rs (/opt/rustwide/target/debug/deps/redis_tests-2cb978442c836ddc)
[INFO] [stdout] 
[INFO] [stdout] running 31 tests
[INFO] [stdout] test integration_error_tests::test_redis_connection_with_wrong_credentials ... ignored
[INFO] [stdout] test integration_error_tests::test_redis_large_data_operations ... ignored
[INFO] [stdout] test integration_error_tests::test_redis_operations_with_invalid_data ... ignored
[INFO] [stdout] test integration_tests::test_expiration_operations ... ignored
[INFO] [stdout] test integration_tests::test_hash_operations ... ignored
[INFO] [stdout] test integration_tests::test_increment_operations ... ignored
[INFO] [stdout] test integration_tests::test_list_operations ... ignored
[INFO] [stdout] test integration_tests::test_ping_operation ... ignored
[INFO] [stdout] test integration_tests::test_redis_service_creation ... ignored
[INFO] [stdout] test integration_tests::test_set_operations ... ignored
[INFO] [stdout] test integration_tests::test_string_operations ... ignored
[INFO] [stdout] test error_tests::test_redis_error_types ... ok
[INFO] [stdout] test error_tests::test_redis_error_from_string ... ok
[INFO] [stdout] test performance_tests::test_config_creation_performance ... ok
[INFO] [stdout] test edge_case_tests::test_redis_error_display_formatting ... ok
[INFO] [stdout] test error_tests::test_redis_error_debug_format ... ok
[INFO] [stdout] test edge_case_tests::test_redis_config_validation_comprehensive ... ok
[INFO] [stdout] test edge_case_tests::test_redis_config_url_generation_edge_cases ... ok
[INFO] [stdout] test serialization_tests::test_test_data_serialization ... ok
[INFO] [stdout] test serialization_tests::test_complex_data_serialization ... ok
[INFO] [stdout] test service_tests::test_redis_service_config_access ... ok
[INFO] [stdout] test service_tests::test_redis_config_connection_urls ... ok
[INFO] [stdout] test edge_case_tests::test_test_data_serialization_edge_cases ... ok
[INFO] [stdout] test service_tests::test_test_data_creation ... ok
[INFO] [stdout] test service_tests::test_redis_service_config_validation ... ok
[INFO] [stdout] test service_tests::test_test_data_clone ... ok
[INFO] [stdout] test performance_tests::test_deserialization_performance ... ok
[INFO] [stdout] test serialization_tests::test_various_data_types ... ok
[INFO] [stdout] test performance_tests::test_serialization_performance ... ok
[INFO] [stdout] test stress_tests::test_large_data_serialization ... ok
[INFO] [stdout] test stress_tests::test_config_creation_stress ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 20 passed; 0 failed; 11 ignored; 0 measured; 0 filtered out; finished in 0.37s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests elhaiba_backend
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "77ad0158bc69c052a096fa4256b1c20fdf44860eedb5ee1c5d93ea892da7f137", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "77ad0158bc69c052a096fa4256b1c20fdf44860eedb5ee1c5d93ea892da7f137", kill_on_drop: false }`
[INFO] [stdout] 77ad0158bc69c052a096fa4256b1c20fdf44860eedb5ee1c5d93ea892da7f137
