[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) -> 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> = 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 { [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, 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, 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, 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 { [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 { [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) -> Result { [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( [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, 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, [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, [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, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 79 | pub average_score: Option, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 82 | pub is_locked: Option, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 95 | pub is_favourite: Option, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 96 | pub is_favourite_blocked: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 103 | pub rankings: Option>, [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, [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, [INFO] [stdout] 128 | pub site: Option, [INFO] [stdout] | ^^^^ [INFO] [stdout] 129 | pub thumbnail: Option, [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, [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, [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, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 175 | pub format: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 176 | pub cover_image: Option, [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, [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, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 205 | pub middle: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 206 | pub last: Option, [INFO] [stdout] | ^^^^ [INFO] [stdout] 207 | pub full: Option, [INFO] [stdout] 208 | pub native: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 209 | #[serde(default)] [INFO] [stdout] 210 | pub alternative: Vec, [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, [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, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 244 | pub middle: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 245 | pub last: Option, [INFO] [stdout] | ^^^^ [INFO] [stdout] 246 | pub full: Option, [INFO] [stdout] 247 | pub native: Option, [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, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 297 | pub thumbnail: Option, [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, [INFO] [stdout] | ^^^^ [INFO] [stdout] 311 | pub season: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 312 | pub all_time: Option, [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, [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, 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 { [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 { [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 { [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, 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 { [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, [INFO] [stdout] 16 | config: Arc, [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) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 76 | pub fn with_bearer_token(self, token: impl Into) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 81 | pub fn with_basic_auth(self, username: impl Into, password: impl Into) -> 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(&self, f: F) -> T [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 191 | pub async fn try_execute(&self, f: F) -> Result [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, 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) -> 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> = 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 { [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, 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, 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, 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 { [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 { [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) -> Result { [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( [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, 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, [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, [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, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 79 | pub average_score: Option, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 82 | pub is_locked: Option, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 95 | pub is_favourite: Option, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 96 | pub is_favourite_blocked: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 103 | pub rankings: Option>, [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, [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, [INFO] [stdout] 128 | pub site: Option, [INFO] [stdout] | ^^^^ [INFO] [stdout] 129 | pub thumbnail: Option, [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, [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, [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, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 175 | pub format: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 176 | pub cover_image: Option, [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, [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, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 205 | pub middle: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 206 | pub last: Option, [INFO] [stdout] | ^^^^ [INFO] [stdout] 207 | pub full: Option, [INFO] [stdout] 208 | pub native: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 209 | #[serde(default)] [INFO] [stdout] 210 | pub alternative: Vec, [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, [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, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 244 | pub middle: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 245 | pub last: Option, [INFO] [stdout] | ^^^^ [INFO] [stdout] 246 | pub full: Option, [INFO] [stdout] 247 | pub native: Option, [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, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 297 | pub thumbnail: Option, [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, [INFO] [stdout] | ^^^^ [INFO] [stdout] 311 | pub season: Option, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] 312 | pub all_time: Option, [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, [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, 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 { [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 { [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 { [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, 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 { [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, [INFO] [stdout] 16 | config: Arc, [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) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 76 | pub fn with_bearer_token(self, token: impl Into) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 81 | pub fn with_basic_auth(self, username: impl Into, password: impl Into) -> 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(&self, f: F) -> T [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 191 | pub async fn try_execute(&self, f: F) -> Result [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, 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) -> 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> = 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 { [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, 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, 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, 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 { [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 { [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) -> Result { [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( [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, 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, [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, [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, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 79 | pub average_score: Option, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 82 | pub is_locked: Option, [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 95 | pub is_favourite: Option, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] 96 | pub is_favourite_blocked: Option, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 103 | pub rankings: Option>, [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, [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, [INFO] [stderr] 128 | pub site: Option, [INFO] [stderr] | ^^^^ [INFO] [stderr] 129 | pub thumbnail: Option, [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, [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, [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, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 175 | pub format: Option, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] 176 | pub cover_image: Option, [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, [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, [INFO] [stderr] | ^^^^^ [INFO] [stderr] 205 | pub middle: Option, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] 206 | pub last: Option, [INFO] [stderr] | ^^^^ [INFO] [stderr] 207 | pub full: Option, [INFO] [stderr] 208 | pub native: Option, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] 209 | #[serde(default)] [INFO] [stderr] 210 | pub alternative: Vec, [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, [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, [INFO] [stderr] | ^^^^^ [INFO] [stderr] 244 | pub middle: Option, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] 245 | pub last: Option, [INFO] [stderr] | ^^^^ [INFO] [stderr] 246 | pub full: Option, [INFO] [stderr] 247 | pub native: Option, [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, [INFO] [stderr] | ^^^^^ [INFO] [stderr] 297 | pub thumbnail: Option, [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, [INFO] [stderr] | ^^^^ [INFO] [stderr] 311 | pub season: Option, [INFO] [stderr] | ^^^^^^ [INFO] [stderr] 312 | pub all_time: Option, [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, [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, 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 { [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 { [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 { [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, 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 { [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, [INFO] [stderr] 16 | config: Arc, [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) -> Self { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 76 | pub fn with_bearer_token(self, token: impl Into) -> Self { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 81 | pub fn with_basic_auth(self, username: impl Into, password: impl Into) -> 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(&self, f: F) -> T [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 191 | pub async fn try_execute(&self, f: F) -> Result [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, 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