[INFO] cloning repository https://github.com/krishna-prakash/learning-axum
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/krishna-prakash/learning-axum" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkrishna-prakash%2Flearning-axum", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkrishna-prakash%2Flearning-axum'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] d04f4acebbaa175a180a5829f4f5306755b1e2a7
[INFO] checking krishna-prakash/learning-axum against master#57f772f25c5ce2bd870d6f8c3ab318eaee5a3326 for pr-133502-22
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkrishna-prakash%2Flearning-axum" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/krishna-prakash/learning-axum
[INFO] finished tweaking git repo https://github.com/krishna-prakash/learning-axum
[INFO] tweaked toml for git repo https://github.com/krishna-prakash/learning-axum written to /workspace/builds/worker-4-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/krishna-prakash/learning-axum on toolchain 57f772f25c5ce2bd870d6f8c3ab318eaee5a3326
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/krishna-prakash/learning-axum 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" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded uuid v1.23.0
[INFO] [stderr]   Downloaded async-compression v0.4.41
[INFO] [stderr]   Downloaded redox_syscall v0.7.4
[INFO] [stderr]   Downloaded jsonwebtoken v10.3.0
[INFO] [stderr]   Downloaded tokio v1.51.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 11e36b91ca5fa8e491296fe455956cc25d623668140e1d3dbcf705db441fb3fa
[INFO] running `Command { std: "docker" "start" "-a" "11e36b91ca5fa8e491296fe455956cc25d623668140e1d3dbcf705db441fb3fa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "11e36b91ca5fa8e491296fe455956cc25d623668140e1d3dbcf705db441fb3fa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "11e36b91ca5fa8e491296fe455956cc25d623668140e1d3dbcf705db441fb3fa", kill_on_drop: false }`
[INFO] [stdout] 11e36b91ca5fa8e491296fe455956cc25d623668140e1d3dbcf705db441fb3fa
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+57f772f25c5ce2bd870d6f8c3ab318eaee5a3326" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1c41940e49cf9e908e74e6297b3e70b617e5610c71a2ad4ddc17dfd3d8aaaa47
[INFO] running `Command { std: "docker" "start" "-a" "1c41940e49cf9e908e74e6297b3e70b617e5610c71a2ad4ddc17dfd3d8aaaa47", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.184
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]     Checking subtle v2.6.1
[INFO] [stderr]    Compiling zerovec-derive v0.11.3
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling zerocopy v0.8.48
[INFO] [stderr]    Compiling stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling zerofrom v0.1.7
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking generic-array v0.14.7
[INFO] [stderr]     Checking base64ct v1.8.3
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]     Checking yoke v0.8.2
[INFO] [stderr]    Compiling tokio-macros v2.7.0
[INFO] [stderr]    Compiling writeable v0.6.3
[INFO] [stderr]    Compiling litemap v0.8.2
[INFO] [stderr]    Compiling utf8_iter v1.0.4
[INFO] [stderr]    Compiling icu_normalizer_data v2.2.0
[INFO] [stderr]    Compiling icu_properties_data v2.2.0
[INFO] [stderr]     Checking pem-rfc7468 v0.7.0
[INFO] [stderr]     Checking futures-io v0.3.32
[INFO] [stderr]    Compiling futures-core v0.3.32
[INFO] [stderr]     Checking der v0.7.10
[INFO] [stderr]     Checking futures-util v0.3.32
[INFO] [stderr]     Checking tracing v0.1.44
[INFO] [stderr]     Checking thiserror v2.0.18
[INFO] [stderr]     Checking spin v0.9.8
[INFO] [stderr]    Compiling lock_api v0.4.14
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]     Checking crypto-common v0.1.7
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]    Compiling zerotrie v0.2.4
[INFO] [stderr]    Compiling allocator-api2 v0.2.21
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]    Compiling tinyvec v1.11.0
[INFO] [stderr]     Checking hmac v0.12.1
[INFO] [stderr]     Checking sha2 v0.10.9
[INFO] [stderr]     Checking getrandom v0.2.17
[INFO] [stderr]     Checking errno v0.3.14
[INFO] [stderr]     Checking socket2 v0.6.3
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking mio v1.2.0
[INFO] [stderr]     Checking hkdf v0.12.4
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]     Checking signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling zerovec v0.11.6
[INFO] [stderr]     Checking ff v0.13.1
[INFO] [stderr]     Checking signature v2.2.0
[INFO] [stderr]     Checking spki v0.7.3
[INFO] [stderr]     Checking group v0.13.0
[INFO] [stderr]     Checking crypto-bigint v0.5.5
[INFO] [stderr]     Checking getrandom v0.3.4
[INFO] [stderr]     Checking pkcs8 v0.10.2
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling form_urlencoded v1.2.2
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]     Checking sec1 v0.7.3
[INFO] [stderr]    Compiling zmij v1.0.21
[INFO] [stderr]     Checking tinystr v0.8.3
[INFO] [stderr]     Checking icu_locale_core v2.2.0
[INFO] [stderr]     Checking potential_utf v0.1.5
[INFO] [stderr]    Compiling cpufeatures v0.2.17
[INFO] [stderr]    Compiling futures-task v0.3.32
[INFO] [stderr]     Checking icu_collections v2.2.0
[INFO] [stderr]    Compiling hashbrown v0.17.0
[INFO] [stderr]    Compiling iana-time-zone v0.1.65
[INFO] [stderr]    Compiling tokio v1.51.1
[INFO] [stderr]    Compiling semver v1.0.28
[INFO] [stderr]    Compiling slab v0.4.12
[INFO] [stderr]    Compiling event-listener v5.4.1
[INFO] [stderr]    Compiling crc v3.4.0
[INFO] [stderr]    Compiling rustc_version v0.4.1
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling hashlink v0.10.0
[INFO] [stderr]     Checking rand_core v0.9.5
[INFO] [stderr]     Checking icu_provider v2.2.0
[INFO] [stderr]    Compiling unicode-normalization v0.1.25
[INFO] [stderr]    Compiling crossbeam-queue v0.3.12
[INFO] [stderr]    Compiling indexmap v2.14.0
[INFO] [stderr]     Checking lazy_static v1.5.0
[INFO] [stderr]    Compiling unicode-properties v0.1.4
[INFO] [stderr]    Compiling uuid v1.23.0
[INFO] [stderr]     Checking simd-adler32 v0.3.9
[INFO] [stderr]     Checking icu_properties v2.2.0
[INFO] [stderr]    Compiling unicode-bidi v0.3.18
[INFO] [stderr]     Checking serde_json v1.0.149
[INFO] [stderr]     Checking elliptic-curve v0.13.8
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]    Compiling stringprep v0.1.5
[INFO] [stderr]     Checking smallvec v1.15.1
[INFO] [stderr]    Compiling curve25519-dalek v4.1.3
[INFO] [stderr]     Checking getrandom v0.4.2
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking icu_normalizer v2.2.0
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]     Checking rfc6979 v0.4.0
[INFO] [stderr]    Compiling atoi v2.0.0
[INFO] [stderr]    Compiling futures-channel v0.3.32
[INFO] [stderr]    Compiling whoami v1.6.1
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]    Compiling home v0.5.12
[INFO] [stderr]    Compiling num-conv v0.2.1
[INFO] [stderr]    Compiling num-bigint-dig v0.8.6
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]    Compiling time-macros v0.2.27
[INFO] [stderr]     Checking futures-intrusive v0.5.0
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]     Checking url v2.5.8
[INFO] [stderr]     Checking ecdsa v0.16.9
[INFO] [stderr]     Checking flate2 v1.1.9
[INFO] [stderr]     Checking primeorder v0.13.6
[INFO] [stderr]     Checking num-iter v0.1.45
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]    Compiling multer v3.1.0
[INFO] [stderr]    Compiling curve25519-dalek-derive v0.1.1
[INFO] [stderr]     Checking regex-syntax v0.8.10
[INFO] [stderr]     Checking bitflags v2.11.0
[INFO] [stderr]     Checking compression-core v0.4.31
[INFO] [stderr]     Checking sync_wrapper v1.0.2
[INFO] [stderr]     Checking hdrhistogram v7.5.4
[INFO] [stderr]     Checking ed25519 v2.2.3
[INFO] [stderr]     Checking pkcs1 v0.7.5
[INFO] [stderr]     Checking compression-codecs v0.4.37
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking time v0.3.47
[INFO] [stderr]     Checking axum-core v0.5.6
[INFO] [stderr]     Checking p384 v0.13.1
[INFO] [stderr]     Checking p256 v0.13.2
[INFO] [stderr]     Checking tracing-serde v0.2.0
[INFO] [stderr]     Checking serde_path_to_error v0.1.20
[INFO] [stderr]     Checking sharded-slab v0.1.7
[INFO] [stderr]     Checking pem v3.0.6
[INFO] [stderr]     Checking password-hash v0.5.0
[INFO] [stderr]     Checking blake2 v0.10.6
[INFO] [stderr]     Checking matchit v0.8.4
[INFO] [stderr]     Checking http-range-header v0.4.2
[INFO] [stderr]     Checking dotenv v0.15.0
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand_chacha v0.9.0
[INFO] [stderr]     Checking rand v0.9.4
[INFO] [stderr]     Checking argon2 v0.5.3
[INFO] [stderr]     Checking rand v0.8.6
[INFO] [stderr]     Checking regex-automata v0.4.14
[INFO] [stderr]     Checking tungstenite v0.28.0
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]     Checking ed25519-dalek v2.2.0
[INFO] [stderr]    Compiling sqlx-core v0.8.6
[INFO] [stderr]     Checking simple_asn1 v0.6.4
[INFO] [stderr]     Checking rsa v0.9.10
[INFO] [stderr]     Checking tokio-util v0.7.18
[INFO] [stderr]     Checking hyper v1.9.0
[INFO] [stderr]     Checking tokio-tungstenite v0.28.0
[INFO] [stderr]     Checking async-compression v0.4.41
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking tracing-subscriber v0.3.23
[INFO] [stderr]     Checking tower v0.5.3
[INFO] [stderr]     Checking tower-http v0.6.8
[INFO] [stderr]     Checking jsonwebtoken v10.3.0
[INFO] [stderr]     Checking hyper-util v0.1.20
[INFO] [stderr]    Compiling sqlx-postgres v0.8.6
[INFO] [stderr]     Checking axum v0.8.8
[INFO] [stderr]    Compiling sqlx-macros-core v0.8.6
[INFO] [stderr]    Compiling sqlx-macros v0.8.6
[INFO] [stderr]     Checking sqlx v0.8.6
[INFO] [stderr]     Checking prod-axum v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: function `list_items` is never used
[INFO] [stdout]   --> src/main.rs:34:10
[INFO] [stdout]    |
[INFO] [stdout] 34 | async fn list_items(Query(pagination): Query<Pagination>) -> String {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `api_v1` is never used
[INFO] [stdout]   --> src/main.rs:40:4
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn api_v1() -> Router {
[INFO] [stdout]    |    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreateUserResponse` is never constructed
[INFO] [stdout]   --> src/main.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 81 | struct CreateUserResponse {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Config` is never constructed
[INFO] [stdout]   --> src/main.rs:90:8
[INFO] [stdout]    |
[INFO] [stdout] 90 | struct Config {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_config` is never used
[INFO] [stdout]   --> src/main.rs:95:10
[INFO] [stdout]    |
[INFO] [stdout] 95 | async fn get_config(State(config): State<Arc<Config>>) -> Json<Config> {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Todo` is never constructed
[INFO] [stdout]    --> src/main.rs:102:8
[INFO] [stdout]     |
[INFO] [stdout] 102 | struct Todo {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreateTodo` is never constructed
[INFO] [stdout]    --> src/main.rs:109:8
[INFO] [stdout]     |
[INFO] [stdout] 109 | struct CreateTodo {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `TodoStore` is never used
[INFO] [stdout]    --> src/main.rs:113:6
[INFO] [stdout]     |
[INFO] [stdout] 113 | type TodoStore = Arc<RwLock<HashMap<String, Todo>>>;
[INFO] [stdout]     |      ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_todo` is never used
[INFO] [stdout]    --> src/main.rs:115:10
[INFO] [stdout]     |
[INFO] [stdout] 115 | async fn create_todo(
[INFO] [stdout]     |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `list_todos` is never used
[INFO] [stdout]    --> src/main.rs:127:10
[INFO] [stdout]     |
[INFO] [stdout] 127 | async fn list_todos(
[INFO] [stdout]     |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `query` are never used
[INFO] [stdout]    --> src/main.rs:143:8
[INFO] [stdout]     |
[INFO] [stdout] 142 | impl DbPool {
[INFO] [stdout]     | ----------- associated items in this implementation
[INFO] [stdout] 143 |     fn new(connection_string: &str) -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 150 |     async fn query(&self, _sql: &str) -> Result<Vec<String>, String> {
[INFO] [stdout]     |              ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `db_query` is never used
[INFO] [stdout]    --> src/main.rs:156:10
[INFO] [stdout]     |
[INFO] [stdout] 156 | async fn db_query(State(pool): State<Arc<DbPool>>) -> Json<Vec<String>> {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `UserNotFound` and `InvalidInput` are never constructed
[INFO] [stdout]    --> src/main.rs:186:5
[INFO] [stdout]     |
[INFO] [stdout] 184 | enum AppError {
[INFO] [stdout]     |      -------- variants in this enum
[INFO] [stdout] 185 |     #[error("User not found with ID: {0}")]
[INFO] [stdout] 186 |     UserNotFound(u64),
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 187 |     #[error("Invalid input: {0}")]
[INFO] [stdout] 188 |     InvalidInput(String),
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AppError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `list_items` is never used
[INFO] [stdout]   --> src/main.rs:34:10
[INFO] [stdout]    |
[INFO] [stdout] 34 | async fn list_items(Query(pagination): Query<Pagination>) -> String {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `api_v1` is never used
[INFO] [stdout]   --> src/main.rs:40:4
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn api_v1() -> Router {
[INFO] [stdout]    |    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreateUserResponse` is never constructed
[INFO] [stdout]   --> src/main.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 81 | struct CreateUserResponse {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Config` is never constructed
[INFO] [stdout]   --> src/main.rs:90:8
[INFO] [stdout]    |
[INFO] [stdout] 90 | struct Config {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_config` is never used
[INFO] [stdout]   --> src/main.rs:95:10
[INFO] [stdout]    |
[INFO] [stdout] 95 | async fn get_config(State(config): State<Arc<Config>>) -> Json<Config> {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Todo` is never constructed
[INFO] [stdout]    --> src/main.rs:102:8
[INFO] [stdout]     |
[INFO] [stdout] 102 | struct Todo {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CreateTodo` is never constructed
[INFO] [stdout]    --> src/main.rs:109:8
[INFO] [stdout]     |
[INFO] [stdout] 109 | struct CreateTodo {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `TodoStore` is never used
[INFO] [stdout]    --> src/main.rs:113:6
[INFO] [stdout]     |
[INFO] [stdout] 113 | type TodoStore = Arc<RwLock<HashMap<String, Todo>>>;
[INFO] [stdout]     |      ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_todo` is never used
[INFO] [stdout]    --> src/main.rs:115:10
[INFO] [stdout]     |
[INFO] [stdout] 115 | async fn create_todo(
[INFO] [stdout]     |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `list_todos` is never used
[INFO] [stdout]    --> src/main.rs:127:10
[INFO] [stdout]     |
[INFO] [stdout] 127 | async fn list_todos(
[INFO] [stdout]     |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `query` are never used
[INFO] [stdout]    --> src/main.rs:143:8
[INFO] [stdout]     |
[INFO] [stdout] 142 | impl DbPool {
[INFO] [stdout]     | ----------- associated items in this implementation
[INFO] [stdout] 143 |     fn new(connection_string: &str) -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 150 |     async fn query(&self, _sql: &str) -> Result<Vec<String>, String> {
[INFO] [stdout]     |              ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `db_query` is never used
[INFO] [stdout]    --> src/main.rs:156:10
[INFO] [stdout]     |
[INFO] [stdout] 156 | async fn db_query(State(pool): State<Arc<DbPool>>) -> Json<Vec<String>> {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `UserNotFound` and `InvalidInput` are never constructed
[INFO] [stdout]    --> src/main.rs:186:5
[INFO] [stdout]     |
[INFO] [stdout] 184 | enum AppError {
[INFO] [stdout]     |      -------- variants in this enum
[INFO] [stdout] 185 |     #[error("User not found with ID: {0}")]
[INFO] [stdout] 186 |     UserNotFound(u64),
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 187 |     #[error("Invalid input: {0}")]
[INFO] [stdout] 188 |     InvalidInput(String),
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AppError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 11s
[INFO] running `Command { std: "docker" "inspect" "1c41940e49cf9e908e74e6297b3e70b617e5610c71a2ad4ddc17dfd3d8aaaa47", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1c41940e49cf9e908e74e6297b3e70b617e5610c71a2ad4ddc17dfd3d8aaaa47", kill_on_drop: false }`
[INFO] [stdout] 1c41940e49cf9e908e74e6297b3e70b617e5610c71a2ad4ddc17dfd3d8aaaa47
