[INFO] cloning repository https://github.com/nexelor/media-collector
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/nexelor/media-collector" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnexelor%2Fmedia-collector", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnexelor%2Fmedia-collector'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 4d37e68f18857390d3bd92854137f8d523897284
[INFO] testing nexelor/media-collector against master#ec6f9a5b4413f74386267ef8efc93712c2ce6db6 for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnexelor%2Fmedia-collector" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/nexelor/media-collector
[INFO] finished tweaking git repo https://github.com/nexelor/media-collector
[INFO] tweaked toml for git repo https://github.com/nexelor/media-collector written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/nexelor/media-collector on toolchain ec6f9a5b4413f74386267ef8efc93712c2ce6db6
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/nexelor/media-collector 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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "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 uuid v1.19.0
[INFO] [stderr]   Downloaded quote v1.0.43
[INFO] [stderr]   Downloaded unicode-ident v1.0.22
[INFO] [stderr]   Downloaded urlencoding v2.1.3
[INFO] [stderr]   Downloaded time-core v0.1.7
[INFO] [stderr]   Downloaded take_mut v0.2.2
[INFO] [stderr]   Downloaded serde_bytes v0.11.19
[INFO] [stderr]   Downloaded mongodb-internal-macros v3.5.0
[INFO] [stderr]   Downloaded rustc_version_runtime v0.3.0
[INFO] [stderr]   Downloaded critical-section v1.2.0
[INFO] [stderr]   Downloaded zmij v1.0.14
[INFO] [stderr]   Downloaded tracing-appender v0.2.4
[INFO] [stderr]   Downloaded proc-macro2 v1.0.105
[INFO] [stderr]   Downloaded pbkdf2 v0.12.2
[INFO] [stderr]   Downloaded macro_magic v0.5.1
[INFO] [stderr]   Downloaded macro_magic_macros v0.5.1
[INFO] [stderr]   Downloaded macro_magic_core v0.5.1
[INFO] [stderr]   Downloaded macro_magic_core_macros v0.5.1
[INFO] [stderr]   Downloaded md-5 v0.10.6
[INFO] [stderr]   Downloaded enum-as-inner v0.6.1
[INFO] [stderr]   Downloaded serde_with_macros v3.16.1
[INFO] [stderr]   Downloaded typed-builder v0.22.0
[INFO] [stderr]   Downloaded typed-builder-macro v0.22.0
[INFO] [stderr]   Downloaded stringprep v0.1.5
[INFO] [stderr]   Downloaded time-macros v0.2.25
[INFO] [stderr]   Downloaded tagptr v0.2.0
[INFO] [stderr]   Downloaded portable-atomic v1.13.0
[INFO] [stderr]   Downloaded nonzero_ext v0.3.0
[INFO] [stderr]   Downloaded find-msvc-tools v0.1.8
[INFO] [stderr]   Downloaded ryu v1.0.22
[INFO] [stderr]   Downloaded derive-syn-parse v0.2.0
[INFO] [stderr]   Downloaded mongocrypt-sys v0.1.5+1.15.1
[INFO] [stderr]   Downloaded resolv-conf v0.7.6
[INFO] [stderr]   Downloaded ipconfig v0.3.2
[INFO] [stderr]   Downloaded dashmap v6.1.0
[INFO] [stderr]   Downloaded axum-core v0.5.6
[INFO] [stderr]   Downloaded unicode-properties v0.1.4
[INFO] [stderr]   Downloaded pest_generator v2.8.5
[INFO] [stderr]   Downloaded mongocrypt v0.3.2
[INFO] [stderr]   Downloaded crossbeam-epoch v0.9.18
[INFO] [stderr]   Downloaded quanta v0.12.6
[INFO] [stderr]   Downloaded unicode-bidi v0.3.18
[INFO] [stderr]   Downloaded openssl-sys v0.9.111
[INFO] [stderr]   Downloaded futures-timer v3.0.3
[INFO] [stderr]   Downloaded pest_derive v2.8.5
[INFO] [stderr]   Downloaded pest_meta v2.8.5
[INFO] [stderr]   Downloaded matchit v0.8.4
[INFO] [stderr]   Downloaded socket2 v0.6.1
[INFO] [stderr]   Downloaded bytes v1.11.0
[INFO] [stderr]   Downloaded schemars v1.2.0
[INFO] [stderr]   Downloaded tempfile v3.24.0
[INFO] [stderr]   Downloaded crossbeam-channel v0.5.15
[INFO] [stderr]   Downloaded cc v1.2.53
[INFO] [stderr]   Downloaded derive-where v1.6.0
[INFO] [stderr]   Downloaded spinning_top v0.3.0
[INFO] [stderr]   Downloaded zerocopy-derive v0.8.33
[INFO] [stderr]   Downloaded hickory-resolver v0.25.2
[INFO] [stderr]   Downloaded widestring v1.2.1
[INFO] [stderr]   Downloaded hyper-util v0.1.19
[INFO] [stderr]   Downloaded unicode-normalization v0.1.25
[INFO] [stderr]   Downloaded raw-cpuid v11.6.0
[INFO] [stderr]   Downloaded pest v2.8.5
[INFO] [stderr]   Downloaded governor v0.10.4
[INFO] [stderr]   Downloaded serde_with v3.16.1
[INFO] [stderr]   Downloaded bson v2.15.0
[INFO] [stderr]   Downloaded axum v0.8.8
[INFO] [stderr]   Downloaded time v0.3.45
[INFO] [stderr]   Downloaded moka v0.12.12
[INFO] [stderr]   Downloaded webpki-roots v1.0.5
[INFO] [stderr]   Downloaded openssl v0.10.75
[INFO] [stderr]   Downloaded zerocopy v0.8.33
[INFO] [stderr]   Downloaded regex-syntax v0.8.8
[INFO] [stderr]   Downloaded mongodb v3.5.0
[INFO] [stderr]   Downloaded hickory-proto v0.25.2
[INFO] [stderr]   Downloaded libc v0.2.180
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] bd2f6c404f0ed9eda2a2d1abd10d9ab3bcb6bd772aeda0c124cc937a52e838ba
[INFO] running `Command { std: "docker" "start" "-a" "bd2f6c404f0ed9eda2a2d1abd10d9ab3bcb6bd772aeda0c124cc937a52e838ba", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "bd2f6c404f0ed9eda2a2d1abd10d9ab3bcb6bd772aeda0c124cc937a52e838ba", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "bd2f6c404f0ed9eda2a2d1abd10d9ab3bcb6bd772aeda0c124cc937a52e838ba", kill_on_drop: false }`
[INFO] [stdout] bd2f6c404f0ed9eda2a2d1abd10d9ab3bcb6bd772aeda0c124cc937a52e838ba
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7a07b0545f9000ffce7a7906ed69d5fc03351ae56bc366102950020fc05c0fea
[INFO] running `Command { std: "docker" "start" "-a" "7a07b0545f9000ffce7a7906ed69d5fc03351ae56bc366102950020fc05c0fea", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.105
[INFO] [stderr]    Compiling unicode-ident v1.0.22
[INFO] [stderr]    Compiling quote v1.0.43
[INFO] [stderr]    Compiling cfg-if v1.0.4
[INFO] [stderr]    Compiling libc v0.2.180
[INFO] [stderr]    Compiling portable-atomic v1.13.0
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling critical-section v1.2.0
[INFO] [stderr]    Compiling memchr v2.7.6
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling pin-project-lite v0.2.16
[INFO] [stderr]    Compiling version_check v0.9.5
[INFO] [stderr]    Compiling allocator-api2 v0.2.21
[INFO] [stderr]    Compiling scopeguard v1.2.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling futures-core v0.3.31
[INFO] [stderr]    Compiling itoa v1.0.17
[INFO] [stderr]    Compiling lock_api v0.4.14
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling log v0.4.29
[INFO] [stderr]    Compiling bytes v1.11.0
[INFO] [stderr]    Compiling equivalent v1.0.2
[INFO] [stderr]    Compiling find-msvc-tools v0.1.8
[INFO] [stderr]    Compiling shlex v1.3.0
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling zerocopy v0.8.33
[INFO] [stderr]    Compiling foldhash v0.2.0
[INFO] [stderr]    Compiling stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]    Compiling futures-io v0.3.31
[INFO] [stderr]    Compiling slab v0.4.11
[INFO] [stderr]    Compiling crunchy v0.2.4
[INFO] [stderr]    Compiling tiny-keccak v2.0.2
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling pin-utils v0.1.0
[INFO] [stderr]    Compiling cc v1.2.53
[INFO] [stderr]    Compiling futures-task v0.3.31
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling fnv v1.0.7
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling writeable v0.6.2
[INFO] [stderr]    Compiling litemap v0.8.1
[INFO] [stderr]    Compiling http v1.4.0
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling icu_normalizer_data v2.1.1
[INFO] [stderr]    Compiling zmij v1.0.14
[INFO] [stderr]    Compiling vcpkg v0.2.15
[INFO] [stderr]    Compiling icu_properties_data v2.1.2
[INFO] [stderr]    Compiling pkg-config v0.3.32
[INFO] [stderr]    Compiling percent-encoding v2.3.2
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling subtle v2.6.1
[INFO] [stderr]    Compiling form_urlencoded v1.2.2
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling tracing-core v0.1.36
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling mio v1.1.1
[INFO] [stderr]    Compiling socket2 v0.6.1
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling rand_core v0.9.5
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling tower-service v0.3.3
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling ipnet v2.11.0
[INFO] [stderr]    Compiling rustls-pki-types v1.14.0
[INFO] [stderr]    Compiling strsim v0.11.1
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling ident_case v1.0.1
[INFO] [stderr]    Compiling foreign-types-shared v0.1.1
[INFO] [stderr]    Compiling base64 v0.22.1
[INFO] [stderr]    Compiling const-random-macro v0.1.16
[INFO] [stderr]    Compiling ucd-trie v0.1.7
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling try-lock v0.2.5
[INFO] [stderr]    Compiling tinyvec_macros v0.1.1
[INFO] [stderr]    Compiling atomic-waker v1.1.2
[INFO] [stderr]    Compiling utf8_iter v1.0.4
[INFO] [stderr]    Compiling thiserror v2.0.17
[INFO] [stderr]    Compiling tinyvec v1.10.0
[INFO] [stderr]    Compiling const-random v0.1.18
[INFO] [stderr]    Compiling want v0.3.1
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling pest v2.8.5
[INFO] [stderr]    Compiling foreign-types v0.3.2
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.7
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling tower-layer v0.3.3
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling regex-syntax v0.8.8
[INFO] [stderr]    Compiling powerfmt v0.2.0
[INFO] [stderr]    Compiling untrusted v0.9.0
[INFO] [stderr]    Compiling httpdate v1.0.3
[INFO] [stderr]    Compiling time-core v0.1.7
[INFO] [stderr]    Compiling num-conv v0.1.0
[INFO] [stderr]    Compiling semver v1.0.27
[INFO] [stderr]    Compiling radium v0.7.0
[INFO] [stderr]    Compiling time-macros v0.2.25
[INFO] [stderr]    Compiling deranged v0.5.5
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling rustc_version v0.4.1
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]    Compiling tap v1.0.1
[INFO] [stderr]    Compiling openssl-probe v0.1.6
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling rustls v0.23.36
[INFO] [stderr]    Compiling heck v0.5.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling wyz v0.5.1
[INFO] [stderr]    Compiling dlv-list v0.5.2
[INFO] [stderr]    Compiling convert_case v0.10.0
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.18
[INFO] [stderr]    Compiling rustc_version_runtime v0.3.0
[INFO] [stderr]    Compiling encoding_rs v0.8.35
[INFO] [stderr]    Compiling tagptr v0.2.0
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]    Compiling uuid v1.19.0
[INFO] [stderr]    Compiling cpufeatures v0.2.17
[INFO] [stderr]    Compiling funty v2.0.0
[INFO] [stderr]    Compiling toml_write v0.1.2
[INFO] [stderr]    Compiling unicode-xid v0.2.6
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]    Compiling mime v0.3.17
[INFO] [stderr]    Compiling ryu v1.0.22
[INFO] [stderr]    Compiling lazy_static v1.5.0
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling data-encoding v2.10.0
[INFO] [stderr]    Compiling bitvec v1.0.1
[INFO] [stderr]    Compiling sharded-slab v0.1.7
[INFO] [stderr]    Compiling time v0.3.45
[INFO] [stderr]    Compiling hashlink v0.8.4
[INFO] [stderr]    Compiling pest_meta v2.8.5
[INFO] [stderr]    Compiling ordered-multimap v0.7.3
[INFO] [stderr]    Compiling moka v0.12.12
[INFO] [stderr]    Compiling raw-cpuid v11.6.0
[INFO] [stderr]    Compiling serde_bytes v0.11.19
[INFO] [stderr]    Compiling unicode-normalization v0.1.25
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling hex v0.4.3
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling nu-ansi-term v0.50.3
[INFO] [stderr]    Compiling resolv-conf v0.7.6
[INFO] [stderr]    Compiling unicode-bidi v0.3.18
[INFO] [stderr]    Compiling unicode-properties v0.1.4
[INFO] [stderr]    Compiling iri-string v0.7.10
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]    Compiling arraydeque v0.5.1
[INFO] [stderr]    Compiling base64 v0.21.7
[INFO] [stderr]    Compiling anyhow v1.0.100
[INFO] [stderr]    Compiling yaml-rust2 v0.8.1
[INFO] [stderr]    Compiling stringprep v0.1.5
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling rust-ini v0.20.0
[INFO] [stderr]    Compiling dashmap v6.1.0
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling serde_path_to_error v0.1.20
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.21.3
[INFO] [stderr]    Compiling pest_generator v2.8.5
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]    Compiling rustls-webpki v0.103.9
[INFO] [stderr]    Compiling quanta v0.12.6
[INFO] [stderr]    Compiling pbkdf2 v0.12.2
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling convert_case v0.6.0
[INFO] [stderr]    Compiling webpki-roots v1.0.5
[INFO] [stderr]    Compiling spinning_top v0.3.0
[INFO] [stderr]    Compiling web-time v1.1.0
[INFO] [stderr]    Compiling matchit v0.8.4
[INFO] [stderr]    Compiling take_mut v0.2.2
[INFO] [stderr]    Compiling nonzero_ext v0.3.0
[INFO] [stderr]    Compiling futures-timer v3.0.3
[INFO] [stderr]    Compiling iana-time-zone v0.1.64
[INFO] [stderr]    Compiling pathdiff v0.2.3
[INFO] [stderr]    Compiling urlencoding v2.1.3
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling macro_magic_core_macros v0.5.1
[INFO] [stderr]    Compiling derive-syn-parse v0.2.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling enum-as-inner v0.6.1
[INFO] [stderr]    Compiling macro_magic_core v0.5.1
[INFO] [stderr]    Compiling tokio v1.49.0
[INFO] [stderr]    Compiling pest_derive v2.8.5
[INFO] [stderr]    Compiling typed-builder-macro v0.22.0
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling derive_more-impl v2.1.1
[INFO] [stderr]    Compiling derive-where v1.6.0
[INFO] [stderr]    Compiling macro_magic_macros v0.5.1
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling axum-core v0.5.6
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling macro_magic v0.5.1
[INFO] [stderr]    Compiling mongodb-internal-macros v3.5.0
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling darling_macro v0.21.3
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling typed-builder v0.22.0
[INFO] [stderr]    Compiling darling v0.21.3
[INFO] [stderr]    Compiling serde_with_macros v3.16.1
[INFO] [stderr]    Compiling derive_more v2.1.1
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling serde_with v3.16.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling tracing-serde v0.2.0
[INFO] [stderr]    Compiling bson v2.15.0
[INFO] [stderr]    Compiling json5 v0.4.1
[INFO] [stderr]    Compiling ron v0.8.1
[INFO] [stderr]    Compiling chrono v0.4.43
[INFO] [stderr]    Compiling tracing-subscriber v0.3.22
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling futures-executor v0.3.31
[INFO] [stderr]    Compiling governor v0.10.4
[INFO] [stderr]    Compiling futures v0.3.31
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling tracing-appender v0.2.4
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling hickory-proto v0.25.2
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling config v0.14.1
[INFO] [stderr]    Compiling hickory-resolver v0.25.2
[INFO] [stderr]    Compiling mongodb v3.5.0
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.19
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling axum v0.8.8
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling media-collector v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `UpdateOptions`
[INFO] [stdout]  --> src/anime/my_anime_list/database.rs:3:67
[INFO] [stdout]   |
[INFO] [stdout] 3 | use mongodb::options::{FindOptions, IndexOptions, ReplaceOptions, UpdateOptions};
[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: `BatchFetchTask`
[INFO] [stdout]   --> src/anime/my_anime_list/module.rs:11:55
[INFO] [stdout]    |
[INFO] [stdout] 11 |     FetchAnimeTask, SearchAnimeTask, UpdateAnimeTask, BatchFetchTask,
[INFO] [stdout]    |                                                       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `NaiveTime`
[INFO] [stdout]  --> src/anime/my_anime_list/model.rs:2:24
[INFO] [stdout]   |
[INFO] [stdout] 2 | use chrono::{DateTime, NaiveTime, Utc};
[INFO] [stdout]   |                        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/anime/my_anime_list/converter.rs:2:22
[INFO] [stdout]   |
[INFO] [stdout] 2 | use tracing::{debug, warn};
[INFO] [stdout]   |                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `database::update_anime_extended_data`
[INFO] [stdout]   --> src/anime/my_anime_list/task/fetch_extended.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     database::update_anime_extended_data,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fetch_pictures_for_anime::FetchAnimePicturesTask`
[INFO] [stdout]   --> src/anime/my_anime_list/task/mod.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub use fetch_pictures_for_anime::FetchAnimePicturesTask;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `module::MyAnimeListModule`
[INFO] [stdout]   --> src/anime/my_anime_list/mod.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub use module::MyAnimeListModule;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/anime/anilist/model.rs:2:14
[INFO] [stdout]   |
[INFO] [stdout] 2 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug` and `warn`
[INFO] [stdout]  --> src/anime/anilist/converter.rs:2:15
[INFO] [stdout]   |
[INFO] [stdout] 2 | use tracing::{debug, warn};
[INFO] [stdout]   |               ^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `model::AniListAnimeData`
[INFO] [stdout]   --> src/anime/anilist/task/fetch_pictures_for_anime.rs:10:56
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::anime::anilist::{database::get_anime_by_id, model::AniListAnimeData};
[INFO] [stdout]    |                                                        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fetch_pictures_for_anime::FetchAniListAnimePicturesTask`
[INFO] [stdout]  --> src/anime/anilist/task/mod.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use fetch_pictures_for_anime::FetchAniListAnimePicturesTask;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AniListMedia`, `GraphQLRequest`, and `GraphQLResponse`
[INFO] [stdout]  --> src/anime/anilist/mod.rs:8:17
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub use model::{AniListMedia, GraphQLRequest, GraphQLResponse};
[INFO] [stdout]   |                 ^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `converter::anilist_to_anime_data`
[INFO] [stdout]  --> src/anime/anilist/mod.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use converter::anilist_to_anime_data;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> src/global/http.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tracing::{info, debug, warn, error};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/picture/task.rs:6:28
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tracing::{info, debug, warn, error};
[INFO] [stdout]   |                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `UpdateOptions`
[INFO] [stdout]  --> src/picture/database.rs:4:67
[INFO] [stdout]   |
[INFO] [stdout] 4 | use mongodb::options::{FindOptions, IndexOptions, ReplaceOptions, UpdateOptions};
[INFO] [stdout]   |                                                                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Path`
[INFO] [stdout]  --> src/api/routes/picture.rs:2:15
[INFO] [stdout]   |
[INFO] [stdout] 2 |     extract::{Path, Query, State},
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Deserialize`
[INFO] [stdout]  --> src/api/routes/health.rs:6:13
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]   --> src/global/http.rs:83:31
[INFO] [stdout]    |
[INFO] [stdout] 83 |         let encoded = base64::encode(credentials.as_bytes());
[INFO] [stdout]    |                               ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/anime/anilist/task/fetch_anime.rs:161:13
[INFO] [stdout]     |
[INFO] [stdout] 161 |         let config = RequestConfig::new()
[INFO] [stdout]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/anime/anilist/task/search_anime.rs:100:13
[INFO] [stdout]     |
[INFO] [stdout] 100 |         let config = RequestConfig::new()
[INFO] [stdout]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `queue`
[INFO] [stdout]    --> src/global/queue.rs:289:42
[INFO] [stdout]     |
[INFO] [stdout] 289 |     async fn load_persisted_tasks(&self, queue: &mut BinaryHeap<PriorityTask>) -> Result<(), AppError> {
[INFO] [stdout]     |                                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_queue`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `picture_module_ref` is never read
[INFO] [stdout]    --> src/main.rs:96:69
[INFO] [stdout]     |
[INFO] [stdout]  96 |     let mut picture_module_ref: Option<Arc<PictureFetcherModule>> = None;
[INFO] [stdout]     |                                                                     ^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 108 |     picture_module_ref = Some(Arc::new(picture_module.clone()));
[INFO] [stdout]     |     ------------------ `picture_module_ref` is overwritten here before the previous value is read
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `anime_exists` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:185:14
[INFO] [stdout]     |
[INFO] [stdout] 185 | pub async fn anime_exists(db: &Database, mal_id: i32) -> Result<bool, DatabaseError> {
[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 `search_anime_by_title` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:196:14
[INFO] [stdout]     |
[INFO] [stdout] 196 | pub async fn search_anime_by_title(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_top_rated_anime` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:232:14
[INFO] [stdout]     |
[INFO] [stdout] 232 | pub async fn get_top_rated_anime(db: &Database, limit: i64) -> Result<Vec<AnimeData>, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_most_popular_anime` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:261:14
[INFO] [stdout]     |
[INFO] [stdout] 261 | pub async fn get_most_popular_anime(db: &Database, limit: i64) -> Result<Vec<AnimeData>, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_by_season` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:290:14
[INFO] [stdout]     |
[INFO] [stdout] 290 | pub async fn get_anime_by_season(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_by_media_type` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:325:14
[INFO] [stdout]     |
[INFO] [stdout] 325 | pub async fn get_anime_by_media_type(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_airing_anime` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:358:14
[INFO] [stdout]     |
[INFO] [stdout] 358 | pub async fn get_airing_anime(db: &Database, limit: i64) -> Result<Vec<AnimeData>, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_count` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:387:14
[INFO] [stdout]     |
[INFO] [stdout] 387 | pub async fn get_anime_count(db: &Database) -> Result<u64, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_anime` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:395:14
[INFO] [stdout]     |
[INFO] [stdout] 395 | pub async fn delete_anime(db: &Database, mal_id: i32) -> Result<bool, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `bulk_insert_anime` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:406:14
[INFO] [stdout]     |
[INFO] [stdout] 406 | pub async fn bulk_insert_anime(db: &Database, anime_list: Vec<AnimeData>) -> Result<u64, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `update_anime_extended_data` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:420:14
[INFO] [stdout]     |
[INFO] [stdout] 420 | pub async fn update_anime_extended_data<T: Serialize>(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_needing_update` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:444:14
[INFO] [stdout]     |
[INFO] [stdout] 444 | pub async fn get_anime_needing_update(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AnimeCache` is never constructed
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:482:8
[INFO] [stdout]     |
[INFO] [stdout] 482 | struct AnimeCache {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cache_anime_data` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:490:14
[INFO] [stdout]     |
[INFO] [stdout] 490 | pub async fn cache_anime_data(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_cached_data` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:518:14
[INFO] [stdout]     |
[INFO] [stdout] 518 | pub async fn get_cached_data(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchHistory` is never constructed
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:537:8
[INFO] [stdout]     |
[INFO] [stdout] 537 | struct SearchHistory {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `record_search_history` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:543:10
[INFO] [stdout]     |
[INFO] [stdout] 543 | async fn record_search_history(db: &Database, query: &str) -> Result<(), DatabaseError> {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_recent_searches` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:558:14
[INFO] [stdout]     |
[INFO] [stdout] 558 | pub async fn get_recent_searches(db: &Database, limit: i64) -> Result<Vec<String>, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `queue_fetch_statistics`, `queue_fetch_pictures`, `queue_fetch_complete`, and `queue_fetch_all_extended_data` are never used
[INFO] [stdout]    --> src/anime/my_anime_list/module.rs:234:18
[INFO] [stdout]     |
[INFO] [stdout]  25 | impl MyAnimeListModule {
[INFO] [stdout]     | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub async fn queue_fetch_statistics(&self, anime_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 252 |     pub async fn queue_fetch_pictures(&self, anime_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 259 |     pub async fn queue_fetch_complete(&self, anime_id: u32, with_jikan: bool) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 277 |     pub async fn queue_fetch_all_extended_data(&self, anime_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BatchFetchPayload` is never constructed
[INFO] [stdout]   --> src/anime/my_anime_list/task/batch_fetch.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct BatchFetchPayload {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BatchFetchTask` is never constructed
[INFO] [stdout]   --> src/anime/my_anime_list/task/batch_fetch.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct BatchFetchTask {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `with_jikan` are never used
[INFO] [stdout]   --> src/anime/my_anime_list/task/batch_fetch.rs:28:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | impl BatchFetchTask {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 28 |     pub fn new(
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn with_jikan(mut self) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `last_visible_page` is never read
[INFO] [stdout]    --> src/anime/my_anime_list/task/fetch_extended.rs:295:5
[INFO] [stdout]     |
[INFO] [stdout] 294 | struct JikanPagination {
[INFO] [stdout]     |        --------------- field in this struct
[INFO] [stdout] 295 |     last_visible_page: i32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `JikanPagination` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `duration` is never read
[INFO] [stdout]    --> src/anime/my_anime_list/task/fetch_extended.rs:306:5
[INFO] [stdout]     |
[INFO] [stdout] 300 | struct JikanEpisode {
[INFO] [stdout]     |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 306 |     duration: Option<i32>,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `JikanEpisode` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `locations` is never read
[INFO] [stdout]   --> src/anime/anilist/model.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub struct GraphQLError {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub locations: Vec<ErrorLocation>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `GraphQLError` 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: fields `line` and `column` are never read
[INFO] [stdout]   --> src/anime/anilist/model.rs:36:9
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub struct ErrorLocation {
[INFO] [stdout]    |            ------------- fields in this struct
[INFO] [stdout] 36 |     pub line: i32,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 37 |     pub column: i32,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ErrorLocation` 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: fields `media_type`, `average_score`, `is_locked`, `is_favourite`, `is_favourite_blocked`, and `rankings` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:57:9
[INFO] [stdout]     |
[INFO] [stdout]  52 | pub struct AniListMedia {
[INFO] [stdout]     |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout]  57 |     pub media_type: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  79 |     pub average_score: Option<i32>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  82 |     pub is_locked: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub is_favourite: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^
[INFO] [stdout]  96 |     pub is_favourite_blocked: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     pub rankings: Option<Vec<MediaRank>>,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AniListMedia` 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: field `user_preferred` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 110 | pub struct MediaTitle {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub user_preferred: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaTitle` 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: fields `site` and `thumbnail` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:128:9
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub struct MediaTrailer {
[INFO] [stdout]     |            ------------ fields in this struct
[INFO] [stdout] 127 |     pub id: Option<String>,
[INFO] [stdout] 128 |     pub site: Option<String>,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 129 |     pub thumbnail: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaTrailer` 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: field `is_adult` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:151:9
[INFO] [stdout]     |
[INFO] [stdout] 143 | pub struct MediaTag {
[INFO] [stdout]     |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 151 |     pub is_adult: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaTag` 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: field `id` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:162:9
[INFO] [stdout]     |
[INFO] [stdout] 161 | pub struct MediaEdge {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] 162 |     pub id: Option<i32>,
[INFO] [stdout]     |         ^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaEdge` 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: fields `id_mal`, `format`, and `cover_image` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:171:9
[INFO] [stdout]     |
[INFO] [stdout] 169 | pub struct MediaNode {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 170 |     pub id: i32,
[INFO] [stdout] 171 |     pub id_mal: Option<i32>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 175 |     pub format: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 176 |     pub cover_image: Option<MediaCoverImage>,
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaNode` 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: field `id` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:186:9
[INFO] [stdout]     |
[INFO] [stdout] 185 | pub struct CharacterEdge {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] 186 |     pub id: Option<i32>,
[INFO] [stdout]     |         ^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `CharacterEdge` 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: fields `first`, `middle`, `last`, `native`, and `alternative` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:204:9
[INFO] [stdout]     |
[INFO] [stdout] 203 | pub struct CharacterName {
[INFO] [stdout]     |            ------------- fields in this struct
[INFO] [stdout] 204 |     pub first: Option<String>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 205 |     pub middle: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 206 |     pub last: Option<String>,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 207 |     pub full: Option<String>,
[INFO] [stdout] 208 |     pub native: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 209 |     #[serde(default)]
[INFO] [stdout] 210 |     pub alternative: Vec<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `CharacterName` 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: field `id` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:226:9
[INFO] [stdout]     |
[INFO] [stdout] 225 | pub struct StaffEdge {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] 226 |     pub id: Option<i32>,
[INFO] [stdout]     |         ^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `StaffEdge` 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: fields `first`, `middle`, `last`, and `native` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:243:9
[INFO] [stdout]     |
[INFO] [stdout] 242 | pub struct StaffName {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 243 |     pub first: Option<String>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 244 |     pub middle: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 245 |     pub last: Option<String>,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 246 |     pub full: Option<String>,
[INFO] [stdout] 247 |     pub native: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `StaffName` 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: field `is_main` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:264:9
[INFO] [stdout]     |
[INFO] [stdout] 263 | pub struct StudioEdge {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] 264 |     pub is_main: bool,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `StudioEdge` 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: field `is_animation_studio` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:273:9
[INFO] [stdout]     |
[INFO] [stdout] 270 | pub struct StudioNode {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 273 |     pub is_animation_studio: bool,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `StudioNode` 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: fields `title` and `thumbnail` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:296:9
[INFO] [stdout]     |
[INFO] [stdout] 295 | pub struct MediaStreamingEpisode {
[INFO] [stdout]     |            --------------------- fields in this struct
[INFO] [stdout] 296 |     pub title: Option<String>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 297 |     pub thumbnail: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaStreamingEpisode` 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: multiple fields are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:305:9
[INFO] [stdout]     |
[INFO] [stdout] 304 | pub struct MediaRank {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 305 |     pub id: i32,
[INFO] [stdout]     |         ^^
[INFO] [stdout] 306 |     pub rank: i32,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 307 |     #[serde(rename = "type")]
[INFO] [stdout] 308 |     pub rank_type: String,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 309 |     pub format: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 310 |     pub year: Option<i32>,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 311 |     pub season: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 312 |     pub all_time: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 313 |     pub context: String,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaRank` 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 `PageData` is never constructed
[INFO] [stdout]    --> src/anime/anilist/model.rs:341:12
[INFO] [stdout]     |
[INFO] [stdout] 341 | pub struct PageData {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Page` is never constructed
[INFO] [stdout]    --> src/anime/anilist/model.rs:347:12
[INFO] [stdout]     |
[INFO] [stdout] 347 | pub struct Page {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PageInfo` is never constructed
[INFO] [stdout]    --> src/anime/anilist/model.rs:355:12
[INFO] [stdout]     |
[INFO] [stdout] 355 | pub struct PageInfo {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEARCH_ANIME_QUERY` is never used
[INFO] [stdout]    --> src/anime/anilist/queries.rs:402:11
[INFO] [stdout]     |
[INFO] [stdout] 402 | pub const SEARCH_ANIME_QUERY: &str = r#"
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TRENDING_ANIME_QUERY` is never used
[INFO] [stdout]    --> src/anime/anilist/queries.rs:460:11
[INFO] [stdout]     |
[INFO] [stdout] 460 | pub const TRENDING_ANIME_QUERY: &str = r#"
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ANIME_BY_SEASON_QUERY` is never used
[INFO] [stdout]    --> src/anime/anilist/queries.rs:492:11
[INFO] [stdout]     |
[INFO] [stdout] 492 | pub const ANIME_BY_SEASON_QUERY: &str = r#"
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config` is never read
[INFO] [stdout]   --> src/anime/anilist/module.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct AniListModule {
[INFO] [stdout]    |            ------------- field in this struct
[INFO] [stdout] 13 |     client: ClientWithLimiter,
[INFO] [stdout] 14 |     config: Arc<AppConfig>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `queue_fetch_by_anilist_id`, `queue_fetch_by_anilist_id_with_pictures`, `queue_fetch_by_anilist_id_full`, `queue_fetch_by_anilist_id_with_options`, and `queue_search_anime` are never used
[INFO] [stdout]    --> src/anime/anilist/module.rs:104:18
[INFO] [stdout]     |
[INFO] [stdout]  19 | impl AniListModule {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 104 |     pub async fn queue_fetch_by_anilist_id(&self, anilist_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub async fn queue_fetch_by_anilist_id_with_pictures(&self, anilist_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub async fn queue_fetch_by_anilist_id_full(&self, anilist_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 118 |     async fn queue_fetch_by_anilist_id_with_options(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 160 |     pub async fn queue_search_anime(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `by_anilist_id` is never used
[INFO] [stdout]   --> src/anime/anilist/task/fetch_anime.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl FetchAnimeTask {
[INFO] [stdout]    | ------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 62 |     pub fn by_anilist_id(
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchAnimePayload` is never constructed
[INFO] [stdout]   --> src/anime/anilist/task/search_anime.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct SearchAnimePayload {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchAnimeTask` is never constructed
[INFO] [stdout]   --> src/anime/anilist/task/search_anime.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct SearchAnimeTask {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/anime/anilist/task/search_anime.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl SearchAnimeTask {
[INFO] [stdout]    | -------------------- associated function in this implementation
[INFO] [stdout] 31 |     pub fn new(
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_by_mal_id` is never used
[INFO] [stdout]    --> src/anime/anilist/database.rs:127:14
[INFO] [stdout]     |
[INFO] [stdout] 127 | pub async fn get_anime_by_mal_id(db: &Database, mal_id: i32) -> Result<Option<AniListAnimeData>, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `anime_exists` is never used
[INFO] [stdout]    --> src/anime/anilist/database.rs:136:14
[INFO] [stdout]     |
[INFO] [stdout] 136 | pub async fn anime_exists(db: &Database, anilist_id: i32) -> Result<bool, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `search_anime_by_title` is never used
[INFO] [stdout]    --> src/anime/anilist/database.rs:147:14
[INFO] [stdout]     |
[INFO] [stdout] 147 | pub async fn search_anime_by_title(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_count` is never used
[INFO] [stdout]    --> src/anime/anilist/database.rs:180:14
[INFO] [stdout]     |
[INFO] [stdout] 180 | pub async fn get_anime_count(db: &Database) -> Result<u64, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_anime` is never used
[INFO] [stdout]    --> src/anime/anilist/database.rs:188:14
[INFO] [stdout]     |
[INFO] [stdout] 188 | pub async fn delete_anime(db: &Database, anilist_id: i32) -> Result<bool, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `NotFound` is never constructed
[INFO] [stdout]  --> src/anime/error.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub enum AnimeError {
[INFO] [stdout]   |          ---------- variant in this enum
[INFO] [stdout] 3 |     #[error("anime not found")]
[INFO] [stdout] 4 |     NotFound,
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `AnimeError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `update_module_heartbeat` and `get_active_modules` are never used
[INFO] [stdout]    --> src/global/database.rs:149:18
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl DatabaseInstance {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 149 |     pub async fn update_module_heartbeat(&self, module_name: &str) -> Result<(), DatabaseError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 176 |     pub async fn get_active_modules(&self) -> Result<Vec<String>, DatabaseError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `MaxRetriesExceeded` is never constructed
[INFO] [stdout]   --> src/global/error.rs:49:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub enum HttpError {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 49 |     MaxRetriesExceeded,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `HttpError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AppState` is never constructed
[INFO] [stdout]  --> src/global/state.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct AppState {
[INFO] [stdout]   |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Custom` is never constructed
[INFO] [stdout]   --> src/global/module.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub enum ModuleMessage {
[INFO] [stdout]    |          ------------- variant in this enum
[INFO] [stdout] 16 |     Shutdown,
[INFO] [stdout] 17 |     Custom(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ModuleMessage` 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 `ModuleResponse` is never constructed
[INFO] [stdout]   --> src/global/module.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct ModuleResponse<T> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `try_acquire` is never used
[INFO] [stdout]    --> src/global/module.rs:114:12
[INFO] [stdout]     |
[INFO] [stdout]  63 | impl RateLimiter {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub fn try_acquire(&self) -> Result<(), std::time::Duration> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config` is never read
[INFO] [stdout]   --> src/global/http.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct HttpClientManager {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] 15 |     clients: Arc<ClientPool>,
[INFO] [stdout] 16 |     config: Arc<AppConfig>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `HttpClientManager` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `with_api_key`, `with_bearer_token`, `with_basic_auth`, and `with_retry_config` are never used
[INFO] [stdout]   --> src/global/http.rs:71:12
[INFO] [stdout]    |
[INFO] [stdout] 58 | impl RequestConfig {
[INFO] [stdout]    | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 71 |     pub fn with_api_key(self, api_key: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn with_bearer_token(self, token: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 81 |     pub fn with_basic_auth(self, username: impl Into<String>, password: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88 |     pub fn with_retry_config(mut self, config: RetryConfig) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `execute` and `try_execute` are never used
[INFO] [stdout]    --> src/global/http.rs:178:18
[INFO] [stdout]     |
[INFO] [stdout] 175 | impl ClientWithLimiter {
[INFO] [stdout]     | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 178 |     pub async fn execute<F, Fut, T>(&self, f: F) -> T
[INFO] [stdout]     |                  ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub async fn try_execute<F, Fut, T>(&self, f: F) -> Result<T, std::time::Duration>
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `is_child_module_enabled` and `get_child_module_config` are never used
[INFO] [stdout]    --> src/global/config.rs:204:12
[INFO] [stdout]     |
[INFO] [stdout] 147 | impl AppConfig {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub fn is_child_module_enabled(&self, module_name: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub fn get_child_module_config(&self, module_name: &str) -> Option<&ChildModuleConfig> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `name` is never used
[INFO] [stdout]    --> src/global/queue.rs:129:12
[INFO] [stdout]     |
[INFO] [stdout]  96 | impl TaskQueue {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 129 |     pub fn name(&self) -> &str {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ParseEnumError` is never constructed
[INFO] [stdout]  --> src/global/model.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ParseEnumError {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `storage_path` and `queue_fetch_pictures` are never used
[INFO] [stdout]    --> src/picture/mod.rs:53:12
[INFO] [stdout]     |
[INFO] [stdout]  23 | impl PictureFetcherModule {
[INFO] [stdout]     | ------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  53 |     pub fn storage_path(&self) -> &Path {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub async fn queue_fetch_pictures(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_failed` is never used
[INFO] [stdout]   --> src/picture/model.rs:99:12
[INFO] [stdout]    |
[INFO] [stdout] 70 | impl PictureMetadata {
[INFO] [stdout]    | -------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 99 |     pub fn is_failed(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_picture_by_path` is never used
[INFO] [stdout]   --> src/picture/database.rs:95:14
[INFO] [stdout]    |
[INFO] [stdout] 95 | pub async fn get_picture_by_path(db: &Database, path: &str) -> Result<Option<PictureMetadata>, DatabaseError> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `update_picture_status` is never used
[INFO] [stdout]    --> src/picture/database.rs:138:14
[INFO] [stdout]     |
[INFO] [stdout] 138 | pub async fn update_picture_status(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `with_pictures` and `full_fetch` are never read
[INFO] [stdout]   --> src/api/routes/anime.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct UpdateAnimeRequest {
[INFO] [stdout]    |            ------------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub with_pictures: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 45 |     #[serde(default)]
[INFO] [stdout] 46 |     pub full_fetch: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `UpdateAnimeRequest` 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 3m 46s
[INFO] running `Command { std: "docker" "inspect" "7a07b0545f9000ffce7a7906ed69d5fc03351ae56bc366102950020fc05c0fea", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7a07b0545f9000ffce7a7906ed69d5fc03351ae56bc366102950020fc05c0fea", kill_on_drop: false }`
[INFO] [stdout] 7a07b0545f9000ffce7a7906ed69d5fc03351ae56bc366102950020fc05c0fea
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 315aca78a78f536734290643432d2f6bb333dd353c346012c79a9fedb58964cb
[INFO] running `Command { std: "docker" "start" "-a" "315aca78a78f536734290643432d2f6bb333dd353c346012c79a9fedb58964cb", kill_on_drop: false }`
[INFO] [stderr]    Compiling media-collector v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `UpdateOptions`
[INFO] [stdout]  --> src/anime/my_anime_list/database.rs:3:67
[INFO] [stdout]   |
[INFO] [stdout] 3 | use mongodb::options::{FindOptions, IndexOptions, ReplaceOptions, UpdateOptions};
[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: `BatchFetchTask`
[INFO] [stdout]   --> src/anime/my_anime_list/module.rs:11:55
[INFO] [stdout]    |
[INFO] [stdout] 11 |     FetchAnimeTask, SearchAnimeTask, UpdateAnimeTask, BatchFetchTask,
[INFO] [stdout]    |                                                       ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `NaiveTime`
[INFO] [stdout]  --> src/anime/my_anime_list/model.rs:2:24
[INFO] [stdout]   |
[INFO] [stdout] 2 | use chrono::{DateTime, NaiveTime, Utc};
[INFO] [stdout]   |                        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/anime/my_anime_list/converter.rs:2:22
[INFO] [stdout]   |
[INFO] [stdout] 2 | use tracing::{debug, warn};
[INFO] [stdout]   |                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `database::update_anime_extended_data`
[INFO] [stdout]   --> src/anime/my_anime_list/task/fetch_extended.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     database::update_anime_extended_data,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fetch_pictures_for_anime::FetchAnimePicturesTask`
[INFO] [stdout]   --> src/anime/my_anime_list/task/mod.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub use fetch_pictures_for_anime::FetchAnimePicturesTask;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `module::MyAnimeListModule`
[INFO] [stdout]   --> src/anime/my_anime_list/mod.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub use module::MyAnimeListModule;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/anime/anilist/model.rs:2:14
[INFO] [stdout]   |
[INFO] [stdout] 2 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug` and `warn`
[INFO] [stdout]  --> src/anime/anilist/converter.rs:2:15
[INFO] [stdout]   |
[INFO] [stdout] 2 | use tracing::{debug, warn};
[INFO] [stdout]   |               ^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `model::AniListAnimeData`
[INFO] [stdout]   --> src/anime/anilist/task/fetch_pictures_for_anime.rs:10:56
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::anime::anilist::{database::get_anime_by_id, model::AniListAnimeData};
[INFO] [stdout]    |                                                        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fetch_pictures_for_anime::FetchAniListAnimePicturesTask`
[INFO] [stdout]  --> src/anime/anilist/task/mod.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use fetch_pictures_for_anime::FetchAniListAnimePicturesTask;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AniListMedia`, `GraphQLRequest`, and `GraphQLResponse`
[INFO] [stdout]  --> src/anime/anilist/mod.rs:8:17
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub use model::{AniListMedia, GraphQLRequest, GraphQLResponse};
[INFO] [stdout]   |                 ^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `converter::anilist_to_anime_data`
[INFO] [stdout]  --> src/anime/anilist/mod.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use converter::anilist_to_anime_data;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> src/global/http.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tracing::{info, debug, warn, error};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/picture/task.rs:6:28
[INFO] [stdout]   |
[INFO] [stdout] 6 | use tracing::{info, debug, warn, error};
[INFO] [stdout]   |                            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `UpdateOptions`
[INFO] [stdout]  --> src/picture/database.rs:4:67
[INFO] [stdout]   |
[INFO] [stdout] 4 | use mongodb::options::{FindOptions, IndexOptions, ReplaceOptions, UpdateOptions};
[INFO] [stdout]   |                                                                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Path`
[INFO] [stdout]  --> src/api/routes/picture.rs:2:15
[INFO] [stdout]   |
[INFO] [stdout] 2 |     extract::{Path, Query, State},
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Deserialize`
[INFO] [stdout]  --> src/api/routes/health.rs:6:13
[INFO] [stdout]   |
[INFO] [stdout] 6 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stdout]   --> src/global/http.rs:83:31
[INFO] [stdout]    |
[INFO] [stdout] 83 |         let encoded = base64::encode(credentials.as_bytes());
[INFO] [stdout]    |                               ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/anime/anilist/task/fetch_anime.rs:161:13
[INFO] [stdout]     |
[INFO] [stdout] 161 |         let config = RequestConfig::new()
[INFO] [stdout]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/anime/anilist/task/search_anime.rs:100:13
[INFO] [stdout]     |
[INFO] [stdout] 100 |         let config = RequestConfig::new()
[INFO] [stdout]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `queue`
[INFO] [stdout]    --> src/global/queue.rs:289:42
[INFO] [stdout]     |
[INFO] [stdout] 289 |     async fn load_persisted_tasks(&self, queue: &mut BinaryHeap<PriorityTask>) -> Result<(), AppError> {
[INFO] [stdout]     |                                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_queue`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `picture_module_ref` is never read
[INFO] [stdout]    --> src/main.rs:96:69
[INFO] [stdout]     |
[INFO] [stdout]  96 |     let mut picture_module_ref: Option<Arc<PictureFetcherModule>> = None;
[INFO] [stdout]     |                                                                     ^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 108 |     picture_module_ref = Some(Arc::new(picture_module.clone()));
[INFO] [stdout]     |     ------------------ `picture_module_ref` is overwritten here before the previous value is read
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `anime_exists` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:185:14
[INFO] [stdout]     |
[INFO] [stdout] 185 | pub async fn anime_exists(db: &Database, mal_id: i32) -> Result<bool, DatabaseError> {
[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 `search_anime_by_title` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:196:14
[INFO] [stdout]     |
[INFO] [stdout] 196 | pub async fn search_anime_by_title(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_top_rated_anime` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:232:14
[INFO] [stdout]     |
[INFO] [stdout] 232 | pub async fn get_top_rated_anime(db: &Database, limit: i64) -> Result<Vec<AnimeData>, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_most_popular_anime` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:261:14
[INFO] [stdout]     |
[INFO] [stdout] 261 | pub async fn get_most_popular_anime(db: &Database, limit: i64) -> Result<Vec<AnimeData>, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_by_season` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:290:14
[INFO] [stdout]     |
[INFO] [stdout] 290 | pub async fn get_anime_by_season(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_by_media_type` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:325:14
[INFO] [stdout]     |
[INFO] [stdout] 325 | pub async fn get_anime_by_media_type(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_airing_anime` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:358:14
[INFO] [stdout]     |
[INFO] [stdout] 358 | pub async fn get_airing_anime(db: &Database, limit: i64) -> Result<Vec<AnimeData>, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_count` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:387:14
[INFO] [stdout]     |
[INFO] [stdout] 387 | pub async fn get_anime_count(db: &Database) -> Result<u64, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_anime` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:395:14
[INFO] [stdout]     |
[INFO] [stdout] 395 | pub async fn delete_anime(db: &Database, mal_id: i32) -> Result<bool, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `bulk_insert_anime` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:406:14
[INFO] [stdout]     |
[INFO] [stdout] 406 | pub async fn bulk_insert_anime(db: &Database, anime_list: Vec<AnimeData>) -> Result<u64, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `update_anime_extended_data` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:420:14
[INFO] [stdout]     |
[INFO] [stdout] 420 | pub async fn update_anime_extended_data<T: Serialize>(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_needing_update` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:444:14
[INFO] [stdout]     |
[INFO] [stdout] 444 | pub async fn get_anime_needing_update(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AnimeCache` is never constructed
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:482:8
[INFO] [stdout]     |
[INFO] [stdout] 482 | struct AnimeCache {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cache_anime_data` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:490:14
[INFO] [stdout]     |
[INFO] [stdout] 490 | pub async fn cache_anime_data(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_cached_data` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:518:14
[INFO] [stdout]     |
[INFO] [stdout] 518 | pub async fn get_cached_data(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchHistory` is never constructed
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:537:8
[INFO] [stdout]     |
[INFO] [stdout] 537 | struct SearchHistory {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `record_search_history` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:543:10
[INFO] [stdout]     |
[INFO] [stdout] 543 | async fn record_search_history(db: &Database, query: &str) -> Result<(), DatabaseError> {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_recent_searches` is never used
[INFO] [stdout]    --> src/anime/my_anime_list/database.rs:558:14
[INFO] [stdout]     |
[INFO] [stdout] 558 | pub async fn get_recent_searches(db: &Database, limit: i64) -> Result<Vec<String>, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `queue_fetch_statistics`, `queue_fetch_pictures`, `queue_fetch_complete`, and `queue_fetch_all_extended_data` are never used
[INFO] [stdout]    --> src/anime/my_anime_list/module.rs:234:18
[INFO] [stdout]     |
[INFO] [stdout]  25 | impl MyAnimeListModule {
[INFO] [stdout]     | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub async fn queue_fetch_statistics(&self, anime_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 252 |     pub async fn queue_fetch_pictures(&self, anime_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 259 |     pub async fn queue_fetch_complete(&self, anime_id: u32, with_jikan: bool) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 277 |     pub async fn queue_fetch_all_extended_data(&self, anime_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BatchFetchPayload` is never constructed
[INFO] [stdout]   --> src/anime/my_anime_list/task/batch_fetch.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct BatchFetchPayload {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BatchFetchTask` is never constructed
[INFO] [stdout]   --> src/anime/my_anime_list/task/batch_fetch.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct BatchFetchTask {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `with_jikan` are never used
[INFO] [stdout]   --> src/anime/my_anime_list/task/batch_fetch.rs:28:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | impl BatchFetchTask {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 28 |     pub fn new(
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn with_jikan(mut self) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `last_visible_page` is never read
[INFO] [stdout]    --> src/anime/my_anime_list/task/fetch_extended.rs:295:5
[INFO] [stdout]     |
[INFO] [stdout] 294 | struct JikanPagination {
[INFO] [stdout]     |        --------------- field in this struct
[INFO] [stdout] 295 |     last_visible_page: i32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `JikanPagination` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `duration` is never read
[INFO] [stdout]    --> src/anime/my_anime_list/task/fetch_extended.rs:306:5
[INFO] [stdout]     |
[INFO] [stdout] 300 | struct JikanEpisode {
[INFO] [stdout]     |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 306 |     duration: Option<i32>,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `JikanEpisode` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `locations` is never read
[INFO] [stdout]   --> src/anime/anilist/model.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub struct GraphQLError {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub locations: Vec<ErrorLocation>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `GraphQLError` 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: fields `line` and `column` are never read
[INFO] [stdout]   --> src/anime/anilist/model.rs:36:9
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub struct ErrorLocation {
[INFO] [stdout]    |            ------------- fields in this struct
[INFO] [stdout] 36 |     pub line: i32,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 37 |     pub column: i32,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ErrorLocation` 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: fields `media_type`, `average_score`, `is_locked`, `is_favourite`, `is_favourite_blocked`, and `rankings` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:57:9
[INFO] [stdout]     |
[INFO] [stdout]  52 | pub struct AniListMedia {
[INFO] [stdout]     |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout]  57 |     pub media_type: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  79 |     pub average_score: Option<i32>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  82 |     pub is_locked: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub is_favourite: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^
[INFO] [stdout]  96 |     pub is_favourite_blocked: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     pub rankings: Option<Vec<MediaRank>>,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AniListMedia` 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: field `user_preferred` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 110 | pub struct MediaTitle {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub user_preferred: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaTitle` 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: fields `site` and `thumbnail` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:128:9
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub struct MediaTrailer {
[INFO] [stdout]     |            ------------ fields in this struct
[INFO] [stdout] 127 |     pub id: Option<String>,
[INFO] [stdout] 128 |     pub site: Option<String>,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 129 |     pub thumbnail: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaTrailer` 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: field `is_adult` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:151:9
[INFO] [stdout]     |
[INFO] [stdout] 143 | pub struct MediaTag {
[INFO] [stdout]     |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 151 |     pub is_adult: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaTag` 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: field `id` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:162:9
[INFO] [stdout]     |
[INFO] [stdout] 161 | pub struct MediaEdge {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] 162 |     pub id: Option<i32>,
[INFO] [stdout]     |         ^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaEdge` 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: fields `id_mal`, `format`, and `cover_image` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:171:9
[INFO] [stdout]     |
[INFO] [stdout] 169 | pub struct MediaNode {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 170 |     pub id: i32,
[INFO] [stdout] 171 |     pub id_mal: Option<i32>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 175 |     pub format: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 176 |     pub cover_image: Option<MediaCoverImage>,
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaNode` 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: field `id` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:186:9
[INFO] [stdout]     |
[INFO] [stdout] 185 | pub struct CharacterEdge {
[INFO] [stdout]     |            ------------- field in this struct
[INFO] [stdout] 186 |     pub id: Option<i32>,
[INFO] [stdout]     |         ^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `CharacterEdge` 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: fields `first`, `middle`, `last`, `native`, and `alternative` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:204:9
[INFO] [stdout]     |
[INFO] [stdout] 203 | pub struct CharacterName {
[INFO] [stdout]     |            ------------- fields in this struct
[INFO] [stdout] 204 |     pub first: Option<String>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 205 |     pub middle: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 206 |     pub last: Option<String>,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 207 |     pub full: Option<String>,
[INFO] [stdout] 208 |     pub native: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 209 |     #[serde(default)]
[INFO] [stdout] 210 |     pub alternative: Vec<String>,
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `CharacterName` 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: field `id` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:226:9
[INFO] [stdout]     |
[INFO] [stdout] 225 | pub struct StaffEdge {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] 226 |     pub id: Option<i32>,
[INFO] [stdout]     |         ^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `StaffEdge` 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: fields `first`, `middle`, `last`, and `native` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:243:9
[INFO] [stdout]     |
[INFO] [stdout] 242 | pub struct StaffName {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 243 |     pub first: Option<String>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 244 |     pub middle: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 245 |     pub last: Option<String>,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 246 |     pub full: Option<String>,
[INFO] [stdout] 247 |     pub native: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `StaffName` 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: field `is_main` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:264:9
[INFO] [stdout]     |
[INFO] [stdout] 263 | pub struct StudioEdge {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] 264 |     pub is_main: bool,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `StudioEdge` 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: field `is_animation_studio` is never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:273:9
[INFO] [stdout]     |
[INFO] [stdout] 270 | pub struct StudioNode {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 273 |     pub is_animation_studio: bool,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `StudioNode` 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: fields `title` and `thumbnail` are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:296:9
[INFO] [stdout]     |
[INFO] [stdout] 295 | pub struct MediaStreamingEpisode {
[INFO] [stdout]     |            --------------------- fields in this struct
[INFO] [stdout] 296 |     pub title: Option<String>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 297 |     pub thumbnail: Option<String>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaStreamingEpisode` 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: multiple fields are never read
[INFO] [stdout]    --> src/anime/anilist/model.rs:305:9
[INFO] [stdout]     |
[INFO] [stdout] 304 | pub struct MediaRank {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 305 |     pub id: i32,
[INFO] [stdout]     |         ^^
[INFO] [stdout] 306 |     pub rank: i32,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 307 |     #[serde(rename = "type")]
[INFO] [stdout] 308 |     pub rank_type: String,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 309 |     pub format: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 310 |     pub year: Option<i32>,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 311 |     pub season: Option<String>,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 312 |     pub all_time: Option<bool>,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 313 |     pub context: String,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MediaRank` 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 `PageData` is never constructed
[INFO] [stdout]    --> src/anime/anilist/model.rs:341:12
[INFO] [stdout]     |
[INFO] [stdout] 341 | pub struct PageData {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Page` is never constructed
[INFO] [stdout]    --> src/anime/anilist/model.rs:347:12
[INFO] [stdout]     |
[INFO] [stdout] 347 | pub struct Page {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PageInfo` is never constructed
[INFO] [stdout]    --> src/anime/anilist/model.rs:355:12
[INFO] [stdout]     |
[INFO] [stdout] 355 | pub struct PageInfo {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEARCH_ANIME_QUERY` is never used
[INFO] [stdout]    --> src/anime/anilist/queries.rs:402:11
[INFO] [stdout]     |
[INFO] [stdout] 402 | pub const SEARCH_ANIME_QUERY: &str = r#"
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TRENDING_ANIME_QUERY` is never used
[INFO] [stdout]    --> src/anime/anilist/queries.rs:460:11
[INFO] [stdout]     |
[INFO] [stdout] 460 | pub const TRENDING_ANIME_QUERY: &str = r#"
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ANIME_BY_SEASON_QUERY` is never used
[INFO] [stdout]    --> src/anime/anilist/queries.rs:492:11
[INFO] [stdout]     |
[INFO] [stdout] 492 | pub const ANIME_BY_SEASON_QUERY: &str = r#"
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config` is never read
[INFO] [stdout]   --> src/anime/anilist/module.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct AniListModule {
[INFO] [stdout]    |            ------------- field in this struct
[INFO] [stdout] 13 |     client: ClientWithLimiter,
[INFO] [stdout] 14 |     config: Arc<AppConfig>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `queue_fetch_by_anilist_id`, `queue_fetch_by_anilist_id_with_pictures`, `queue_fetch_by_anilist_id_full`, `queue_fetch_by_anilist_id_with_options`, and `queue_search_anime` are never used
[INFO] [stdout]    --> src/anime/anilist/module.rs:104:18
[INFO] [stdout]     |
[INFO] [stdout]  19 | impl AniListModule {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 104 |     pub async fn queue_fetch_by_anilist_id(&self, anilist_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub async fn queue_fetch_by_anilist_id_with_pictures(&self, anilist_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub async fn queue_fetch_by_anilist_id_full(&self, anilist_id: u32) -> Result<(), AppError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 118 |     async fn queue_fetch_by_anilist_id_with_options(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 160 |     pub async fn queue_search_anime(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `by_anilist_id` is never used
[INFO] [stdout]   --> src/anime/anilist/task/fetch_anime.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl FetchAnimeTask {
[INFO] [stdout]    | ------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 62 |     pub fn by_anilist_id(
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchAnimePayload` is never constructed
[INFO] [stdout]   --> src/anime/anilist/task/search_anime.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct SearchAnimePayload {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SearchAnimeTask` is never constructed
[INFO] [stdout]   --> src/anime/anilist/task/search_anime.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct SearchAnimeTask {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/anime/anilist/task/search_anime.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl SearchAnimeTask {
[INFO] [stdout]    | -------------------- associated function in this implementation
[INFO] [stdout] 31 |     pub fn new(
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_by_mal_id` is never used
[INFO] [stdout]    --> src/anime/anilist/database.rs:127:14
[INFO] [stdout]     |
[INFO] [stdout] 127 | pub async fn get_anime_by_mal_id(db: &Database, mal_id: i32) -> Result<Option<AniListAnimeData>, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `anime_exists` is never used
[INFO] [stdout]    --> src/anime/anilist/database.rs:136:14
[INFO] [stdout]     |
[INFO] [stdout] 136 | pub async fn anime_exists(db: &Database, anilist_id: i32) -> Result<bool, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `search_anime_by_title` is never used
[INFO] [stdout]    --> src/anime/anilist/database.rs:147:14
[INFO] [stdout]     |
[INFO] [stdout] 147 | pub async fn search_anime_by_title(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_anime_count` is never used
[INFO] [stdout]    --> src/anime/anilist/database.rs:180:14
[INFO] [stdout]     |
[INFO] [stdout] 180 | pub async fn get_anime_count(db: &Database) -> Result<u64, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_anime` is never used
[INFO] [stdout]    --> src/anime/anilist/database.rs:188:14
[INFO] [stdout]     |
[INFO] [stdout] 188 | pub async fn delete_anime(db: &Database, anilist_id: i32) -> Result<bool, DatabaseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `NotFound` is never constructed
[INFO] [stdout]  --> src/anime/error.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub enum AnimeError {
[INFO] [stdout]   |          ---------- variant in this enum
[INFO] [stdout] 3 |     #[error("anime not found")]
[INFO] [stdout] 4 |     NotFound,
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `AnimeError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `update_module_heartbeat` and `get_active_modules` are never used
[INFO] [stdout]    --> src/global/database.rs:149:18
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl DatabaseInstance {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 149 |     pub async fn update_module_heartbeat(&self, module_name: &str) -> Result<(), DatabaseError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 176 |     pub async fn get_active_modules(&self) -> Result<Vec<String>, DatabaseError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `MaxRetriesExceeded` is never constructed
[INFO] [stdout]   --> src/global/error.rs:49:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub enum HttpError {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 49 |     MaxRetriesExceeded,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `HttpError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AppState` is never constructed
[INFO] [stdout]  --> src/global/state.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct AppState {
[INFO] [stdout]   |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Custom` is never constructed
[INFO] [stdout]   --> src/global/module.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub enum ModuleMessage {
[INFO] [stdout]    |          ------------- variant in this enum
[INFO] [stdout] 16 |     Shutdown,
[INFO] [stdout] 17 |     Custom(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ModuleMessage` 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 `ModuleResponse` is never constructed
[INFO] [stdout]   --> src/global/module.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct ModuleResponse<T> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `try_acquire` is never used
[INFO] [stdout]    --> src/global/module.rs:114:12
[INFO] [stdout]     |
[INFO] [stdout]  63 | impl RateLimiter {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub fn try_acquire(&self) -> Result<(), std::time::Duration> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config` is never read
[INFO] [stdout]   --> src/global/http.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct HttpClientManager {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] 15 |     clients: Arc<ClientPool>,
[INFO] [stdout] 16 |     config: Arc<AppConfig>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `HttpClientManager` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `with_api_key`, `with_bearer_token`, `with_basic_auth`, and `with_retry_config` are never used
[INFO] [stdout]   --> src/global/http.rs:71:12
[INFO] [stdout]    |
[INFO] [stdout] 58 | impl RequestConfig {
[INFO] [stdout]    | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 71 |     pub fn with_api_key(self, api_key: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn with_bearer_token(self, token: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 81 |     pub fn with_basic_auth(self, username: impl Into<String>, password: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88 |     pub fn with_retry_config(mut self, config: RetryConfig) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `execute` and `try_execute` are never used
[INFO] [stdout]    --> src/global/http.rs:178:18
[INFO] [stdout]     |
[INFO] [stdout] 175 | impl ClientWithLimiter {
[INFO] [stdout]     | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 178 |     pub async fn execute<F, Fut, T>(&self, f: F) -> T
[INFO] [stdout]     |                  ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub async fn try_execute<F, Fut, T>(&self, f: F) -> Result<T, std::time::Duration>
[INFO] [stdout]     |                  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `is_child_module_enabled` and `get_child_module_config` are never used
[INFO] [stdout]    --> src/global/config.rs:204:12
[INFO] [stdout]     |
[INFO] [stdout] 147 | impl AppConfig {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub fn is_child_module_enabled(&self, module_name: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub fn get_child_module_config(&self, module_name: &str) -> Option<&ChildModuleConfig> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `name` is never used
[INFO] [stdout]    --> src/global/queue.rs:129:12
[INFO] [stdout]     |
[INFO] [stdout]  96 | impl TaskQueue {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 129 |     pub fn name(&self) -> &str {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ParseEnumError` is never constructed
[INFO] [stdout]  --> src/global/model.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ParseEnumError {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `storage_path` and `queue_fetch_pictures` are never used
[INFO] [stdout]    --> src/picture/mod.rs:53:12
[INFO] [stdout]     |
[INFO] [stdout]  23 | impl PictureFetcherModule {
[INFO] [stdout]     | ------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  53 |     pub fn storage_path(&self) -> &Path {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub async fn queue_fetch_pictures(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_failed` is never used
[INFO] [stdout]   --> src/picture/model.rs:99:12
[INFO] [stdout]    |
[INFO] [stdout] 70 | impl PictureMetadata {
[INFO] [stdout]    | -------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 99 |     pub fn is_failed(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_picture_by_path` is never used
[INFO] [stdout]   --> src/picture/database.rs:95:14
[INFO] [stdout]    |
[INFO] [stdout] 95 | pub async fn get_picture_by_path(db: &Database, path: &str) -> Result<Option<PictureMetadata>, DatabaseError> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `update_picture_status` is never used
[INFO] [stdout]    --> src/picture/database.rs:138:14
[INFO] [stdout]     |
[INFO] [stdout] 138 | pub async fn update_picture_status(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `with_pictures` and `full_fetch` are never read
[INFO] [stdout]   --> src/api/routes/anime.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub struct UpdateAnimeRequest {
[INFO] [stdout]    |            ------------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub with_pictures: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 45 |     #[serde(default)]
[INFO] [stdout] 46 |     pub full_fetch: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `UpdateAnimeRequest` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 49.15s
[INFO] running `Command { std: "docker" "inspect" "315aca78a78f536734290643432d2f6bb333dd353c346012c79a9fedb58964cb", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "315aca78a78f536734290643432d2f6bb333dd353c346012c79a9fedb58964cb", kill_on_drop: false }`
[INFO] [stdout] 315aca78a78f536734290643432d2f6bb333dd353c346012c79a9fedb58964cb
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] d50777381679f045f02edee26029409d9addd1e515186707416343cf59cf44aa
[INFO] running `Command { std: "docker" "start" "-a" "d50777381679f045f02edee26029409d9addd1e515186707416343cf59cf44aa", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `UpdateOptions`
[INFO] [stderr]  --> src/anime/my_anime_list/database.rs:3:67
[INFO] [stderr]   |
[INFO] [stderr] 3 | use mongodb::options::{FindOptions, IndexOptions, ReplaceOptions, UpdateOptions};
[INFO] [stderr]   |                                                                   ^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `BatchFetchTask`
[INFO] [stderr]   --> src/anime/my_anime_list/module.rs:11:55
[INFO] [stderr]    |
[INFO] [stderr] 11 |     FetchAnimeTask, SearchAnimeTask, UpdateAnimeTask, BatchFetchTask,
[INFO] [stderr]    |                                                       ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `NaiveTime`
[INFO] [stderr]  --> src/anime/my_anime_list/model.rs:2:24
[INFO] [stderr]   |
[INFO] [stderr] 2 | use chrono::{DateTime, NaiveTime, Utc};
[INFO] [stderr]   |                        ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `warn`
[INFO] [stderr]  --> src/anime/my_anime_list/converter.rs:2:22
[INFO] [stderr]   |
[INFO] [stderr] 2 | use tracing::{debug, warn};
[INFO] [stderr]   |                      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `database::update_anime_extended_data`
[INFO] [stderr]   --> src/anime/my_anime_list/task/fetch_extended.rs:14:5
[INFO] [stderr]    |
[INFO] [stderr] 14 |     database::update_anime_extended_data,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `fetch_pictures_for_anime::FetchAnimePicturesTask`
[INFO] [stderr]   --> src/anime/my_anime_list/task/mod.rs:23:9
[INFO] [stderr]    |
[INFO] [stderr] 23 | pub use fetch_pictures_for_anime::FetchAnimePicturesTask;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `module::MyAnimeListModule`
[INFO] [stderr]   --> src/anime/my_anime_list/mod.rs:10:9
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub use module::MyAnimeListModule;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `DateTime` and `Utc`
[INFO] [stderr]  --> src/anime/anilist/model.rs:2:14
[INFO] [stderr]   |
[INFO] [stderr] 2 | use chrono::{DateTime, Utc};
[INFO] [stderr]   |              ^^^^^^^^  ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `debug` and `warn`
[INFO] [stderr]  --> src/anime/anilist/converter.rs:2:15
[INFO] [stderr]   |
[INFO] [stderr] 2 | use tracing::{debug, warn};
[INFO] [stderr]   |               ^^^^^  ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `model::AniListAnimeData`
[INFO] [stderr]   --> src/anime/anilist/task/fetch_pictures_for_anime.rs:10:56
[INFO] [stderr]    |
[INFO] [stderr] 10 | use crate::anime::anilist::{database::get_anime_by_id, model::AniListAnimeData};
[INFO] [stderr]    |                                                        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `fetch_pictures_for_anime::FetchAniListAnimePicturesTask`
[INFO] [stderr]  --> src/anime/anilist/task/mod.rs:7:9
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub use fetch_pictures_for_anime::FetchAniListAnimePicturesTask;
[INFO] [stderr]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `AniListMedia`, `GraphQLRequest`, and `GraphQLResponse`
[INFO] [stderr]  --> src/anime/anilist/mod.rs:8:17
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub use model::{AniListMedia, GraphQLRequest, GraphQLResponse};
[INFO] [stderr]   |                 ^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `converter::anilist_to_anime_data`
[INFO] [stderr]  --> src/anime/anilist/mod.rs:9:9
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub use converter::anilist_to_anime_data;
[INFO] [stderr]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `info`
[INFO] [stderr]  --> src/global/http.rs:6:15
[INFO] [stderr]   |
[INFO] [stderr] 6 | use tracing::{info, debug, warn, error};
[INFO] [stderr]   |               ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `warn`
[INFO] [stderr]  --> src/picture/task.rs:6:28
[INFO] [stderr]   |
[INFO] [stderr] 6 | use tracing::{info, debug, warn, error};
[INFO] [stderr]   |                            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `UpdateOptions`
[INFO] [stderr]  --> src/picture/database.rs:4:67
[INFO] [stderr]   |
[INFO] [stderr] 4 | use mongodb::options::{FindOptions, IndexOptions, ReplaceOptions, UpdateOptions};
[INFO] [stderr]   |                                                                   ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Path`
[INFO] [stderr]  --> src/api/routes/picture.rs:2:15
[INFO] [stderr]   |
[INFO] [stderr] 2 |     extract::{Path, Query, State},
[INFO] [stderr]   |               ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Deserialize`
[INFO] [stderr]  --> src/api/routes/health.rs:6:13
[INFO] [stderr]   |
[INFO] [stderr] 6 | use serde::{Deserialize, Serialize};
[INFO] [stderr]   |             ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `base64::encode`: Use Engine::encode
[INFO] [stderr]   --> src/global/http.rs:83:31
[INFO] [stderr]    |
[INFO] [stderr] 83 |         let encoded = base64::encode(credentials.as_bytes());
[INFO] [stderr]    |                               ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `config`
[INFO] [stderr]    --> src/anime/anilist/task/fetch_anime.rs:161:13
[INFO] [stderr]     |
[INFO] [stderr] 161 |         let config = RequestConfig::new()
[INFO] [stderr]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `config`
[INFO] [stderr]    --> src/anime/anilist/task/search_anime.rs:100:13
[INFO] [stderr]     |
[INFO] [stderr] 100 |         let config = RequestConfig::new()
[INFO] [stderr]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `queue`
[INFO] [stderr]    --> src/global/queue.rs:289:42
[INFO] [stderr]     |
[INFO] [stderr] 289 |     async fn load_persisted_tasks(&self, queue: &mut BinaryHeap<PriorityTask>) -> Result<(), AppError> {
[INFO] [stderr]     |                                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_queue`
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `picture_module_ref` is never read
[INFO] [stderr]    --> src/main.rs:96:69
[INFO] [stderr]     |
[INFO] [stderr]  96 |     let mut picture_module_ref: Option<Arc<PictureFetcherModule>> = None;
[INFO] [stderr]     |                                                                     ^^^^ this value is reassigned later and never used
[INFO] [stderr] ...
[INFO] [stderr] 108 |     picture_module_ref = Some(Arc::new(picture_module.clone()));
[INFO] [stderr]     |     ------------------ `picture_module_ref` is overwritten here before the previous value is read
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `anime_exists` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:185:14
[INFO] [stderr]     |
[INFO] [stderr] 185 | pub async fn anime_exists(db: &Database, mal_id: i32) -> Result<bool, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `search_anime_by_title` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:196:14
[INFO] [stderr]     |
[INFO] [stderr] 196 | pub async fn search_anime_by_title(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_top_rated_anime` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:232:14
[INFO] [stderr]     |
[INFO] [stderr] 232 | pub async fn get_top_rated_anime(db: &Database, limit: i64) -> Result<Vec<AnimeData>, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_most_popular_anime` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:261:14
[INFO] [stderr]     |
[INFO] [stderr] 261 | pub async fn get_most_popular_anime(db: &Database, limit: i64) -> Result<Vec<AnimeData>, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_anime_by_season` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:290:14
[INFO] [stderr]     |
[INFO] [stderr] 290 | pub async fn get_anime_by_season(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_anime_by_media_type` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:325:14
[INFO] [stderr]     |
[INFO] [stderr] 325 | pub async fn get_anime_by_media_type(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_airing_anime` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:358:14
[INFO] [stderr]     |
[INFO] [stderr] 358 | pub async fn get_airing_anime(db: &Database, limit: i64) -> Result<Vec<AnimeData>, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_anime_count` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:387:14
[INFO] [stderr]     |
[INFO] [stderr] 387 | pub async fn get_anime_count(db: &Database) -> Result<u64, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `delete_anime` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:395:14
[INFO] [stderr]     |
[INFO] [stderr] 395 | pub async fn delete_anime(db: &Database, mal_id: i32) -> Result<bool, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `bulk_insert_anime` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:406:14
[INFO] [stderr]     |
[INFO] [stderr] 406 | pub async fn bulk_insert_anime(db: &Database, anime_list: Vec<AnimeData>) -> Result<u64, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `update_anime_extended_data` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:420:14
[INFO] [stderr]     |
[INFO] [stderr] 420 | pub async fn update_anime_extended_data<T: Serialize>(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_anime_needing_update` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:444:14
[INFO] [stderr]     |
[INFO] [stderr] 444 | pub async fn get_anime_needing_update(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `AnimeCache` is never constructed
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:482:8
[INFO] [stderr]     |
[INFO] [stderr] 482 | struct AnimeCache {
[INFO] [stderr]     |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `cache_anime_data` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:490:14
[INFO] [stderr]     |
[INFO] [stderr] 490 | pub async fn cache_anime_data(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_cached_data` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:518:14
[INFO] [stderr]     |
[INFO] [stderr] 518 | pub async fn get_cached_data(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SearchHistory` is never constructed
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:537:8
[INFO] [stderr]     |
[INFO] [stderr] 537 | struct SearchHistory {
[INFO] [stderr]     |        ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `record_search_history` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:543:10
[INFO] [stderr]     |
[INFO] [stderr] 543 | async fn record_search_history(db: &Database, query: &str) -> Result<(), DatabaseError> {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_recent_searches` is never used
[INFO] [stderr]    --> src/anime/my_anime_list/database.rs:558:14
[INFO] [stderr]     |
[INFO] [stderr] 558 | pub async fn get_recent_searches(db: &Database, limit: i64) -> Result<Vec<String>, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `queue_fetch_statistics`, `queue_fetch_pictures`, `queue_fetch_complete`, and `queue_fetch_all_extended_data` are never used
[INFO] [stderr]    --> src/anime/my_anime_list/module.rs:234:18
[INFO] [stderr]     |
[INFO] [stderr]  25 | impl MyAnimeListModule {
[INFO] [stderr]     | ---------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 234 |     pub async fn queue_fetch_statistics(&self, anime_id: u32) -> Result<(), AppError> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 252 |     pub async fn queue_fetch_pictures(&self, anime_id: u32) -> Result<(), AppError> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 259 |     pub async fn queue_fetch_complete(&self, anime_id: u32, with_jikan: bool) -> Result<(), AppError> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 277 |     pub async fn queue_fetch_all_extended_data(&self, anime_id: u32) -> Result<(), AppError> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `BatchFetchPayload` is never constructed
[INFO] [stderr]   --> src/anime/my_anime_list/task/batch_fetch.rs:12:12
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct BatchFetchPayload {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `BatchFetchTask` is never constructed
[INFO] [stderr]   --> src/anime/my_anime_list/task/batch_fetch.rs:16:12
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub struct BatchFetchTask {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new` and `with_jikan` are never used
[INFO] [stderr]   --> src/anime/my_anime_list/task/batch_fetch.rs:28:12
[INFO] [stderr]    |
[INFO] [stderr] 27 | impl BatchFetchTask {
[INFO] [stderr]    | ------------------- associated items in this implementation
[INFO] [stderr] 28 |     pub fn new(
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 47 |     pub fn with_jikan(mut self) -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `last_visible_page` is never read
[INFO] [stderr]    --> src/anime/my_anime_list/task/fetch_extended.rs:295:5
[INFO] [stderr]     |
[INFO] [stderr] 294 | struct JikanPagination {
[INFO] [stderr]     |        --------------- field in this struct
[INFO] [stderr] 295 |     last_visible_page: i32,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `JikanPagination` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `duration` is never read
[INFO] [stderr]    --> src/anime/my_anime_list/task/fetch_extended.rs:306:5
[INFO] [stderr]     |
[INFO] [stderr] 300 | struct JikanEpisode {
[INFO] [stderr]     |        ------------ field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 306 |     duration: Option<i32>,
[INFO] [stderr]     |     ^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `JikanEpisode` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `locations` is never read
[INFO] [stderr]   --> src/anime/anilist/model.rs:31:9
[INFO] [stderr]    |
[INFO] [stderr] 28 | pub struct GraphQLError {
[INFO] [stderr]    |            ------------ field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 31 |     pub locations: Vec<ErrorLocation>,
[INFO] [stderr]    |         ^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `GraphQLError` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `line` and `column` are never read
[INFO] [stderr]   --> src/anime/anilist/model.rs:36:9
[INFO] [stderr]    |
[INFO] [stderr] 35 | pub struct ErrorLocation {
[INFO] [stderr]    |            ------------- fields in this struct
[INFO] [stderr] 36 |     pub line: i32,
[INFO] [stderr]    |         ^^^^
[INFO] [stderr] 37 |     pub column: i32,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ErrorLocation` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `media_type`, `average_score`, `is_locked`, `is_favourite`, `is_favourite_blocked`, and `rankings` are never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:57:9
[INFO] [stderr]     |
[INFO] [stderr]  52 | pub struct AniListMedia {
[INFO] [stderr]     |            ------------ fields in this struct
[INFO] [stderr] ...
[INFO] [stderr]  57 |     pub media_type: Option<String>,
[INFO] [stderr]     |         ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  79 |     pub average_score: Option<i32>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  82 |     pub is_locked: Option<bool>,
[INFO] [stderr]     |         ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  95 |     pub is_favourite: Option<bool>,
[INFO] [stderr]     |         ^^^^^^^^^^^^
[INFO] [stderr]  96 |     pub is_favourite_blocked: Option<bool>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 103 |     pub rankings: Option<Vec<MediaRank>>,
[INFO] [stderr]     |         ^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `AniListMedia` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `user_preferred` is never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:114:9
[INFO] [stderr]     |
[INFO] [stderr] 110 | pub struct MediaTitle {
[INFO] [stderr]     |            ---------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 114 |     pub user_preferred: Option<String>,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `MediaTitle` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `site` and `thumbnail` are never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:128:9
[INFO] [stderr]     |
[INFO] [stderr] 126 | pub struct MediaTrailer {
[INFO] [stderr]     |            ------------ fields in this struct
[INFO] [stderr] 127 |     pub id: Option<String>,
[INFO] [stderr] 128 |     pub site: Option<String>,
[INFO] [stderr]     |         ^^^^
[INFO] [stderr] 129 |     pub thumbnail: Option<String>,
[INFO] [stderr]     |         ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `MediaTrailer` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `is_adult` is never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:151:9
[INFO] [stderr]     |
[INFO] [stderr] 143 | pub struct MediaTag {
[INFO] [stderr]     |            -------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 151 |     pub is_adult: Option<bool>,
[INFO] [stderr]     |         ^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `MediaTag` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `id` is never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:162:9
[INFO] [stderr]     |
[INFO] [stderr] 161 | pub struct MediaEdge {
[INFO] [stderr]     |            --------- field in this struct
[INFO] [stderr] 162 |     pub id: Option<i32>,
[INFO] [stderr]     |         ^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `MediaEdge` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `id_mal`, `format`, and `cover_image` are never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:171:9
[INFO] [stderr]     |
[INFO] [stderr] 169 | pub struct MediaNode {
[INFO] [stderr]     |            --------- fields in this struct
[INFO] [stderr] 170 |     pub id: i32,
[INFO] [stderr] 171 |     pub id_mal: Option<i32>,
[INFO] [stderr]     |         ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 175 |     pub format: Option<String>,
[INFO] [stderr]     |         ^^^^^^
[INFO] [stderr] 176 |     pub cover_image: Option<MediaCoverImage>,
[INFO] [stderr]     |         ^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `MediaNode` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `id` is never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:186:9
[INFO] [stderr]     |
[INFO] [stderr] 185 | pub struct CharacterEdge {
[INFO] [stderr]     |            ------------- field in this struct
[INFO] [stderr] 186 |     pub id: Option<i32>,
[INFO] [stderr]     |         ^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `CharacterEdge` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `first`, `middle`, `last`, `native`, and `alternative` are never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:204:9
[INFO] [stderr]     |
[INFO] [stderr] 203 | pub struct CharacterName {
[INFO] [stderr]     |            ------------- fields in this struct
[INFO] [stderr] 204 |     pub first: Option<String>,
[INFO] [stderr]     |         ^^^^^
[INFO] [stderr] 205 |     pub middle: Option<String>,
[INFO] [stderr]     |         ^^^^^^
[INFO] [stderr] 206 |     pub last: Option<String>,
[INFO] [stderr]     |         ^^^^
[INFO] [stderr] 207 |     pub full: Option<String>,
[INFO] [stderr] 208 |     pub native: Option<String>,
[INFO] [stderr]     |         ^^^^^^
[INFO] [stderr] 209 |     #[serde(default)]
[INFO] [stderr] 210 |     pub alternative: Vec<String>,
[INFO] [stderr]     |         ^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `CharacterName` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `id` is never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:226:9
[INFO] [stderr]     |
[INFO] [stderr] 225 | pub struct StaffEdge {
[INFO] [stderr]     |            --------- field in this struct
[INFO] [stderr] 226 |     pub id: Option<i32>,
[INFO] [stderr]     |         ^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `StaffEdge` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `first`, `middle`, `last`, and `native` are never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:243:9
[INFO] [stderr]     |
[INFO] [stderr] 242 | pub struct StaffName {
[INFO] [stderr]     |            --------- fields in this struct
[INFO] [stderr] 243 |     pub first: Option<String>,
[INFO] [stderr]     |         ^^^^^
[INFO] [stderr] 244 |     pub middle: Option<String>,
[INFO] [stderr]     |         ^^^^^^
[INFO] [stderr] 245 |     pub last: Option<String>,
[INFO] [stderr]     |         ^^^^
[INFO] [stderr] 246 |     pub full: Option<String>,
[INFO] [stderr] 247 |     pub native: Option<String>,
[INFO] [stderr]     |         ^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `StaffName` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `is_main` is never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:264:9
[INFO] [stderr]     |
[INFO] [stderr] 263 | pub struct StudioEdge {
[INFO] [stderr]     |            ---------- field in this struct
[INFO] [stderr] 264 |     pub is_main: bool,
[INFO] [stderr]     |         ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `StudioEdge` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `is_animation_studio` is never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:273:9
[INFO] [stderr]     |
[INFO] [stderr] 270 | pub struct StudioNode {
[INFO] [stderr]     |            ---------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 273 |     pub is_animation_studio: bool,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `StudioNode` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `title` and `thumbnail` are never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:296:9
[INFO] [stderr]     |
[INFO] [stderr] 295 | pub struct MediaStreamingEpisode {
[INFO] [stderr]     |            --------------------- fields in this struct
[INFO] [stderr] 296 |     pub title: Option<String>,
[INFO] [stderr]     |         ^^^^^
[INFO] [stderr] 297 |     pub thumbnail: Option<String>,
[INFO] [stderr]     |         ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `MediaStreamingEpisode` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: multiple fields are never read
[INFO] [stderr]    --> src/anime/anilist/model.rs:305:9
[INFO] [stderr]     |
[INFO] [stderr] 304 | pub struct MediaRank {
[INFO] [stderr]     |            --------- fields in this struct
[INFO] [stderr] 305 |     pub id: i32,
[INFO] [stderr]     |         ^^
[INFO] [stderr] 306 |     pub rank: i32,
[INFO] [stderr]     |         ^^^^
[INFO] [stderr] 307 |     #[serde(rename = "type")]
[INFO] [stderr] 308 |     pub rank_type: String,
[INFO] [stderr]     |         ^^^^^^^^^
[INFO] [stderr] 309 |     pub format: String,
[INFO] [stderr]     |         ^^^^^^
[INFO] [stderr] 310 |     pub year: Option<i32>,
[INFO] [stderr]     |         ^^^^
[INFO] [stderr] 311 |     pub season: Option<String>,
[INFO] [stderr]     |         ^^^^^^
[INFO] [stderr] 312 |     pub all_time: Option<bool>,
[INFO] [stderr]     |         ^^^^^^^^
[INFO] [stderr] 313 |     pub context: String,
[INFO] [stderr]     |         ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `MediaRank` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PageData` is never constructed
[INFO] [stderr]    --> src/anime/anilist/model.rs:341:12
[INFO] [stderr]     |
[INFO] [stderr] 341 | pub struct PageData {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Page` is never constructed
[INFO] [stderr]    --> src/anime/anilist/model.rs:347:12
[INFO] [stderr]     |
[INFO] [stderr] 347 | pub struct Page {
[INFO] [stderr]     |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PageInfo` is never constructed
[INFO] [stderr]    --> src/anime/anilist/model.rs:355:12
[INFO] [stderr]     |
[INFO] [stderr] 355 | pub struct PageInfo {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `SEARCH_ANIME_QUERY` is never used
[INFO] [stderr]    --> src/anime/anilist/queries.rs:402:11
[INFO] [stderr]     |
[INFO] [stderr] 402 | pub const SEARCH_ANIME_QUERY: &str = r#"
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `TRENDING_ANIME_QUERY` is never used
[INFO] [stderr]    --> src/anime/anilist/queries.rs:460:11
[INFO] [stderr]     |
[INFO] [stderr] 460 | pub const TRENDING_ANIME_QUERY: &str = r#"
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `ANIME_BY_SEASON_QUERY` is never used
[INFO] [stderr]    --> src/anime/anilist/queries.rs:492:11
[INFO] [stderr]     |
[INFO] [stderr] 492 | pub const ANIME_BY_SEASON_QUERY: &str = r#"
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `config` is never read
[INFO] [stderr]   --> src/anime/anilist/module.rs:14:5
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct AniListModule {
[INFO] [stderr]    |            ------------- field in this struct
[INFO] [stderr] 13 |     client: ClientWithLimiter,
[INFO] [stderr] 14 |     config: Arc<AppConfig>,
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `queue_fetch_by_anilist_id`, `queue_fetch_by_anilist_id_with_pictures`, `queue_fetch_by_anilist_id_full`, `queue_fetch_by_anilist_id_with_options`, and `queue_search_anime` are never used
[INFO] [stderr]    --> src/anime/anilist/module.rs:104:18
[INFO] [stderr]     |
[INFO] [stderr]  19 | impl AniListModule {
[INFO] [stderr]     | ------------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 104 |     pub async fn queue_fetch_by_anilist_id(&self, anilist_id: u32) -> Result<(), AppError> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 109 |     pub async fn queue_fetch_by_anilist_id_with_pictures(&self, anilist_id: u32) -> Result<(), AppError> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 114 |     pub async fn queue_fetch_by_anilist_id_full(&self, anilist_id: u32) -> Result<(), AppError> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 118 |     async fn queue_fetch_by_anilist_id_with_options(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 160 |     pub async fn queue_search_anime(
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `by_anilist_id` is never used
[INFO] [stderr]   --> src/anime/anilist/task/fetch_anime.rs:62:12
[INFO] [stderr]    |
[INFO] [stderr] 42 | impl FetchAnimeTask {
[INFO] [stderr]    | ------------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 62 |     pub fn by_anilist_id(
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SearchAnimePayload` is never constructed
[INFO] [stderr]   --> src/anime/anilist/task/search_anime.rs:15:12
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub struct SearchAnimePayload {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SearchAnimeTask` is never constructed
[INFO] [stderr]   --> src/anime/anilist/task/search_anime.rs:21:12
[INFO] [stderr]    |
[INFO] [stderr] 21 | pub struct SearchAnimeTask {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/anime/anilist/task/search_anime.rs:31:12
[INFO] [stderr]    |
[INFO] [stderr] 30 | impl SearchAnimeTask {
[INFO] [stderr]    | -------------------- associated function in this implementation
[INFO] [stderr] 31 |     pub fn new(
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_anime_by_mal_id` is never used
[INFO] [stderr]    --> src/anime/anilist/database.rs:127:14
[INFO] [stderr]     |
[INFO] [stderr] 127 | pub async fn get_anime_by_mal_id(db: &Database, mal_id: i32) -> Result<Option<AniListAnimeData>, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `anime_exists` is never used
[INFO] [stderr]    --> src/anime/anilist/database.rs:136:14
[INFO] [stderr]     |
[INFO] [stderr] 136 | pub async fn anime_exists(db: &Database, anilist_id: i32) -> Result<bool, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `search_anime_by_title` is never used
[INFO] [stderr]    --> src/anime/anilist/database.rs:147:14
[INFO] [stderr]     |
[INFO] [stderr] 147 | pub async fn search_anime_by_title(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_anime_count` is never used
[INFO] [stderr]    --> src/anime/anilist/database.rs:180:14
[INFO] [stderr]     |
[INFO] [stderr] 180 | pub async fn get_anime_count(db: &Database) -> Result<u64, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `delete_anime` is never used
[INFO] [stderr]    --> src/anime/anilist/database.rs:188:14
[INFO] [stderr]     |
[INFO] [stderr] 188 | pub async fn delete_anime(db: &Database, anilist_id: i32) -> Result<bool, DatabaseError> {
[INFO] [stderr]     |              ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variant `NotFound` is never constructed
[INFO] [stderr]  --> src/anime/error.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | pub enum AnimeError {
[INFO] [stderr]   |          ---------- variant in this enum
[INFO] [stderr] 3 |     #[error("anime not found")]
[INFO] [stderr] 4 |     NotFound,
[INFO] [stderr]   |     ^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `AnimeError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `update_module_heartbeat` and `get_active_modules` are never used
[INFO] [stderr]    --> src/global/database.rs:149:18
[INFO] [stderr]     |
[INFO] [stderr]  15 | impl DatabaseInstance {
[INFO] [stderr]     | --------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 149 |     pub async fn update_module_heartbeat(&self, module_name: &str) -> Result<(), DatabaseError> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 176 |     pub async fn get_active_modules(&self) -> Result<Vec<String>, DatabaseError> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variant `MaxRetriesExceeded` is never constructed
[INFO] [stderr]   --> src/global/error.rs:49:5
[INFO] [stderr]    |
[INFO] [stderr] 26 | pub enum HttpError {
[INFO] [stderr]    |          --------- variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 49 |     MaxRetriesExceeded,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `HttpError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: struct `AppState` is never constructed
[INFO] [stderr]  --> src/global/state.rs:6:12
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub struct AppState {
[INFO] [stderr]   |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Custom` is never constructed
[INFO] [stderr]   --> src/global/module.rs:17:5
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub enum ModuleMessage {
[INFO] [stderr]    |          ------------- variant in this enum
[INFO] [stderr] 16 |     Shutdown,
[INFO] [stderr] 17 |     Custom(String),
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ModuleMessage` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ModuleResponse` is never constructed
[INFO] [stderr]   --> src/global/module.rs:22:12
[INFO] [stderr]    |
[INFO] [stderr] 22 | pub struct ModuleResponse<T> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `try_acquire` is never used
[INFO] [stderr]    --> src/global/module.rs:114:12
[INFO] [stderr]     |
[INFO] [stderr]  63 | impl RateLimiter {
[INFO] [stderr]     | ---------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 114 |     pub fn try_acquire(&self) -> Result<(), std::time::Duration> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `config` is never read
[INFO] [stderr]   --> src/global/http.rs:16:5
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub struct HttpClientManager {
[INFO] [stderr]    |            ----------------- field in this struct
[INFO] [stderr] 15 |     clients: Arc<ClientPool>,
[INFO] [stderr] 16 |     config: Arc<AppConfig>,
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `HttpClientManager` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `with_api_key`, `with_bearer_token`, `with_basic_auth`, and `with_retry_config` are never used
[INFO] [stderr]   --> src/global/http.rs:71:12
[INFO] [stderr]    |
[INFO] [stderr] 58 | impl RequestConfig {
[INFO] [stderr]    | ------------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 71 |     pub fn with_api_key(self, api_key: impl Into<String>) -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 76 |     pub fn with_bearer_token(self, token: impl Into<String>) -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 81 |     pub fn with_basic_auth(self, username: impl Into<String>, password: impl Into<String>) -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 88 |     pub fn with_retry_config(mut self, config: RetryConfig) -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `execute` and `try_execute` are never used
[INFO] [stderr]    --> src/global/http.rs:178:18
[INFO] [stderr]     |
[INFO] [stderr] 175 | impl ClientWithLimiter {
[INFO] [stderr]     | ---------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 178 |     pub async fn execute<F, Fut, T>(&self, f: F) -> T
[INFO] [stderr]     |                  ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 191 |     pub async fn try_execute<F, Fut, T>(&self, f: F) -> Result<T, std::time::Duration>
[INFO] [stderr]     |                  ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `is_child_module_enabled` and `get_child_module_config` are never used
[INFO] [stderr]    --> src/global/config.rs:204:12
[INFO] [stderr]     |
[INFO] [stderr] 147 | impl AppConfig {
[INFO] [stderr]     | -------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 204 |     pub fn is_child_module_enabled(&self, module_name: &str) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 212 |     pub fn get_child_module_config(&self, module_name: &str) -> Option<&ChildModuleConfig> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `name` is never used
[INFO] [stderr]    --> src/global/queue.rs:129:12
[INFO] [stderr]     |
[INFO] [stderr]  96 | impl TaskQueue {
[INFO] [stderr]     | -------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 129 |     pub fn name(&self) -> &str {
[INFO] [stderr]     |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ParseEnumError` is never constructed
[INFO] [stderr]  --> src/global/model.rs:4:12
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub struct ParseEnumError {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `storage_path` and `queue_fetch_pictures` are never used
[INFO] [stderr]    --> src/picture/mod.rs:53:12
[INFO] [stderr]     |
[INFO] [stderr]  23 | impl PictureFetcherModule {
[INFO] [stderr]     | ------------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  53 |     pub fn storage_path(&self) -> &Path {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 109 |     pub async fn queue_fetch_pictures(
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `is_failed` is never used
[INFO] [stderr]   --> src/picture/model.rs:99:12
[INFO] [stderr]    |
[INFO] [stderr] 70 | impl PictureMetadata {
[INFO] [stderr]    | -------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 99 |     pub fn is_failed(&self) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_picture_by_path` is never used
[INFO] [stderr]   --> src/picture/database.rs:95:14
[INFO] [stderr]    |
[INFO] [stderr] 95 | pub async fn get_picture_by_path(db: &Database, path: &str) -> Result<Option<PictureMetadata>, DatabaseError> {
[INFO] [stderr]    |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `update_picture_status` is never used
[INFO] [stderr]    --> src/picture/database.rs:138:14
[INFO] [stderr]     |
[INFO] [stderr] 138 | pub async fn update_picture_status(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `with_pictures` and `full_fetch` are never read
[INFO] [stderr]   --> src/api/routes/anime.rs:44:9
[INFO] [stderr]    |
[INFO] [stderr] 39 | pub struct UpdateAnimeRequest {
[INFO] [stderr]    |            ------------------ fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 44 |     pub with_pictures: bool,
[INFO] [stderr]    |         ^^^^^^^^^^^^^
[INFO] [stderr] 45 |     #[serde(default)]
[INFO] [stderr] 46 |     pub full_fetch: bool,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `UpdateAnimeRequest` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: `media-collector` (bin "media-collector" test) generated 98 warnings (run `cargo fix --bin "media-collector" -p media-collector --tests` to apply 21 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.68s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/media_collector-9bb227d8097d4636)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "d50777381679f045f02edee26029409d9addd1e515186707416343cf59cf44aa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d50777381679f045f02edee26029409d9addd1e515186707416343cf59cf44aa", kill_on_drop: false }`
[INFO] [stdout] d50777381679f045f02edee26029409d9addd1e515186707416343cf59cf44aa
