[INFO] cloning repository https://github.com/zjhken/rust-tide-template
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/zjhken/rust-tide-template" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fzjhken%2Frust-tide-template", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fzjhken%2Frust-tide-template'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] e036f29a3ec7c26cd59f7fc9f8ead3b89809dc8d
[INFO] checking zjhken/rust-tide-template against master#292be5c7c05138d753bbd4b30db7a3f1a5c914f7 for pr-148271-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fzjhken%2Frust-tide-template" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/zjhken/rust-tide-template
[INFO] finished tweaking git repo https://github.com/zjhken/rust-tide-template
[INFO] tweaked toml for git repo https://github.com/zjhken/rust-tide-template written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/zjhken/rust-tide-template on toolchain 292be5c7c05138d753bbd4b30db7a3f1a5c914f7
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+292be5c7c05138d753bbd4b30db7a3f1a5c914f7" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/zjhken/rust-tide-template 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" "+292be5c7c05138d753bbd4b30db7a3f1a5c914f7" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded value-bag v1.8.1
[INFO] [stderr]   Downloaded sval_ref v2.13.0
[INFO] [stderr]   Downloaded sval_json v2.13.0
[INFO] [stderr]   Downloaded sval_buffer v2.13.0
[INFO] [stderr]   Downloaded sval v2.13.0
[INFO] [stderr]   Downloaded http-client v6.5.3
[INFO] [stderr]   Downloaded anyhow_ext v0.2.1
[INFO] [stderr]   Downloaded crypto-mac v0.10.0
[INFO] [stderr]   Downloaded hmac v0.10.1
[INFO] [stderr]   Downloaded const_fn v0.4.10
[INFO] [stderr]   Downloaded base-x v0.2.11
[INFO] [stderr]   Downloaded base64-simd v0.8.0
[INFO] [stderr]   Downloaded vsimd v0.8.0
[INFO] [stderr]   Downloaded sha1_smol v1.0.0
[INFO] [stderr]   Downloaded standback v0.2.17
[INFO] [stderr]   Downloaded rusty_ulid v2.0.0
[INFO] [stderr]   Downloaded webpki v0.21.4
[INFO] [stderr]   Downloaded rustls v0.18.1
[INFO] [stderr]   Downloaded tide v0.16.0
[INFO] [stderr]   Downloaded cc v1.0.96
[INFO] [stderr]   Downloaded nom v5.1.3
[INFO] [stderr]   Downloaded aes-gcm v0.8.0
[INFO] [stderr]   Downloaded stdweb v0.4.20
[INFO] [stderr]   Downloaded sea-query v0.30.7
[INFO] [stderr]   Downloaded blake3 v0.3.8
[INFO] [stderr]   Downloaded fern v0.7.1
[INFO] [stderr]   Downloaded webpki-roots v0.20.0
[INFO] [stderr]   Downloaded async-std v1.12.0
[INFO] [stderr]   Downloaded aes-soft v0.6.4
[INFO] [stderr]   Downloaded aesni v0.10.0
[INFO] [stderr]   Downloaded aes v0.6.0
[INFO] [stderr]   Downloaded time v0.2.27
[INFO] [stderr]   Downloaded lexical-core v0.7.6
[INFO] [stderr]   Downloaded femme v2.2.1
[INFO] [stderr]   Downloaded serde_qs v0.8.5
[INFO] [stderr]   Downloaded sval_nested v2.13.0
[INFO] [stderr]   Downloaded parking_lot v0.12.2
[INFO] [stderr]   Downloaded surf v2.3.2
[INFO] [stderr]   Downloaded http-types v2.12.0
[INFO] [stderr]   Downloaded config v0.10.1
[INFO] [stderr]   Downloaded value-bag-serde1 v1.8.1
[INFO] [stderr]   Downloaded sval_fmt v2.13.0
[INFO] [stderr]   Downloaded tikv-jemalloc-sys v0.5.4+5.3.0-patched
[INFO] [stderr]   Downloaded sval_dynamic v2.13.0
[INFO] [stderr]   Downloaded async-h1 v2.3.4
[INFO] [stderr]   Downloaded arrayvec v0.5.2
[INFO] [stderr]   Downloaded cookie v0.14.4
[INFO] [stderr]   Downloaded terminal_size v0.3.0
[INFO] [stderr]   Downloaded async-session v2.0.1
[INFO] [stderr]   Downloaded async-sse v4.1.0
[INFO] [stderr]   Downloaded async-dup v1.2.4
[INFO] [stderr]   Downloaded async-tls v0.10.0
[INFO] [stderr]   Downloaded deadpool v0.7.0
[INFO] [stderr]   Downloaded sct v0.6.1
[INFO] [stderr]   Downloaded ghash v0.3.1
[INFO] [stderr]   Downloaded hkdf v0.10.0
[INFO] [stderr]   Downloaded time-macros-impl v0.1.2
[INFO] [stderr]   Downloaded tikv-jemallocator v0.5.4
[INFO] [stderr]   Downloaded waker-fn v1.1.1
[INFO] [stderr]   Downloaded route-recognizer v0.2.0
[INFO] [stderr]   Downloaded serde_fmt v1.0.3
[INFO] [stderr]   Downloaded outref v0.5.2
[INFO] [stderr]   Downloaded sea-query-attr v0.1.2
[INFO] [stderr]   Downloaded sea-query-derive v0.4.1
[INFO] [stderr]   Downloaded async-io v2.3.2
[INFO] [stderr]   Downloaded async-signal v0.2.6
[INFO] [stderr]   Downloaded discard v1.0.4
[INFO] [stderr]   Downloaded stdweb-derive v0.5.3
[INFO] [stderr]   Downloaded time-macros v0.1.1
[INFO] [stderr]   Downloaded blocking v1.6.0
[INFO] [stderr]   Downloaded aead v0.3.2
[INFO] [stderr]   Downloaded cipher v0.2.5
[INFO] [stderr]   Downloaded ctr v0.6.0
[INFO] [stderr]   Downloaded cpuid-bool v0.2.0
[INFO] [stderr]   Downloaded universal-hash v0.4.0
[INFO] [stderr]   Downloaded polyval v0.4.5
[INFO] [stderr]   Downloaded sha1 v0.6.1
[INFO] [stderr]   Downloaded stdweb-internal-macros v0.2.9
[INFO] [stderr]   Downloaded stdweb-internal-runtime v0.1.5
[INFO] [stderr]   Downloaded infer v0.2.3
[INFO] [stderr]   Downloaded value-bag-sval2 v1.8.1
[INFO] [stderr]   Downloaded sval_serde v2.13.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+292be5c7c05138d753bbd4b30db7a3f1a5c914f7" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] b11ccd36583cde1ad568845edfa3d8aee07fd0601ffca1e073f93bae8ee858d1
[INFO] running `Command { std: "docker" "start" "-a" "b11ccd36583cde1ad568845edfa3d8aee07fd0601ffca1e073f93bae8ee858d1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "b11ccd36583cde1ad568845edfa3d8aee07fd0601ffca1e073f93bae8ee858d1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b11ccd36583cde1ad568845edfa3d8aee07fd0601ffca1e073f93bae8ee858d1", kill_on_drop: false }`
[INFO] [stdout] b11ccd36583cde1ad568845edfa3d8aee07fd0601ffca1e073f93bae8ee858d1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+292be5c7c05138d753bbd4b30db7a3f1a5c914f7" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f7a7122864fb40df6623a9cbb9146433b90804b432afa40dac6144e04721a48e
[INFO] running `Command { std: "docker" "start" "-a" "f7a7122864fb40df6623a9cbb9146433b90804b432afa40dac6144e04721a48e", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.81
[INFO] [stderr]    Compiling libc v0.2.154
[INFO] [stderr]    Compiling crossbeam-utils v0.8.19
[INFO] [stderr]    Compiling serde v1.0.199
[INFO] [stderr]     Checking futures-core v0.3.30
[INFO] [stderr]     Checking parking v2.2.0
[INFO] [stderr]    Compiling cc v1.0.96
[INFO] [stderr]     Checking futures-io v0.3.30
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling io-lifetimes v1.0.11
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]    Compiling polling v2.8.0
[INFO] [stderr]     Checking memchr v2.7.2
[INFO] [stderr]    Compiling rustix v0.37.27
[INFO] [stderr]    Compiling rustix v0.38.34
[INFO] [stderr]    Compiling async-io v1.13.0
[INFO] [stderr]     Checking linux-raw-sys v0.4.13
[INFO] [stderr]     Checking concurrent-queue v2.5.0
[INFO] [stderr]    Compiling quote v1.0.36
[INFO] [stderr]     Checking event-listener v4.0.3
[INFO] [stderr]     Checking getrandom v0.2.14
[INFO] [stderr]    Compiling thiserror v1.0.59
[INFO] [stderr]    Compiling syn v2.0.60
[INFO] [stderr]     Checking fastrand v2.1.0
[INFO] [stderr]     Checking event-listener-strategy v0.4.0
[INFO] [stderr]    Compiling serde_json v1.0.116
[INFO] [stderr]     Checking subtle v2.5.0
[INFO] [stderr]     Checking async-lock v3.3.0
[INFO] [stderr]     Checking futures-lite v2.3.0
[INFO] [stderr]     Checking event-listener v5.3.0
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]     Checking linux-raw-sys v0.3.8
[INFO] [stderr]     Checking async-task v4.7.1
[INFO] [stderr]     Checking event-listener-strategy v0.5.2
[INFO] [stderr]     Checking fastrand v1.9.0
[INFO] [stderr]    Compiling value-bag v1.8.1
[INFO] [stderr]     Checking waker-fn v1.1.1
[INFO] [stderr]     Checking ahash v0.8.11
[INFO] [stderr]     Checking futures-lite v1.13.0
[INFO] [stderr]    Compiling log v0.4.22
[INFO] [stderr]     Checking async-channel v2.2.1
[INFO] [stderr]     Checking piper v0.2.1
[INFO] [stderr]     Checking async-lock v2.8.0
[INFO] [stderr]     Checking socket2 v0.4.10
[INFO] [stderr]     Checking signal-hook-registry v1.4.2
[INFO] [stderr]     Checking digest v0.9.0
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking blocking v1.6.0
[INFO] [stderr]     Checking async-executor v1.11.0
[INFO] [stderr]     Checking event-listener v3.1.0
[INFO] [stderr]    Compiling standback v0.2.17
[INFO] [stderr]     Checking smallvec v1.13.2
[INFO] [stderr]    Compiling proc-macro-hack v0.5.20+deprecated
[INFO] [stderr]    Compiling getrandom v0.1.16
[INFO] [stderr]     Checking unicode-normalization v0.1.23
[INFO] [stderr]     Checking async-channel v1.9.0
[INFO] [stderr]     Checking cipher v0.2.5
[INFO] [stderr]     Checking futures-sink v0.3.30
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking idna v0.5.0
[INFO] [stderr]     Checking universal-hash v0.4.0
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]    Compiling ring v0.16.20
[INFO] [stderr]     Checking cpuid-bool v0.2.0
[INFO] [stderr]    Compiling anyhow v1.0.82
[INFO] [stderr]    Compiling const_fn v0.4.10
[INFO] [stderr]     Checking polyval v0.4.5
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand_core v0.5.1
[INFO] [stderr]     Checking futures-channel v0.3.30
[INFO] [stderr]     Checking aes-soft v0.6.4
[INFO] [stderr]     Checking crypto-mac v0.10.0
[INFO] [stderr]     Checking block-buffer v0.9.0
[INFO] [stderr]    Compiling time v0.2.27
[INFO] [stderr]    Compiling atomic-waker v1.1.2
[INFO] [stderr]     Checking untrusted v0.7.1
[INFO] [stderr]     Checking arrayvec v0.5.2
[INFO] [stderr]     Checking spin v0.5.2
[INFO] [stderr]     Checking futures-task v0.3.30
[INFO] [stderr]    Compiling libsqlite3-sys v0.27.0
[INFO] [stderr]     Checking sha2 v0.9.9
[INFO] [stderr]     Checking hmac v0.10.1
[INFO] [stderr]     Checking aes v0.6.0
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking ghash v0.3.1
[INFO] [stderr]    Compiling async-attributes v1.1.2
[INFO] [stderr]    Compiling time-macros-impl v0.1.2
[INFO] [stderr]     Checking ctr v0.6.0
[INFO] [stderr]     Checking aead v0.3.2
[INFO] [stderr]     Checking time-macros v0.1.1
[INFO] [stderr]    Compiling cookie v0.14.4
[INFO] [stderr]    Compiling bitflags v1.3.2
[INFO] [stderr]    Compiling lexical-core v0.7.6
[INFO] [stderr]     Checking aes-gcm v0.8.0
[INFO] [stderr]    Compiling serde_derive v1.0.199
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]    Compiling thiserror-impl v1.0.59
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking hkdf v0.10.0
[INFO] [stderr]     Checking futures-util v0.3.30
[INFO] [stderr]    Compiling tracing v0.1.40
[INFO] [stderr]     Checking crossbeam-queue v0.3.11
[INFO] [stderr]    Compiling nom v5.1.3
[INFO] [stderr]     Checking base64 v0.13.1
[INFO] [stderr]    Compiling polling v3.7.0
[INFO] [stderr]    Compiling http-types v2.12.0
[INFO] [stderr]     Checking static_assertions v1.1.0
[INFO] [stderr]    Compiling unicode-bidi v0.3.15
[INFO] [stderr]    Compiling async-io v2.3.2
[INFO] [stderr]    Compiling async-global-executor v2.4.1
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]     Checking webpki v0.21.4
[INFO] [stderr]    Compiling parking_lot v0.12.2
[INFO] [stderr]     Checking futures-executor v0.3.30
[INFO] [stderr]    Compiling kv-log-macro v1.0.7
[INFO] [stderr]     Checking infer v0.2.3
[INFO] [stderr]     Checking base64 v0.12.3
[INFO] [stderr]    Compiling indexmap v2.2.6
[INFO] [stderr]    Compiling futures-intrusive v0.5.0
[INFO] [stderr]    Compiling sha2 v0.10.8
[INFO] [stderr]    Compiling atoi v2.0.0
[INFO] [stderr]    Compiling async-std v1.12.0
[INFO] [stderr]    Compiling url v2.5.0
[INFO] [stderr]    Compiling hashlink v0.8.4
[INFO] [stderr]     Checking sct v0.6.1
[INFO] [stderr]    Compiling pin-project-internal v1.1.5
[INFO] [stderr]    Compiling async-trait v0.1.80
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]     Checking erased-serde v0.4.4
[INFO] [stderr]     Checking serde_fmt v1.0.3
[INFO] [stderr]     Checking serde_qs v0.8.5
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking either v1.11.0
[INFO] [stderr]     Checking value-bag-serde1 v1.8.1
[INFO] [stderr]    Compiling bytes v1.6.0
[INFO] [stderr]    Compiling darling_core v0.14.4
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]    Compiling itertools v0.12.1
[INFO] [stderr]     Checking rustls v0.18.1
[INFO] [stderr]     Checking async-signal v0.2.6
[INFO] [stderr]     Checking async-process v1.8.1
[INFO] [stderr]    Compiling flume v0.11.0
[INFO] [stderr]     Checking config v0.10.1
[INFO] [stderr]     Checking pin-project v1.1.5
[INFO] [stderr]     Checking webpki-roots v0.20.0
[INFO] [stderr]     Checking async-dup v1.2.4
[INFO] [stderr]     Checking crypto-mac v0.8.0
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]    Compiling sqlformat v0.2.3
[INFO] [stderr]    Compiling blake3 v0.3.8
[INFO] [stderr]     Checking tokio v1.37.0
[INFO] [stderr]     Checking utf8parse v0.2.1
[INFO] [stderr]    Compiling urlencoding v2.1.3
[INFO] [stderr]     Checking anstyle-parse v0.2.3
[INFO] [stderr]    Compiling darling_macro v0.14.4
[INFO] [stderr]    Compiling mime_guess v2.0.4
[INFO] [stderr]     Checking async-tls v0.10.0
[INFO] [stderr]     Checking futures v0.3.30
[INFO] [stderr]    Compiling tempfile v3.10.1
[INFO] [stderr]     Checking dashmap v5.5.3
[INFO] [stderr]    Compiling tikv-jemalloc-sys v0.5.4+5.3.0-patched
[INFO] [stderr]     Checking deadpool v0.7.0
[INFO] [stderr]     Checking cfg-if v0.1.10
[INFO] [stderr]     Checking anstyle v1.0.6
[INFO] [stderr]     Checking anstyle-query v1.0.2
[INFO] [stderr]     Checking colorchoice v1.0.0
[INFO] [stderr]     Checking constant_time_eq v0.1.5
[INFO] [stderr]     Checking deranged v0.3.11
[INFO] [stderr]     Checking anstream v0.6.13
[INFO] [stderr]     Checking chrono v0.4.38
[INFO] [stderr]    Compiling darling v0.14.4
[INFO] [stderr]     Checking hmac v0.8.1
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]     Checking serde_spanned v0.6.5
[INFO] [stderr]     Checking toml_datetime v0.6.5
[INFO] [stderr]     Checking terminal_size v0.3.0
[INFO] [stderr]     Checking winnow v0.6.7
[INFO] [stderr]     Checking pin-project-lite v0.1.12
[INFO] [stderr]     Checking clap_lex v0.7.0
[INFO] [stderr]     Checking time v0.3.36
[INFO] [stderr]     Checking clap_builder v4.5.2
[INFO] [stderr]     Checking async-session v2.0.1
[INFO] [stderr]    Compiling clap_derive v4.5.4
[INFO] [stderr]    Compiling sea-query-attr v0.1.2
[INFO] [stderr]     Checking async-h1 v2.3.4
[INFO] [stderr]     Checking async-sse v4.1.0
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking http-client v6.5.3
[INFO] [stderr]     Checking femme v2.2.1
[INFO] [stderr]    Compiling sea-query-derive v0.4.1
[INFO] [stderr]     Checking toml_edit v0.22.12
[INFO] [stderr]    Compiling sqlx-core v0.7.4
[INFO] [stderr]    Compiling inherent v1.0.11
[INFO] [stderr]     Checking vsimd v0.8.0
[INFO] [stderr]     Checking outref v0.5.2
[INFO] [stderr]     Checking route-recognizer v0.2.0
[INFO] [stderr]     Checking clap v4.5.4
[INFO] [stderr]     Checking base64-simd v0.8.0
[INFO] [stderr]     Checking tracing-subscriber v0.3.18
[INFO] [stderr]     Checking tide v0.16.0
[INFO] [stderr]     Checking sea-query v0.30.7
[INFO] [stderr]     Checking surf v2.3.2
[INFO] [stderr]     Checking rusty_ulid v2.0.0
[INFO] [stderr]     Checking fern v0.7.1
[INFO] [stderr]     Checking anyhow_ext v0.2.1
[INFO] [stderr]     Checking dashmap v6.1.0
[INFO] [stderr]     Checking humantime v2.1.0
[INFO] [stderr]     Checking toml v0.8.12
[INFO] [stderr]     Checking sqlx-sqlite v0.7.4
[INFO] [stderr]    Compiling sqlx-macros-core v0.7.4
[INFO] [stderr]    Compiling sqlx-macros v0.7.4
[INFO] [stderr]     Checking sqlx v0.7.4
[INFO] [stderr]     Checking tikv-jemallocator v0.5.4
[INFO] [stderr]     Checking rust-tide-template v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `default` and `fmt::write`
[INFO] [stdout]  --> src/cli.rs:2:11
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::{default, fmt::write, path::PathBuf};
[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 macro definition: `retry_http`
[INFO] [stdout]   --> src/common.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 | macro_rules! retry_http {
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_macros)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `retry_http`
[INFO] [stdout]   --> src/common.rs:52:16
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub(crate) use retry_http;
[INFO] [stdout]    |                ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `anyhow_ext::Context`
[INFO] [stdout]  --> src/database.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use anyhow_ext::Context;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::sync::Mutex`
[INFO] [stdout]  --> src/database.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use async_std::sync::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ForeignKey`
[INFO] [stdout]  --> src/database.rs:7:19
[INFO] [stdout]   |
[INFO] [stdout] 7 |     ColumnDef, Expr, ForeignKey, Iden, QueryStatementWriter, SqliteQueryBuilder, Table, Value,
[INFO] [stdout]   |                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::sync::Mutex`
[INFO] [stdout]  --> src/logging.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use async_std::sync::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `anyhow_ext::Context`
[INFO] [stdout]  --> src/logging.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use anyhow_ext::Context;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `level_filters::LevelFilter`
[INFO] [stdout]  --> src/logging.rs:8:15
[INFO] [stdout]   |
[INFO] [stdout] 8 | use tracing::{level_filters::LevelFilter, Level};
[INFO] [stdout]   |               ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tracing_subscriber::fmt::format`
[INFO] [stdout]  --> src/logging.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use tracing_subscriber::fmt::format;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::config::LogLevel`
[INFO] [stdout]   --> src/logging.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::config::LogLevel;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Handle`, `Registry`, `filter`, `layer`, `self`, and `self`
[INFO] [stdout]   --> src/logging.rs:15:2
[INFO] [stdout]    |
[INFO] [stdout] 15 |     filter,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 16 |     fmt::{self, layer},
[INFO] [stdout]    |           ^^^^  ^^^^^
[INFO] [stdout] 17 |     prelude::*,
[INFO] [stdout] 18 |     reload::{self, Handle},
[INFO] [stdout]    |              ^^^^  ^^^^^^
[INFO] [stdout] 19 |     Registry,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]   --> src/logging.rs:24:17
[INFO] [stdout]    |
[INFO] [stdout] 24 | use std::time::{Duration, Instant};
[INFO] [stdout]    |                 ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `surf::StatusCode`
[INFO] [stdout]   --> src/logging.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use surf::StatusCode;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tide::Response`
[INFO] [stdout]   --> src/logging.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | use tide::Response;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Middleware`, `Next`, and `Request`
[INFO] [stdout]   --> src/logging.rs:28:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | use tide::{Middleware, Next, Request};
[INFO] [stdout]    |            ^^^^^^^^^^  ^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Instrument`, `debug`, `error_span`, `error`, `info_span`, `warn_span`, and `warn`
[INFO] [stdout]   --> src/logging.rs:29:15
[INFO] [stdout]    |
[INFO] [stdout] 29 | use tracing::{debug, error, error_span, info, info_span, warn, warn_span, Instrument};
[INFO] [stdout]    |               ^^^^^  ^^^^^  ^^^^^^^^^^        ^^^^^^^^^  ^^^^  ^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration` and `Instant`
[INFO] [stdout]  --> src/server.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::time::{Duration, Instant};
[INFO] [stdout]   |                 ^^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Instrument`, `error_span`, `info_span`, `info`, `warn_span`, and `warn`
[INFO] [stdout]  --> src/server.rs:7:29
[INFO] [stdout]   |
[INFO] [stdout] 7 | use tracing::{debug, error, error_span, info, info_span, warn, warn_span, Instrument};
[INFO] [stdout]   |                             ^^^^^^^^^^  ^^^^  ^^^^^^^^^  ^^^^  ^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `config::CFG`
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use config::CFG;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `database::init_database` and `load_config`
[INFO] [stdout]   --> src/main.rs:18:32
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crate::{cli::Cli, config::{load_config, get_log_level}, database::init_database};
[INFO] [stdout]    |                                ^^^^^^^^^^^                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `default` and `fmt::write`
[INFO] [stdout]  --> src/cli.rs:2:11
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::{default, fmt::write, path::PathBuf};
[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 macro definition: `retry_http`
[INFO] [stdout]   --> src/common.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 | macro_rules! retry_http {
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_macros)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `retry_http`
[INFO] [stdout]   --> src/common.rs:52:16
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub(crate) use retry_http;
[INFO] [stdout]    |                ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `anyhow_ext::Context`
[INFO] [stdout]  --> src/database.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use anyhow_ext::Context;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::sync::Mutex`
[INFO] [stdout]  --> src/database.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use async_std::sync::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ForeignKey`
[INFO] [stdout]  --> src/database.rs:7:19
[INFO] [stdout]   |
[INFO] [stdout] 7 |     ColumnDef, Expr, ForeignKey, Iden, QueryStatementWriter, SqliteQueryBuilder, Table, Value,
[INFO] [stdout]   |                      ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::sync::Mutex`
[INFO] [stdout]  --> src/logging.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use async_std::sync::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `anyhow_ext::Context`
[INFO] [stdout]  --> src/logging.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use anyhow_ext::Context;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `level_filters::LevelFilter`
[INFO] [stdout]  --> src/logging.rs:8:15
[INFO] [stdout]   |
[INFO] [stdout] 8 | use tracing::{level_filters::LevelFilter, Level};
[INFO] [stdout]   |               ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tracing_subscriber::fmt::format`
[INFO] [stdout]  --> src/logging.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use tracing_subscriber::fmt::format;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::config::LogLevel`
[INFO] [stdout]   --> src/logging.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::config::LogLevel;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Handle`, `Registry`, `filter`, `layer`, `self`, and `self`
[INFO] [stdout]   --> src/logging.rs:15:2
[INFO] [stdout]    |
[INFO] [stdout] 15 |     filter,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 16 |     fmt::{self, layer},
[INFO] [stdout]    |           ^^^^  ^^^^^
[INFO] [stdout] 17 |     prelude::*,
[INFO] [stdout] 18 |     reload::{self, Handle},
[INFO] [stdout]    |              ^^^^  ^^^^^^
[INFO] [stdout] 19 |     Registry,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]   --> src/logging.rs:24:17
[INFO] [stdout]    |
[INFO] [stdout] 24 | use std::time::{Duration, Instant};
[INFO] [stdout]    |                 ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `surf::StatusCode`
[INFO] [stdout]   --> src/logging.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use surf::StatusCode;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tide::Response`
[INFO] [stdout]   --> src/logging.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | use tide::Response;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Middleware`, `Next`, and `Request`
[INFO] [stdout]   --> src/logging.rs:28:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | use tide::{Middleware, Next, Request};
[INFO] [stdout]    |            ^^^^^^^^^^  ^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Instrument`, `debug`, `error_span`, `error`, `info_span`, `warn_span`, and `warn`
[INFO] [stdout]   --> src/logging.rs:29:15
[INFO] [stdout]    |
[INFO] [stdout] 29 | use tracing::{debug, error, error_span, info, info_span, warn, warn_span, Instrument};
[INFO] [stdout]    |               ^^^^^  ^^^^^  ^^^^^^^^^^        ^^^^^^^^^  ^^^^  ^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration` and `Instant`
[INFO] [stdout]  --> src/server.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::time::{Duration, Instant};
[INFO] [stdout]   |                 ^^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Instrument`, `error_span`, `info_span`, `info`, `warn_span`, and `warn`
[INFO] [stdout]  --> src/server.rs:7:29
[INFO] [stdout]   |
[INFO] [stdout] 7 | use tracing::{debug, error, error_span, info, info_span, warn, warn_span, Instrument};
[INFO] [stdout]   |                             ^^^^^^^^^^  ^^^^  ^^^^^^^^^  ^^^^  ^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `config::CFG`
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use config::CFG;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `database::init_database` and `load_config`
[INFO] [stdout]   --> src/main.rs:18:32
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crate::{cli::Cli, config::{load_config, get_log_level}, database::init_database};
[INFO] [stdout]    |                                ^^^^^^^^^^^                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]    --> src/database.rs:102:2
[INFO] [stdout]     |
[INFO] [stdout] 101 |     todo!("implement your table logic");
[INFO] [stdout]     |     ----------------------------------- any code following this expression is unreachable
[INFO] [stdout] 102 |     Ok(())
[INFO] [stdout]     |     ^^^^^^ unreachable expression
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]    --> src/database.rs:102:2
[INFO] [stdout]     |
[INFO] [stdout] 101 |     todo!("implement your table logic");
[INFO] [stdout]     |     ----------------------------------- any code following this expression is unreachable
[INFO] [stdout] 102 |     Ok(())
[INFO] [stdout]     |     ^^^^^^ unreachable expression
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `QueryStatementWriter`
[INFO] [stdout]  --> src/database.rs:7:37
[INFO] [stdout]   |
[INFO] [stdout] 7 |     ColumnDef, Expr, ForeignKey, Iden, QueryStatementWriter, SqliteQueryBuilder, Table, Value,
[INFO] [stdout]   |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `prelude`
[INFO] [stdout]   --> src/logging.rs:17:2
[INFO] [stdout]    |
[INFO] [stdout] 17 |     prelude::*,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/auth.rs:25:3
[INFO] [stdout]    |
[INFO] [stdout] 25 |         mut req: tide::Request<State>,
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `username`
[INFO] [stdout]   --> src/auth.rs:53:16
[INFO] [stdout]    |
[INFO] [stdout] 53 | async fn authn(username: &str, password: &str) -> tide::Result<bool> {
[INFO] [stdout]    |                ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_username`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `password`
[INFO] [stdout]   --> src/auth.rs:53:32
[INFO] [stdout]    |
[INFO] [stdout] 53 | async fn authn(username: &str, password: &str) -> tide::Result<bool> {
[INFO] [stdout]    |                                ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_password`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `QueryStatementWriter`
[INFO] [stdout]  --> src/database.rs:7:37
[INFO] [stdout]   |
[INFO] [stdout] 7 |     ColumnDef, Expr, ForeignKey, Iden, QueryStatementWriter, SqliteQueryBuilder, Table, Value,
[INFO] [stdout]   |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `prelude`
[INFO] [stdout]   --> src/logging.rs:17:2
[INFO] [stdout]    |
[INFO] [stdout] 17 |     prelude::*,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/auth.rs:25:3
[INFO] [stdout]    |
[INFO] [stdout] 25 |         mut req: tide::Request<State>,
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `username`
[INFO] [stdout]   --> src/auth.rs:53:16
[INFO] [stdout]    |
[INFO] [stdout] 53 | async fn authn(username: &str, password: &str) -> tide::Result<bool> {
[INFO] [stdout]    |                ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_username`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `password`
[INFO] [stdout]   --> src/auth.rs:53:32
[INFO] [stdout]    |
[INFO] [stdout] 53 | async fn authn(username: &str, password: &str) -> tide::Result<bool> {
[INFO] [stdout]    |                                ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_password`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pool`
[INFO] [stdout]   --> src/database.rs:51:6
[INFO] [stdout]    |
[INFO] [stdout] 51 |     let pool = get_db_pool();
[INFO] [stdout]    |         ^^^^ help: if this is intentional, prefix it with an underscore: `_pool`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sql`
[INFO] [stdout]   --> src/database.rs:53:6
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let sql = Table::create()
[INFO] [stdout]    |         ^^^ help: if this is intentional, prefix it with an underscore: `_sql`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]   --> src/database.rs:99:6
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let result = sqlx::query(&sql).bind(&sql).execute(get_db_pool()).await?;
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pool`
[INFO] [stdout]   --> src/database.rs:51:6
[INFO] [stdout]    |
[INFO] [stdout] 51 |     let pool = get_db_pool();
[INFO] [stdout]    |         ^^^^ help: if this is intentional, prefix it with an underscore: `_pool`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sql`
[INFO] [stdout]   --> src/database.rs:53:6
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let sql = Table::create()
[INFO] [stdout]    |         ^^^ help: if this is intentional, prefix it with an underscore: `_sql`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]   --> src/database.rs:99:6
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let result = sqlx::query(&sql).bind(&sql).execute(get_db_pool()).await?;
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `req`
[INFO] [stdout]   --> src/server.rs:41:26
[INFO] [stdout]    |
[INFO] [stdout] 41 | async fn example_handler(req: Request<()>) -> tide::Result<Response> {
[INFO] [stdout]    |                          ^^^ help: if this is intentional, prefix it with an underscore: `_req`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/server.rs:49:25
[INFO] [stdout]    |
[INFO] [stdout] 49 |     async fn handle(&self, mut req: Request<State>, next: Next<'_, State>) -> tide::Result {
[INFO] [stdout]    |                            ----^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/server.rs:53:7
[INFO] [stdout]    |
[INFO] [stdout] 53 |         let mut res = next.run(req).await;
[INFO] [stdout]    |             ----^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/server.rs:73:25
[INFO] [stdout]    |
[INFO] [stdout] 73 |     async fn handle(&self, mut req: Request<State>, next: Next<'_, State>) -> tide::Result {
[INFO] [stdout]    |                            ----^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/server.rs:86:25
[INFO] [stdout]    |
[INFO] [stdout] 86 |     async fn handle(&self, mut req: Request<State>, next: Next<'_, State>) -> tide::Result {
[INFO] [stdout]    |                            ----^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `CRED_CACHE` is never used
[INFO] [stdout]   --> src/auth.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | static CRED_CACHE: LazyLock<DashMap<String, (String, Instant)>> = LazyLock::new(|| DashMap::new());
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `password` is never read
[INFO] [stdout]   --> src/auth.rs:17:6
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Cred {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout] 16 |     pub username: String,
[INFO] [stdout] 17 |     pub password: String,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Cred` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AuthMiddleware` is never constructed
[INFO] [stdout]   --> src/auth.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct AuthMiddleware;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `authn` is never used
[INFO] [stdout]   --> src/auth.rs:53:10
[INFO] [stdout]    |
[INFO] [stdout] 53 | async fn authn(username: &str, password: &str) -> tide::Result<bool> {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cache_cred` is never used
[INFO] [stdout]   --> src/auth.rs:92:14
[INFO] [stdout]    |
[INFO] [stdout] 92 | pub async fn cache_cred(username: &str, cred: String) {
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ONE_DAY` is never used
[INFO] [stdout]   --> src/auth.rs:96:7
[INFO] [stdout]    |
[INFO] [stdout] 96 | const ONE_DAY: u64 = 60 * 60 * 24;
[INFO] [stdout]    |       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `req`
[INFO] [stdout]   --> src/server.rs:41:26
[INFO] [stdout]    |
[INFO] [stdout] 41 | async fn example_handler(req: Request<()>) -> tide::Result<Response> {
[INFO] [stdout]    |                          ^^^ help: if this is intentional, prefix it with an underscore: `_req`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_cached_cred` is never used
[INFO] [stdout]   --> src/auth.rs:98:14
[INFO] [stdout]    |
[INFO] [stdout] 98 | pub async fn get_cached_cred(username: &str) -> Option<String> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `HTTP_CLIENT` is never used
[INFO] [stdout]   --> src/common.rs:54:12
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub static HTTP_CLIENT: OnceLock<surf::Client> = OnceLock::new();
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `http` is never used
[INFO] [stdout]   --> src/common.rs:56:8
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub fn http() -> &'static Client {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_http_client` is never used
[INFO] [stdout]   --> src/common.rs:60:8
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub fn setup_http_client(trust_store_bytes: Option<&[u8]>) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_path_and_file_overwrite` is never used
[INFO] [stdout]   --> src/common.rs:76:14
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub async fn create_path_and_file_overwrite(path: &PathBuf) -> Result<fs::File> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `make_resp` is never used
[INFO] [stdout]   --> src/common.rs:93:8
[INFO] [stdout]    |
[INFO] [stdout] 93 | pub fn make_resp<S>(status: S, body: impl Into<tide::Body>) -> tide::Response
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ErrorHandleMiddleware` is never constructed
[INFO] [stdout]    --> src/common.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout] 103 | pub struct ErrorHandleMiddleware;
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `ensure_path` is never used
[INFO] [stdout]    --> src/common.rs:117:21
[INFO] [stdout]     |
[INFO] [stdout] 117 | pub(crate) async fn ensure_path(path: &std::path::PathBuf) -> Result<()> {
[INFO] [stdout]     |                     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `recursively_delete_empty_folder` is never used
[INFO] [stdout]    --> src/common.rs:128:14
[INFO] [stdout]     |
[INFO] [stdout] 128 | pub async fn recursively_delete_empty_folder(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load_config_from_cli` is never used
[INFO] [stdout]   --> src/config.rs:16:14
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub async fn load_config_from_cli(cli: &Cli) -> Result<()> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load_config` is never used
[INFO] [stdout]   --> src/config.rs:31:14
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub async fn load_config<P>(config_path: P) -> Result<()>
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `port` and `db_url` are never read
[INFO] [stdout]   --> src/config.rs:47:6
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct Config {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] 47 |     pub port: u16,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 48 |     pub log_level: LogLevel,
[INFO] [stdout] 49 |     pub db_url: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cfg` is never used
[INFO] [stdout]   --> src/config.rs:78:14
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub async fn cfg() -> async_std::sync::RwLockReadGuard<'static, Config> {
[INFO] [stdout]    |              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_config` is never used
[INFO] [stdout]   --> src/config.rs:83:14
[INFO] [stdout]    |
[INFO] [stdout] 83 | pub async fn get_config() -> Config {
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_db_url` is never used
[INFO] [stdout]   --> src/config.rs:99:14
[INFO] [stdout]    |
[INFO] [stdout] 99 | pub async fn get_db_url() -> String {
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DB_POOL` is never used
[INFO] [stdout]   --> src/database.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | static DB_POOL: OnceLock<Pool<Sqlite>> = OnceLock::new();
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `init_db_pool` is never used
[INFO] [stdout]   --> src/database.rs:14:8
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub fn init_db_pool(pool: Pool<Sqlite>) -> &'static Pool<Sqlite> {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_db_pool` is never used
[INFO] [stdout]   --> src/database.rs:18:8
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub fn get_db_pool() -> &'static Pool<Sqlite> {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `init_database` is never used
[INFO] [stdout]   --> src/database.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub fn init_database(db_url: &str) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `ensure_db_file` is never used
[INFO] [stdout]   --> src/database.rs:32:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | async fn ensure_db_file(db_url: &str) -> Result<()> {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `ensure_tables` is never used
[INFO] [stdout]   --> src/database.rs:49:10
[INFO] [stdout]    |
[INFO] [stdout] 49 | async fn ensure_tables() -> Result<()> {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `User` is never used
[INFO] [stdout]    --> src/database.rs:106:6
[INFO] [stdout]     |
[INFO] [stdout] 106 | enum User {
[INFO] [stdout]     |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/server.rs:49:25
[INFO] [stdout]    |
[INFO] [stdout] 49 |     async fn handle(&self, mut req: Request<State>, next: Next<'_, State>) -> tide::Result {
[INFO] [stdout]    |                            ----^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/server.rs:53:7
[INFO] [stdout]    |
[INFO] [stdout] 53 |         let mut res = next.run(req).await;
[INFO] [stdout]    |             ----^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/server.rs:73:25
[INFO] [stdout]    |
[INFO] [stdout] 73 |     async fn handle(&self, mut req: Request<State>, next: Next<'_, State>) -> tide::Result {
[INFO] [stdout]    |                            ----^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/server.rs:86:25
[INFO] [stdout]    |
[INFO] [stdout] 86 |     async fn handle(&self, mut req: Request<State>, next: Next<'_, State>) -> tide::Result {
[INFO] [stdout]    |                            ----^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `CRED_CACHE` is never used
[INFO] [stdout]   --> src/auth.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | static CRED_CACHE: LazyLock<DashMap<String, (String, Instant)>> = LazyLock::new(|| DashMap::new());
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `password` is never read
[INFO] [stdout]   --> src/auth.rs:17:6
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Cred {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout] 16 |     pub username: String,
[INFO] [stdout] 17 |     pub password: String,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Cred` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AuthMiddleware` is never constructed
[INFO] [stdout]   --> src/auth.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct AuthMiddleware;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `authn` is never used
[INFO] [stdout]   --> src/auth.rs:53:10
[INFO] [stdout]    |
[INFO] [stdout] 53 | async fn authn(username: &str, password: &str) -> tide::Result<bool> {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cache_cred` is never used
[INFO] [stdout]   --> src/auth.rs:92:14
[INFO] [stdout]    |
[INFO] [stdout] 92 | pub async fn cache_cred(username: &str, cred: String) {
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ONE_DAY` is never used
[INFO] [stdout]   --> src/auth.rs:96:7
[INFO] [stdout]    |
[INFO] [stdout] 96 | const ONE_DAY: u64 = 60 * 60 * 24;
[INFO] [stdout]    |       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_cached_cred` is never used
[INFO] [stdout]   --> src/auth.rs:98:14
[INFO] [stdout]    |
[INFO] [stdout] 98 | pub async fn get_cached_cred(username: &str) -> Option<String> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `HTTP_CLIENT` is never used
[INFO] [stdout]   --> src/common.rs:54:12
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub static HTTP_CLIENT: OnceLock<surf::Client> = OnceLock::new();
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `http` is never used
[INFO] [stdout]   --> src/common.rs:56:8
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub fn http() -> &'static Client {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_http_client` is never used
[INFO] [stdout]   --> src/common.rs:60:8
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub fn setup_http_client(trust_store_bytes: Option<&[u8]>) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_path_and_file_overwrite` is never used
[INFO] [stdout]   --> src/common.rs:76:14
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub async fn create_path_and_file_overwrite(path: &PathBuf) -> Result<fs::File> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `make_resp` is never used
[INFO] [stdout]   --> src/common.rs:93:8
[INFO] [stdout]    |
[INFO] [stdout] 93 | pub fn make_resp<S>(status: S, body: impl Into<tide::Body>) -> tide::Response
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ErrorHandleMiddleware` is never constructed
[INFO] [stdout]    --> src/common.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout] 103 | pub struct ErrorHandleMiddleware;
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `ensure_path` is never used
[INFO] [stdout]    --> src/common.rs:117:21
[INFO] [stdout]     |
[INFO] [stdout] 117 | pub(crate) async fn ensure_path(path: &std::path::PathBuf) -> Result<()> {
[INFO] [stdout]     |                     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `recursively_delete_empty_folder` is never used
[INFO] [stdout]    --> src/common.rs:128:14
[INFO] [stdout]     |
[INFO] [stdout] 128 | pub async fn recursively_delete_empty_folder(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load_config_from_cli` is never used
[INFO] [stdout]   --> src/config.rs:16:14
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub async fn load_config_from_cli(cli: &Cli) -> Result<()> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load_config` is never used
[INFO] [stdout]   --> src/config.rs:31:14
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub async fn load_config<P>(config_path: P) -> Result<()>
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `port` and `db_url` are never read
[INFO] [stdout]   --> src/config.rs:47:6
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct Config {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] 47 |     pub port: u16,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 48 |     pub log_level: LogLevel,
[INFO] [stdout] 49 |     pub db_url: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cfg` is never used
[INFO] [stdout]   --> src/config.rs:78:14
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub async fn cfg() -> async_std::sync::RwLockReadGuard<'static, Config> {
[INFO] [stdout]    |              ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_config` is never used
[INFO] [stdout]   --> src/config.rs:83:14
[INFO] [stdout]    |
[INFO] [stdout] 83 | pub async fn get_config() -> Config {
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_db_url` is never used
[INFO] [stdout]   --> src/config.rs:99:14
[INFO] [stdout]    |
[INFO] [stdout] 99 | pub async fn get_db_url() -> String {
[INFO] [stdout]    |              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DB_POOL` is never used
[INFO] [stdout]   --> src/database.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | static DB_POOL: OnceLock<Pool<Sqlite>> = OnceLock::new();
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `init_db_pool` is never used
[INFO] [stdout]   --> src/database.rs:14:8
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub fn init_db_pool(pool: Pool<Sqlite>) -> &'static Pool<Sqlite> {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_db_pool` is never used
[INFO] [stdout]   --> src/database.rs:18:8
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub fn get_db_pool() -> &'static Pool<Sqlite> {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `init_database` is never used
[INFO] [stdout]   --> src/database.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub fn init_database(db_url: &str) -> Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `ensure_db_file` is never used
[INFO] [stdout]   --> src/database.rs:32:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | async fn ensure_db_file(db_url: &str) -> Result<()> {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `ensure_tables` is never used
[INFO] [stdout]   --> src/database.rs:49:10
[INFO] [stdout]    |
[INFO] [stdout] 49 | async fn ensure_tables() -> Result<()> {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `User` is never used
[INFO] [stdout]    --> src/database.rs:106:6
[INFO] [stdout]     |
[INFO] [stdout] 106 | enum User {
[INFO] [stdout]     |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 4m 53s
[INFO] running `Command { std: "docker" "inspect" "f7a7122864fb40df6623a9cbb9146433b90804b432afa40dac6144e04721a48e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f7a7122864fb40df6623a9cbb9146433b90804b432afa40dac6144e04721a48e", kill_on_drop: false }`
[INFO] [stdout] f7a7122864fb40df6623a9cbb9146433b90804b432afa40dac6144e04721a48e
