[INFO] cloning repository https://github.com/PatalJunior/axum-backend-nanomon
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/PatalJunior/axum-backend-nanomon" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FPatalJunior%2Faxum-backend-nanomon", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FPatalJunior%2Faxum-backend-nanomon'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 2d0d8f4e3638bb2a2e06f6b3165543ed3336567a
[INFO] checking PatalJunior/axum-backend-nanomon against try#4f260f0f20b3133d20cfb50353c0221943af5796+rustflags=-Dunmustuse_in_always_ok for pr-148577
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FPatalJunior%2Faxum-backend-nanomon" "/workspace/builds/worker-3-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/PatalJunior/axum-backend-nanomon
[INFO] finished tweaking git repo https://github.com/PatalJunior/axum-backend-nanomon
[INFO] tweaked toml for git repo https://github.com/PatalJunior/axum-backend-nanomon written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/PatalJunior/axum-backend-nanomon on toolchain 4f260f0f20b3133d20cfb50353c0221943af5796
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+4f260f0f20b3133d20cfb50353c0221943af5796" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/PatalJunior/axum-backend-nanomon 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" "+4f260f0f20b3133d20cfb50353c0221943af5796" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+4f260f0f20b3133d20cfb50353c0221943af5796" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 89ef099a9e7521eb3af470eecd410967d0671b55bed16d2dcf1905ef1773338f
[INFO] running `Command { std: "docker" "start" "-a" "89ef099a9e7521eb3af470eecd410967d0671b55bed16d2dcf1905ef1773338f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "89ef099a9e7521eb3af470eecd410967d0671b55bed16d2dcf1905ef1773338f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "89ef099a9e7521eb3af470eecd410967d0671b55bed16d2dcf1905ef1773338f", kill_on_drop: false }`
[INFO] [stdout] 89ef099a9e7521eb3af470eecd410967d0671b55bed16d2dcf1905ef1773338f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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 -Dunmustuse_in_always_ok" "-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+4f260f0f20b3133d20cfb50353c0221943af5796" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c73cc30266d768d2f702a888cfafdf83aecf16b2a13ebadb9c23e7351ec57a42
[INFO] running `Command { std: "docker" "start" "-a" "c73cc30266d768d2f702a888cfafdf83aecf16b2a13ebadb9c23e7351ec57a42", kill_on_drop: false }`
[INFO] [stderr]    Compiling typenum v1.18.0
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling pq-sys v0.7.2
[INFO] [stderr]    Compiling syn v2.0.104
[INFO] [stderr]    Compiling indexmap v2.10.0
[INFO] [stderr]     Checking rand_core v0.9.3
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling winnow v0.7.11
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking const-oid v0.10.1
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking rand_chacha v0.9.0
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking password-hash v0.5.0
[INFO] [stderr]     Checking rand v0.9.1
[INFO] [stderr]     Checking generic-array v0.14.7
[INFO] [stderr]     Checking hybrid-array v0.3.1
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]     Checking crypto-common v0.1.6
[INFO] [stderr]     Checking block-buffer v0.11.0-rc.4
[INFO] [stderr]     Checking crypto-common v0.2.0-rc.3
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking blake2 v0.10.6
[INFO] [stderr]     Checking headers v0.4.1
[INFO] [stderr]     Checking argon2 v0.5.3
[INFO] [stderr]     Checking digest v0.11.0-rc.0
[INFO] [stderr]     Checking sha2 v0.11.0-rc.0
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling diesel_table_macro_syntax v0.2.0
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling axum-macros v0.5.0
[INFO] [stderr]     Checking tokio v1.46.0
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking axum-core v0.5.2
[INFO] [stderr]     Checking tracing-subscriber v0.3.19
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling dsl_auto_type v0.1.3
[INFO] [stderr]    Compiling diesel_derives v2.2.6
[INFO] [stderr]     Checking serde v1.0.219
[INFO] [stderr]     Checking deadpool-runtime v0.1.4
[INFO] [stderr]     Checking hyper v1.6.0
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking deadpool v0.12.2
[INFO] [stderr]     Checking deadpool-sync v0.1.4
[INFO] [stderr]     Checking hyper-util v0.1.14
[INFO] [stderr]     Checking serde_spanned v0.6.9
[INFO] [stderr]     Checking toml_datetime v0.6.11
[INFO] [stderr]     Checking uuid v1.17.0
[INFO] [stderr]     Checking chrono v0.4.41
[INFO] [stderr]     Checking serde_path_to_error v0.1.17
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking toml_edit v0.22.27
[INFO] [stderr]     Checking axum v0.8.4
[INFO] [stderr]     Checking toml v0.8.23
[INFO] [stderr]     Checking migrations_internals v2.2.0
[INFO] [stderr]     Checking diesel v2.2.11
[INFO] [stderr]    Compiling migrations_macros v2.2.0
[INFO] [stderr]     Checking axum-extra v0.10.1
[INFO] [stderr]     Checking deadpool-diesel v0.6.1
[INFO] [stderr]     Checking diesel_migrations v2.2.0
[INFO] [stderr]     Checking axum-diesel-real-world v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `crate::infra::db::schema::tokens::previous_token_id`
[INFO] [stdout]  --> src/domain/models/token.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::infra::db::schema::tokens::previous_token_id;
[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: `OptionalExtension`
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:2:58
[INFO] [stdout]   |
[INFO] [stdout] 2 | use diesel::{AsChangeset, ExpressionMethods, Insertable, OptionalExtension, QueryDsl, Queryable, RunQueryDsl, Selectable, SelectableHelper};
[INFO] [stdout]   |                                                          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TokenError`
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:5:36
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::domain::models::token::{TokenError, TokenModel};
[INFO] [stdout]   |                                    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::infra::db::schema::tokens::previous_token_id`
[INFO] [stdout]  --> src/domain/models/token.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::infra::db::schema::tokens::previous_token_id;
[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: `OptionalExtension`
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:2:58
[INFO] [stdout]   |
[INFO] [stdout] 2 | use diesel::{AsChangeset, ExpressionMethods, Insertable, OptionalExtension, QueryDsl, Queryable, RunQueryDsl, Selectable, SelectableHelper};
[INFO] [stdout]   |                                                          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TokenError`
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:5:36
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::domain::models::token::{TokenError, TokenModel};
[INFO] [stdout]   |                                    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TokenModel` is never constructed
[INFO] [stdout]   --> src/domain/models/token.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct TokenModel {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TokenError` is never used
[INFO] [stdout]   --> src/domain/models/token.rs:25:10
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub enum TokenError {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreatTokenRequest` is never constructed
[INFO] [stdout]   --> src/handlers/tokens/mod.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct CreatTokenRequest {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TokenResponse` is never constructed
[INFO] [stdout]   --> src/handlers/tokens/mod.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct TokenResponse {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hash_token` is never used
[INFO] [stdout]   --> src/handlers/tokens/create_token.rs:14:4
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn hash_token(token: &str) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_token` is never used
[INFO] [stdout]   --> src/handlers/tokens/create_token.rs:22:14
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub async fn create_token(
[INFO] [stdout]    |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TokenDb` is never constructed
[INFO] [stdout]   --> src/infra/repositories/token_repository.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct TokenDb {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TokensFilter` is never constructed
[INFO] [stdout]   --> src/infra/repositories/token_repository.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub struct TokensFilter {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `insert` is never used
[INFO] [stdout]   --> src/infra/repositories/token_repository.rs:54:14
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub async fn insert(
[INFO] [stdout]    |              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get` is never used
[INFO] [stdout]   --> src/infra/repositories/token_repository.rs:73:14
[INFO] [stdout]    |
[INFO] [stdout] 73 | pub async fn get(
[INFO] [stdout]    |              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_all` is never used
[INFO] [stdout]   --> src/infra/repositories/token_repository.rs:92:14
[INFO] [stdout]    |
[INFO] [stdout] 92 | pub async fn get_all(
[INFO] [stdout]    |              ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `update` is never used
[INFO] [stdout]    --> src/infra/repositories/token_repository.rs:129:14
[INFO] [stdout]     |
[INFO] [stdout] 129 | pub async fn update(
[INFO] [stdout]     |              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `adapt_token_db_to_token` is never used
[INFO] [stdout]    --> src/infra/repositories/token_repository.rs:151:4
[INFO] [stdout]     |
[INFO] [stdout] 151 | fn adapt_token_db_to_token(token_db: TokenDb) -> TokenModel {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, uuid::Uuid>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: requested on the command line with `-D unmustuse-in-always-ok`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<uuid::Uuid, Infallible>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<std::string::String, Infallible>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, bool>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<bool, Infallible>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, NaiveDate>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<NaiveDate, Infallible>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, uuid::Uuid>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<uuid::Uuid, Infallible>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, uuid::Uuid>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<std::string::String, Infallible>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, DateTime<Utc>>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<DateTime<Utc>, Infallible>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, DateTime<Utc>>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::option::Option<DateTime<Utc>>>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<std::option::Option<DateTime<Utc>>, Infallible>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::option::Option<uuid::Uuid>>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<std::option::Option<uuid::Uuid>, Infallible>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::option::Option<uuid::Uuid>>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `axum-diesel-real-world` (bin "axum-diesel-real-world") due to 25 previous errors; 16 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] warning: struct `TokenModel` is never constructed
[INFO] [stdout]   --> src/domain/models/token.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct TokenModel {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TokenError` is never used
[INFO] [stdout]   --> src/domain/models/token.rs:25:10
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub enum TokenError {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreatTokenRequest` is never constructed
[INFO] [stdout]   --> src/handlers/tokens/mod.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct CreatTokenRequest {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TokenResponse` is never constructed
[INFO] [stdout]   --> src/handlers/tokens/mod.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct TokenResponse {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hash_token` is never used
[INFO] [stdout]   --> src/handlers/tokens/create_token.rs:14:4
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn hash_token(token: &str) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_token` is never used
[INFO] [stdout]   --> src/handlers/tokens/create_token.rs:22:14
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub async fn create_token(
[INFO] [stdout]    |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TokenDb` is never constructed
[INFO] [stdout]   --> src/infra/repositories/token_repository.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct TokenDb {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TokensFilter` is never constructed
[INFO] [stdout]   --> src/infra/repositories/token_repository.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub struct TokensFilter {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `insert` is never used
[INFO] [stdout]   --> src/infra/repositories/token_repository.rs:54:14
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub async fn insert(
[INFO] [stdout]    |              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get` is never used
[INFO] [stdout]   --> src/infra/repositories/token_repository.rs:73:14
[INFO] [stdout]    |
[INFO] [stdout] 73 | pub async fn get(
[INFO] [stdout]    |              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_all` is never used
[INFO] [stdout]   --> src/infra/repositories/token_repository.rs:92:14
[INFO] [stdout]    |
[INFO] [stdout] 92 | pub async fn get_all(
[INFO] [stdout]    |              ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `update` is never used
[INFO] [stdout]    --> src/infra/repositories/token_repository.rs:129:14
[INFO] [stdout]     |
[INFO] [stdout] 129 | pub async fn update(
[INFO] [stdout]     |              ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `adapt_token_db_to_token` is never used
[INFO] [stdout]    --> src/infra/repositories/token_repository.rs:151:4
[INFO] [stdout]     |
[INFO] [stdout] 151 | fn adapt_token_db_to_token(token_db: TokenDb) -> TokenModel {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, uuid::Uuid>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: requested on the command line with `-D unmustuse-in-always-ok`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<uuid::Uuid, Infallible>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<std::string::String, Infallible>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, bool>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<bool, Infallible>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, NaiveDate>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<NaiveDate, Infallible>
[INFO] [stdout]   --> src/infra/repositories/user_repository.rs:10:21
[INFO] [stdout]    |
[INFO] [stdout] 10 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, uuid::Uuid>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<uuid::Uuid, Infallible>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, uuid::Uuid>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<std::string::String, Infallible>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, DateTime<Utc>>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<DateTime<Utc>, Infallible>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, DateTime<Utc>>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::option::Option<DateTime<Utc>>>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<std::option::Option<DateTime<Utc>>, Infallible>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::string::String>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::option::Option<uuid::Uuid>>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: Result<std::option::Option<uuid::Uuid>, Infallible>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: this error originates in the derive macro `Queryable` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: this type will no longer be must used: ControlFlow<Result<Infallible, Infallible>, std::option::Option<uuid::Uuid>>
[INFO] [stdout]  --> src/infra/repositories/token_repository.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | #[derive(Serialize, Queryable, Selectable)]
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `axum-diesel-real-world` (bin "axum-diesel-real-world" test) due to 25 previous errors; 16 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "c73cc30266d768d2f702a888cfafdf83aecf16b2a13ebadb9c23e7351ec57a42", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c73cc30266d768d2f702a888cfafdf83aecf16b2a13ebadb9c23e7351ec57a42", kill_on_drop: false }`
[INFO] [stdout] c73cc30266d768d2f702a888cfafdf83aecf16b2a13ebadb9c23e7351ec57a42
