[INFO] cloning repository https://github.com/QpxDesign/fang_rs
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/QpxDesign/fang_rs" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FQpxDesign%2Ffang_rs", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FQpxDesign%2Ffang_rs'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 7355805da5e6884afc086fd2770db8e244861b33
[INFO] testing QpxDesign/fang_rs against 1.94.0 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FQpxDesign%2Ffang_rs" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/QpxDesign/fang_rs
[INFO] finished tweaking git repo https://github.com/QpxDesign/fang_rs
[INFO] tweaked toml for git repo https://github.com/QpxDesign/fang_rs written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/QpxDesign/fang_rs on toolchain 1.94.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.94.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/QpxDesign/fang_rs 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" "+1.94.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded icu_properties v2.0.1
[INFO] [stderr]   Downloaded http-range-header v0.4.2
[INFO] [stderr]   Downloaded signal-hook-registry v1.4.6
[INFO] [stderr]   Downloaded mime_guess v2.0.5
[INFO] [stderr]   Downloaded parking v2.2.1
[INFO] [stderr]   Downloaded derive_builder_macro v0.20.2
[INFO] [stderr]   Downloaded crc v3.3.0
[INFO] [stderr]   Downloaded radium v0.3.0
[INFO] [stderr]   Downloaded shuffle v0.1.7
[INFO] [stderr]   Downloaded sqlx-macros v0.8.6
[INFO] [stderr]   Downloaded axum-cookie v0.2.3
[INFO] [stderr]   Downloaded password-hash v0.5.0
[INFO] [stderr]   Downloaded axum-template v3.0.0
[INFO] [stderr]   Downloaded argon2 v0.5.3
[INFO] [stderr]   Downloaded pest_derive v2.8.1
[INFO] [stderr]   Downloaded axum-extra v0.10.1
[INFO] [stderr]   Downloaded hyper-util v0.1.16
[INFO] [stderr]   Downloaded cc v1.2.32
[INFO] [stderr]   Downloaded pest v2.8.1
[INFO] [stderr]   Downloaded unicode-normalization v0.1.24
[INFO] [stderr]   Downloaded cookie-rs v0.4.1
[INFO] [stderr]   Downloaded sqlx v0.8.6
[INFO] [stderr]   Downloaded hyper v1.6.0
[INFO] [stderr]   Downloaded axum v0.8.4
[INFO] [stderr]   Downloaded serde_json v1.0.142
[INFO] [stderr]   Downloaded icu_properties_data v2.0.1
[INFO] [stderr]   Downloaded sqlx-postgres v0.8.6
[INFO] [stderr]   Downloaded zerovec v0.11.4
[INFO] [stderr]   Downloaded sqlx-core v0.8.6
[INFO] [stderr]   Downloaded http v1.3.1
[INFO] [stderr]   Downloaded handlebars v6.3.2
[INFO] [stderr]   Downloaded bitvec v0.17.4
[INFO] [stderr]   Downloaded flume v0.11.1
[INFO] [stderr]   Downloaded rsa v0.9.8
[INFO] [stderr]   Downloaded icu_normalizer_data v2.0.0
[INFO] [stderr]   Downloaded icu_collections v2.0.0
[INFO] [stderr]   Downloaded icu_locale_core v2.0.0
[INFO] [stderr]   Downloaded zerotrie v0.2.2
[INFO] [stderr]   Downloaded sqlx-mysql v0.8.6
[INFO] [stderr]   Downloaded tinyvec v1.9.0
[INFO] [stderr]   Downloaded icu_provider v2.0.0
[INFO] [stderr]   Downloaded sqlx-sqlite v0.8.6
[INFO] [stderr]   Downloaded tokio-util v0.7.16
[INFO] [stderr]   Downloaded unicode-bidi v0.3.18
[INFO] [stderr]   Downloaded unicode-properties v0.1.3
[INFO] [stderr]   Downloaded stringprep v0.1.5
[INFO] [stderr]   Downloaded event-listener v5.4.1
[INFO] [stderr]   Downloaded hashlink v0.10.0
[INFO] [stderr]   Downloaded icu_normalizer v2.0.0
[INFO] [stderr]   Downloaded litemap v0.8.0
[INFO] [stderr]   Downloaded axum-core v0.5.2
[INFO] [stderr]   Downloaded matchit v0.8.4
[INFO] [stderr]   Downloaded derive_builder_core v0.20.2
[INFO] [stderr]   Downloaded derive_builder v0.20.2
[INFO] [stderr]   Downloaded num-modular v0.6.1
[INFO] [stderr]   Downloaded num-order v1.2.0
[INFO] [stderr]   Downloaded pest_meta v2.8.1
[INFO] [stderr]   Downloaded pest_generator v2.8.1
[INFO] [stderr]   Downloaded zerovec-derive v0.11.1
[INFO] [stderr]   Downloaded sqlx-macros-core v0.8.6
[INFO] [stderr]   Downloaded tokio v1.47.1
[INFO] [stderr]   Downloaded whoami v1.6.0
[INFO] [stderr]   Downloaded concurrent-queue v2.5.0
[INFO] [stderr]   Downloaded tinystr v0.8.1
[INFO] [stderr]   Downloaded writeable v0.6.1
[INFO] [stderr]   Downloaded yoke v0.8.0
[INFO] [stderr]   Downloaded serde_path_to_error v0.1.17
[INFO] [stderr]   Downloaded wasite v0.1.0
[INFO] [stderr]   Downloaded potential_utf v0.1.2
[INFO] [stderr]   Downloaded yoke-derive v0.8.0
[INFO] [stderr]   Downloaded libsqlite3-sys v0.30.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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" "+1.94.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 33bfc0932d78d48c003e8c62bdcb20bc86427c02ea0be855a5ec0e644b47982e
[INFO] running `Command { std: "docker" "start" "-a" "33bfc0932d78d48c003e8c62bdcb20bc86427c02ea0be855a5ec0e644b47982e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "33bfc0932d78d48c003e8c62bdcb20bc86427c02ea0be855a5ec0e644b47982e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "33bfc0932d78d48c003e8c62bdcb20bc86427c02ea0be855a5ec0e644b47982e", kill_on_drop: false }`
[INFO] [stdout] 33bfc0932d78d48c003e8c62bdcb20bc86427c02ea0be855a5ec0e644b47982e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+1.94.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 3aa355d3f5fb79c1493107e435170b8c955839db772503771d18335d10135a22
[INFO] running `Command { std: "docker" "start" "-a" "3aa355d3f5fb79c1493107e435170b8c955839db772503771d18335d10135a22", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.95
[INFO] [stderr]    Compiling unicode-ident v1.0.18
[INFO] [stderr]    Compiling libc v0.2.174
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling cfg-if v1.0.1
[INFO] [stderr]    Compiling futures-core v0.3.31
[INFO] [stderr]    Compiling typenum v1.18.0
[INFO] [stderr]    Compiling memchr v2.7.5
[INFO] [stderr]    Compiling version_check v0.9.5
[INFO] [stderr]    Compiling bytes v1.10.1
[INFO] [stderr]    Compiling stable_deref_trait v1.2.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling lock_api v0.4.13
[INFO] [stderr]    Compiling itoa v1.0.15
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling subtle v2.4.1
[INFO] [stderr]    Compiling litemap v0.8.0
[INFO] [stderr]    Compiling writeable v0.6.1
[INFO] [stderr]    Compiling icu_normalizer_data v2.0.0
[INFO] [stderr]    Compiling futures-task v0.3.31
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling slab v0.4.10
[INFO] [stderr]    Compiling icu_properties_data v2.0.1
[INFO] [stderr]    Compiling log v0.4.27
[INFO] [stderr]    Compiling syn v2.0.104
[INFO] [stderr]    Compiling futures-io v0.3.31
[INFO] [stderr]    Compiling percent-encoding v2.3.1
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]    Compiling thiserror v2.0.12
[INFO] [stderr]    Compiling zerocopy v0.8.26
[INFO] [stderr]    Compiling ryu v1.0.20
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling socket2 v0.6.0
[INFO] [stderr]    Compiling signal-hook-registry v1.4.6
[INFO] [stderr]    Compiling serde_json v1.0.142
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling http v1.3.1
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]    Compiling cpufeatures v0.2.17
[INFO] [stderr]    Compiling allocator-api2 v0.2.21
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling form_urlencoded v1.2.1
[INFO] [stderr]    Compiling parking v2.2.1
[INFO] [stderr]    Compiling hashbrown v0.15.4
[INFO] [stderr]    Compiling crc-catalog v2.4.0
[INFO] [stderr]    Compiling tinyvec_macros v0.1.1
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]    Compiling tinyvec v1.9.0
[INFO] [stderr]    Compiling crc v3.3.0
[INFO] [stderr]    Compiling crossbeam-queue v0.3.12
[INFO] [stderr]    Compiling event-listener v5.4.1
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling strsim v0.11.1
[INFO] [stderr]    Compiling hashlink v0.10.0
[INFO] [stderr]    Compiling indexmap v2.10.0
[INFO] [stderr]    Compiling ident_case v1.0.1
[INFO] [stderr]    Compiling mime v0.3.17
[INFO] [stderr]    Compiling base64 v0.22.1
[INFO] [stderr]    Compiling rustversion v1.0.21
[INFO] [stderr]    Compiling unicode-normalization v0.1.24
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling unicode-properties v0.1.3
[INFO] [stderr]    Compiling httpdate v1.0.3
[INFO] [stderr]    Compiling bitflags v2.9.1
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling unicode-bidi v0.3.18
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling atoi v2.0.0
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling hmac v0.12.1
[INFO] [stderr]    Compiling ucd-trie v0.1.7
[INFO] [stderr]    Compiling stringprep v0.1.5
[INFO] [stderr]    Compiling dotenvy v0.15.7
[INFO] [stderr]    Compiling whoami v1.6.0
[INFO] [stderr]    Compiling hex v0.4.3
[INFO] [stderr]    Compiling home v0.5.11
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling hkdf v0.12.4
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling md-5 v0.10.6
[INFO] [stderr]    Compiling unicase v2.8.1
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling matchit v0.8.4
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling num-modular v0.6.1
[INFO] [stderr]    Compiling radium v0.3.0
[INFO] [stderr]    Compiling regex-syntax v0.8.5
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling base64ct v1.8.0
[INFO] [stderr]    Compiling num-order v1.2.0
[INFO] [stderr]    Compiling password-hash v0.5.0
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling blake2 v0.10.6
[INFO] [stderr]    Compiling cookie-rs v0.4.1
[INFO] [stderr]    Compiling iana-time-zone v0.1.63
[INFO] [stderr]    Compiling http-range-header v0.4.2
[INFO] [stderr]    Compiling chrono v0.4.41
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling thiserror-impl v2.0.12
[INFO] [stderr]    Compiling yoke v0.8.0
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling zerotrie v0.2.2
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling zerovec v0.11.4
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling tokio-stream v0.1.17
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling derive_builder_core v0.20.2
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling pest v2.8.1
[INFO] [stderr]    Compiling axum-core v0.5.2
[INFO] [stderr]    Compiling argon2 v0.5.3
[INFO] [stderr]    Compiling tinystr v0.8.1
[INFO] [stderr]    Compiling icu_locale_core v2.0.0
[INFO] [stderr]    Compiling potential_utf v0.1.2
[INFO] [stderr]    Compiling derive_builder_macro v0.20.2
[INFO] [stderr]    Compiling icu_collections v2.0.0
[INFO] [stderr]    Compiling derive_builder v0.20.2
[INFO] [stderr]    Compiling rand v0.9.2
[INFO] [stderr]    Compiling pest_meta v2.8.1
[INFO] [stderr]    Compiling icu_provider v2.0.0
[INFO] [stderr]    Compiling uuid v1.17.0
[INFO] [stderr]    Compiling axum-cookie v0.2.3
[INFO] [stderr]    Compiling icu_properties v2.0.1
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling pest_generator v2.8.1
[INFO] [stderr]    Compiling pest_derive v2.8.1
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling serde_path_to_error v0.1.17
[INFO] [stderr]    Compiling icu_normalizer v2.0.0
[INFO] [stderr]    Compiling bitvec v0.17.4
[INFO] [stderr]    Compiling parking_lot v0.12.4
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling futures-intrusive v0.5.0
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling shuffle v0.1.7
[INFO] [stderr]    Compiling handlebars v6.3.2
[INFO] [stderr]    Compiling sqlx-core v0.8.6
[INFO] [stderr]    Compiling sqlx-postgres v0.8.6
[INFO] [stderr]    Compiling hyper v1.6.0
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling tokio-util v0.7.16
[INFO] [stderr]    Compiling tower-http v0.5.2
[INFO] [stderr]    Compiling hyper-util v0.1.16
[INFO] [stderr]    Compiling axum v0.8.4
[INFO] [stderr]    Compiling sqlx-macros-core v0.8.6
[INFO] [stderr]    Compiling sqlx-macros v0.8.6
[INFO] [stderr]    Compiling axum-template v3.0.0
[INFO] [stderr]    Compiling axum-extra v0.10.1
[INFO] [stderr]    Compiling sqlx v0.8.6
[INFO] [stderr]    Compiling fang_rs v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `Router` and `routing::get`
[INFO] [stdout]  --> src/./routes/business_plans.rs:4:43
[INFO] [stdout]   |
[INFO] [stdout] 4 | use axum::{extract::Form, response::Html, routing::get, Router};
[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 imports: `Router` and `routing::get`
[INFO] [stdout]  --> src/./routes/edit_headlines.rs:4:43
[INFO] [stdout]   |
[INFO] [stdout] 4 | use axum::{extract::Form, response::Html, routing::get, Router};
[INFO] [stdout]   |                                           ^^^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::seq::SliceRandom`
[INFO] [stdout]  --> src/./routes/../utils/get_articles.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use rand::seq::SliceRandom;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::thread_rng`
[INFO] [stdout]  --> src/./routes/../utils/get_articles.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use rand::thread_rng;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `shuffle::shuffler::Shuffler`
[INFO] [stdout]  --> src/./routes/../utils/get_articles.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use shuffle::shuffler::Shuffler;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 36 |         if (o.time_created_unix > 0) {
[INFO] [stdout]    |            ^                       ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 36 -         if (o.time_created_unix > 0) {
[INFO] [stdout] 36 +         if o.time_created_unix > 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::structs::article::Article`
[INFO] [stdout]  --> src/./routes/../utils/get_authors.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::structs::article::Article;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Router` and `routing::get`
[INFO] [stdout]  --> src/./routes/submit_page_edit.rs:4:43
[INFO] [stdout]   |
[INFO] [stdout] 4 | use axum::{extract::Form, response::Html, routing::get, Router};
[INFO] [stdout]   |                                           ^^^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::seq::SliceRandom`
[INFO] [stdout]  --> src/./utils/get_articles.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use rand::seq::SliceRandom;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::thread_rng`
[INFO] [stdout]  --> src/./utils/get_articles.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use rand::thread_rng;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `shuffle::shuffler::Shuffler`
[INFO] [stdout]  --> src/./utils/get_articles.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use shuffle::shuffler::Shuffler;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/./utils/get_articles.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 36 |         if (o.time_created_unix > 0) {
[INFO] [stdout]    |            ^                       ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 36 -         if (o.time_created_unix > 0) {
[INFO] [stdout] 36 +         if o.time_created_unix > 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::structs::article::Article`
[INFO] [stdout]  --> src/./utils/get_authors.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::structs::article::Article;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `rand::thread_rng`: Renamed to `rng`
[INFO] [stdout]  --> src/./routes/../utils/get_articles.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | use rand::thread_rng;
[INFO] [stdout]   |           ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `rand::thread_rng`: Renamed to `rng`
[INFO] [stdout]  --> src/./utils/get_articles.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | use rand::thread_rng;
[INFO] [stdout]   |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/article.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 45 |     let mut a = get_articles(State(&pool))
[INFO] [stdout]    |         ----^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/auth.rs:30:9
[INFO] [stdout]    |
[INFO] [stdout] 30 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/auth.rs:62:13
[INFO] [stdout]    |
[INFO] [stdout] 62 |         let mut q = sqlx::query(
[INFO] [stdout]    |             ----^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/./routes/auth.rs:132:9
[INFO] [stdout]     |
[INFO] [stdout] 132 |     let mut q = sqlx::query(
[INFO] [stdout]     |         ----^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/business_plans.rs:32:9
[INFO] [stdout]    |
[INFO] [stdout] 32 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/business_plans.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 35 |     let mut page_values: EditBusinessPlansPageValues = EditBusinessPlansPageValues {
[INFO] [stdout]    |         ----^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/business_plans.rs:98:9
[INFO] [stdout]    |
[INFO] [stdout] 98 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `routes::article::chrono::NaiveDateTime::from_timestamp`: use `DateTime::from_timestamp` instead
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:37:36
[INFO] [stdout]    |
[INFO] [stdout] 37 |             let n = NaiveDateTime::from_timestamp(o.time_created_unix, 0);
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `routes::article::chrono::DateTime::<Tz>::from_utc`: Use TimeZone::from_utc_datetime() or DateTime::from_naive_utc_and_offset instead
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:38:46
[INFO] [stdout]    |
[INFO] [stdout] 38 |             let d: DateTime<Utc> = DateTime::from_utc(n, Utc);
[INFO] [stdout]    |                                              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stdout]    |         ----^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/edit_headlines.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/edit_profile.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/home.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/members.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 22 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/members.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 47 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/page_editor.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/page_editor.rs:52:9
[INFO] [stdout]    |
[INFO] [stdout] 52 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/page_editor.rs:60:9
[INFO] [stdout]    |
[INFO] [stdout] 60 |     let mut a = get_articles(State(&pool))
[INFO] [stdout]    |         ----^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `routes::article::chrono::NaiveDateTime::from_timestamp`: use `DateTime::from_timestamp` instead
[INFO] [stdout]   --> src/./utils/get_articles.rs:37:36
[INFO] [stdout]    |
[INFO] [stdout] 37 |             let n = NaiveDateTime::from_timestamp(o.time_created_unix, 0);
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `routes::article::chrono::DateTime::<Tz>::from_utc`: Use TimeZone::from_utc_datetime() or DateTime::from_naive_utc_and_offset instead
[INFO] [stdout]   --> src/./utils/get_articles.rs:38:46
[INFO] [stdout]    |
[INFO] [stdout] 38 |             let d: DateTime<Utc> = DateTime::from_utc(n, Utc);
[INFO] [stdout]    |                                              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./utils/get_articles.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stdout]    |         ----^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::prelude`
[INFO] [stdout]  --> src/./routes/../utils/get_authors.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::prelude`
[INFO] [stdout]  --> src/./utils/get_authors.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `zines`
[INFO] [stdout]   --> src/./utils/get_articles.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_zines`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pool`
[INFO] [stdout]   --> src/./routes/auth.rs:28:11
[INFO] [stdout]    |
[INFO] [stdout] 28 |     State(pool): State<Pool<Postgres>>,
[INFO] [stdout]    |           ^^^^ help: if this is intentional, prefix it with an underscore: `_pool`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `zines`
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_zines`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `editable` is never used
[INFO] [stdout]  --> src/./routes/../utils/authors_to_string.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub fn editable(authors: Vec<String>) -> String {
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fancy_html` is never used
[INFO] [stdout]   --> src/./routes/../utils/authors_to_string.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub fn fancy_html(authors: String) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_articles` is never used
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:13:14
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub async fn get_articles(State(pool): State<&Pool<Postgres>>) -> Vec<Article> {
[INFO] [stdout]    |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_url_text` is never used
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:50:4
[INFO] [stdout]    |
[INFO] [stdout] 50 | fn format_url_text(t: String) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_authors` is never used
[INFO] [stdout]   --> src/./routes/../utils/get_authors.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub async fn get_authors(State(pool): State<&Pool<Postgres>>) -> Vec<Author> {
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `editable` is never used
[INFO] [stdout]  --> src/./utils/authors_to_string.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub fn editable(authors: Vec<String>) -> String {
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/main.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 |     dotenvy::dotenv();
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 17 |     let _ = dotenvy::dotenv();
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `canUserEdit` should have a snake case name
[INFO] [stdout]   --> src/./routes/home.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     canUserEdit: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: convert the identifier to snake case: `can_user_edit`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Author` should have a snake case name
[INFO] [stdout]  --> src/./structs/mod.rs:1:9
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod Author;
[INFO] [stdout]   |         ^^^^^^ help: convert the identifier to snake case: `author`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `PageEditInput` should have a snake case name
[INFO] [stdout]  --> src/./structs/mod.rs:2:9
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod PageEditInput;
[INFO] [stdout]   |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `page_edit_input`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 58s
[INFO] running `Command { std: "docker" "inspect" "3aa355d3f5fb79c1493107e435170b8c955839db772503771d18335d10135a22", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3aa355d3f5fb79c1493107e435170b8c955839db772503771d18335d10135a22", kill_on_drop: false }`
[INFO] [stdout] 3aa355d3f5fb79c1493107e435170b8c955839db772503771d18335d10135a22
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+1.94.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f312fc43ee2463f7cedeaa4194c3259bb14c86a1cb75a3a9444f5a97b0b3f416
[INFO] running `Command { std: "docker" "start" "-a" "f312fc43ee2463f7cedeaa4194c3259bb14c86a1cb75a3a9444f5a97b0b3f416", kill_on_drop: false }`
[INFO] [stderr]    Compiling fang_rs v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `Router` and `routing::get`
[INFO] [stdout]  --> src/./routes/business_plans.rs:4:43
[INFO] [stdout]   |
[INFO] [stdout] 4 | use axum::{extract::Form, response::Html, routing::get, Router};
[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 imports: `Router` and `routing::get`
[INFO] [stdout]  --> src/./routes/edit_headlines.rs:4:43
[INFO] [stdout]   |
[INFO] [stdout] 4 | use axum::{extract::Form, response::Html, routing::get, Router};
[INFO] [stdout]   |                                           ^^^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::seq::SliceRandom`
[INFO] [stdout]  --> src/./routes/../utils/get_articles.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use rand::seq::SliceRandom;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::thread_rng`
[INFO] [stdout]  --> src/./routes/../utils/get_articles.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use rand::thread_rng;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `shuffle::shuffler::Shuffler`
[INFO] [stdout]  --> src/./routes/../utils/get_articles.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use shuffle::shuffler::Shuffler;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 36 |         if (o.time_created_unix > 0) {
[INFO] [stdout]    |            ^                       ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 36 -         if (o.time_created_unix > 0) {
[INFO] [stdout] 36 +         if o.time_created_unix > 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::structs::article::Article`
[INFO] [stdout]  --> src/./routes/../utils/get_authors.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::structs::article::Article;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Router` and `routing::get`
[INFO] [stdout]  --> src/./routes/submit_page_edit.rs:4:43
[INFO] [stdout]   |
[INFO] [stdout] 4 | use axum::{extract::Form, response::Html, routing::get, Router};
[INFO] [stdout]   |                                           ^^^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::seq::SliceRandom`
[INFO] [stdout]  --> src/./utils/get_articles.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use rand::seq::SliceRandom;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::thread_rng`
[INFO] [stdout]  --> src/./utils/get_articles.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use rand::thread_rng;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `shuffle::shuffler::Shuffler`
[INFO] [stdout]  --> src/./utils/get_articles.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use shuffle::shuffler::Shuffler;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/./utils/get_articles.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 36 |         if (o.time_created_unix > 0) {
[INFO] [stdout]    |            ^                       ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 36 -         if (o.time_created_unix > 0) {
[INFO] [stdout] 36 +         if o.time_created_unix > 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::structs::article::Article`
[INFO] [stdout]  --> src/./utils/get_authors.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::structs::article::Article;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `rand::thread_rng`: Renamed to `rng`
[INFO] [stdout]  --> src/./routes/../utils/get_articles.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | use rand::thread_rng;
[INFO] [stdout]   |           ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `rand::thread_rng`: Renamed to `rng`
[INFO] [stdout]  --> src/./utils/get_articles.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | use rand::thread_rng;
[INFO] [stdout]   |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/article.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 45 |     let mut a = get_articles(State(&pool))
[INFO] [stdout]    |         ----^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/auth.rs:30:9
[INFO] [stdout]    |
[INFO] [stdout] 30 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/auth.rs:62:13
[INFO] [stdout]    |
[INFO] [stdout] 62 |         let mut q = sqlx::query(
[INFO] [stdout]    |             ----^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/./routes/auth.rs:132:9
[INFO] [stdout]     |
[INFO] [stdout] 132 |     let mut q = sqlx::query(
[INFO] [stdout]     |         ----^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/business_plans.rs:32:9
[INFO] [stdout]    |
[INFO] [stdout] 32 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/business_plans.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 35 |     let mut page_values: EditBusinessPlansPageValues = EditBusinessPlansPageValues {
[INFO] [stdout]    |         ----^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/business_plans.rs:98:9
[INFO] [stdout]    |
[INFO] [stdout] 98 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `routes::article::chrono::NaiveDateTime::from_timestamp`: use `DateTime::from_timestamp` instead
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:37:36
[INFO] [stdout]    |
[INFO] [stdout] 37 |             let n = NaiveDateTime::from_timestamp(o.time_created_unix, 0);
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `routes::article::chrono::DateTime::<Tz>::from_utc`: Use TimeZone::from_utc_datetime() or DateTime::from_naive_utc_and_offset instead
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:38:46
[INFO] [stdout]    |
[INFO] [stdout] 38 |             let d: DateTime<Utc> = DateTime::from_utc(n, Utc);
[INFO] [stdout]    |                                              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stdout]    |         ----^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/edit_headlines.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/edit_profile.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/home.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/members.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 22 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/members.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 47 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/page_editor.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/page_editor.rs:52:9
[INFO] [stdout]    |
[INFO] [stdout] 52 |     let mut reg = Handlebars::new();
[INFO] [stdout]    |         ----^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./routes/page_editor.rs:60:9
[INFO] [stdout]    |
[INFO] [stdout] 60 |     let mut a = get_articles(State(&pool))
[INFO] [stdout]    |         ----^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `routes::article::chrono::NaiveDateTime::from_timestamp`: use `DateTime::from_timestamp` instead
[INFO] [stdout]   --> src/./utils/get_articles.rs:37:36
[INFO] [stdout]    |
[INFO] [stdout] 37 |             let n = NaiveDateTime::from_timestamp(o.time_created_unix, 0);
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `routes::article::chrono::DateTime::<Tz>::from_utc`: Use TimeZone::from_utc_datetime() or DateTime::from_naive_utc_and_offset instead
[INFO] [stdout]   --> src/./utils/get_articles.rs:38:46
[INFO] [stdout]    |
[INFO] [stdout] 38 |             let d: DateTime<Utc> = DateTime::from_utc(n, Utc);
[INFO] [stdout]    |                                              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/./utils/get_articles.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stdout]    |         ----^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::prelude`
[INFO] [stdout]  --> src/./routes/../utils/get_authors.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::prelude`
[INFO] [stdout]  --> src/./utils/get_authors.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use chrono::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `zines`
[INFO] [stdout]   --> src/./utils/get_articles.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_zines`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pool`
[INFO] [stdout]   --> src/./routes/auth.rs:28:11
[INFO] [stdout]    |
[INFO] [stdout] 28 |     State(pool): State<Pool<Postgres>>,
[INFO] [stdout]    |           ^^^^ help: if this is intentional, prefix it with an underscore: `_pool`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `zines`
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_zines`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `editable` is never used
[INFO] [stdout]  --> src/./routes/../utils/authors_to_string.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub fn editable(authors: Vec<String>) -> String {
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fancy_html` is never used
[INFO] [stdout]   --> src/./routes/../utils/authors_to_string.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub fn fancy_html(authors: String) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_articles` is never used
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:13:14
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub async fn get_articles(State(pool): State<&Pool<Postgres>>) -> Vec<Article> {
[INFO] [stdout]    |              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_url_text` is never used
[INFO] [stdout]   --> src/./routes/../utils/get_articles.rs:50:4
[INFO] [stdout]    |
[INFO] [stdout] 50 | fn format_url_text(t: String) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_authors` is never used
[INFO] [stdout]   --> src/./routes/../utils/get_authors.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub async fn get_authors(State(pool): State<&Pool<Postgres>>) -> Vec<Author> {
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `editable` is never used
[INFO] [stdout]  --> src/./utils/authors_to_string.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub fn editable(authors: Vec<String>) -> String {
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/main.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 |     dotenvy::dotenv();
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 17 |     let _ = dotenvy::dotenv();
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `canUserEdit` should have a snake case name
[INFO] [stdout]   --> src/./routes/home.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     canUserEdit: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: convert the identifier to snake case: `can_user_edit`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Author` should have a snake case name
[INFO] [stdout]  --> src/./structs/mod.rs:1:9
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub mod Author;
[INFO] [stdout]   |         ^^^^^^ help: convert the identifier to snake case: `author`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `PageEditInput` should have a snake case name
[INFO] [stdout]  --> src/./structs/mod.rs:2:9
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub mod PageEditInput;
[INFO] [stdout]   |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `page_edit_input`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 3.71s
[INFO] running `Command { std: "docker" "inspect" "f312fc43ee2463f7cedeaa4194c3259bb14c86a1cb75a3a9444f5a97b0b3f416", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f312fc43ee2463f7cedeaa4194c3259bb14c86a1cb75a3a9444f5a97b0b3f416", kill_on_drop: false }`
[INFO] [stdout] f312fc43ee2463f7cedeaa4194c3259bb14c86a1cb75a3a9444f5a97b0b3f416
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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" "+1.94.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 15b00f34cba6b973d3974565b70e53785e42b8199e618488b8d8caefb51bb47d
[INFO] running `Command { std: "docker" "start" "-a" "15b00f34cba6b973d3974565b70e53785e42b8199e618488b8d8caefb51bb47d", kill_on_drop: false }`
[INFO] [stderr] warning: unused imports: `Router` and `routing::get`
[INFO] [stderr]  --> src/./routes/business_plans.rs:4:43
[INFO] [stderr]   |
[INFO] [stderr] 4 | use axum::{extract::Form, response::Html, routing::get, Router};
[INFO] [stderr]   |                                           ^^^^^^^^^^^^  ^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Router` and `routing::get`
[INFO] [stderr]  --> src/./routes/edit_headlines.rs:4:43
[INFO] [stderr]   |
[INFO] [stderr] 4 | use axum::{extract::Form, response::Html, routing::get, Router};
[INFO] [stderr]   |                                           ^^^^^^^^^^^^  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::seq::SliceRandom`
[INFO] [stderr]  --> src/./routes/../utils/get_articles.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use rand::seq::SliceRandom;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::thread_rng`
[INFO] [stderr]  --> src/./routes/../utils/get_articles.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use rand::thread_rng;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `shuffle::shuffler::Shuffler`
[INFO] [stderr]  --> src/./routes/../utils/get_articles.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use shuffle::shuffler::Shuffler;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/./routes/../utils/get_articles.rs:36:12
[INFO] [stderr]    |
[INFO] [stderr] 36 |         if (o.time_created_unix > 0) {
[INFO] [stderr]    |            ^                       ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 36 -         if (o.time_created_unix > 0) {
[INFO] [stderr] 36 +         if o.time_created_unix > 0  {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::structs::article::Article`
[INFO] [stderr]  --> src/./routes/../utils/get_authors.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use crate::structs::article::Article;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Router` and `routing::get`
[INFO] [stderr]  --> src/./routes/submit_page_edit.rs:4:43
[INFO] [stderr]   |
[INFO] [stderr] 4 | use axum::{extract::Form, response::Html, routing::get, Router};
[INFO] [stderr]   |                                           ^^^^^^^^^^^^  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::seq::SliceRandom`
[INFO] [stderr]  --> src/./utils/get_articles.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use rand::seq::SliceRandom;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::thread_rng`
[INFO] [stderr]  --> src/./utils/get_articles.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use rand::thread_rng;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `shuffle::shuffler::Shuffler`
[INFO] [stderr]  --> src/./utils/get_articles.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use shuffle::shuffler::Shuffler;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/./utils/get_articles.rs:36:12
[INFO] [stderr]    |
[INFO] [stderr] 36 |         if (o.time_created_unix > 0) {
[INFO] [stderr]    |            ^                       ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 36 -         if (o.time_created_unix > 0) {
[INFO] [stderr] 36 +         if o.time_created_unix > 0  {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::structs::article::Article`
[INFO] [stderr]  --> src/./utils/get_authors.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use crate::structs::article::Article;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `rand::thread_rng`: Renamed to `rng`
[INFO] [stderr]  --> src/./routes/../utils/get_articles.rs:7:11
[INFO] [stderr]   |
[INFO] [stderr] 7 | use rand::thread_rng;
[INFO] [stderr]   |           ^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `rand::thread_rng`: Renamed to `rng`
[INFO] [stderr]  --> src/./utils/get_articles.rs:7:11
[INFO] [stderr]   |
[INFO] [stderr] 7 | use rand::thread_rng;
[INFO] [stderr]   |           ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/article.rs:45:9
[INFO] [stderr]    |
[INFO] [stderr] 45 |     let mut a = get_articles(State(&pool))
[INFO] [stderr]    |         ----^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/auth.rs:30:9
[INFO] [stderr]    |
[INFO] [stderr] 30 |     let mut reg = Handlebars::new();
[INFO] [stderr]    |         ----^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/auth.rs:62:13
[INFO] [stderr]    |
[INFO] [stderr] 62 |         let mut q = sqlx::query(
[INFO] [stderr]    |             ----^
[INFO] [stderr]    |             |
[INFO] [stderr]    |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/./routes/auth.rs:132:9
[INFO] [stderr]     |
[INFO] [stderr] 132 |     let mut q = sqlx::query(
[INFO] [stderr]     |         ----^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/business_plans.rs:32:9
[INFO] [stderr]    |
[INFO] [stderr] 32 |     let mut reg = Handlebars::new();
[INFO] [stderr]    |         ----^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/business_plans.rs:35:9
[INFO] [stderr]    |
[INFO] [stderr] 35 |     let mut page_values: EditBusinessPlansPageValues = EditBusinessPlansPageValues {
[INFO] [stderr]    |         ----^^^^^^^^^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/business_plans.rs:98:9
[INFO] [stderr]    |
[INFO] [stderr] 98 |     let mut reg = Handlebars::new();
[INFO] [stderr]    |         ----^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated associated function `routes::article::chrono::NaiveDateTime::from_timestamp`: use `DateTime::from_timestamp` instead
[INFO] [stderr]   --> src/./routes/../utils/get_articles.rs:37:36
[INFO] [stderr]    |
[INFO] [stderr] 37 |             let n = NaiveDateTime::from_timestamp(o.time_created_unix, 0);
[INFO] [stderr]    |                                    ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated associated function `routes::article::chrono::DateTime::<Tz>::from_utc`: Use TimeZone::from_utc_datetime() or DateTime::from_naive_utc_and_offset instead
[INFO] [stderr]   --> src/./routes/../utils/get_articles.rs:38:46
[INFO] [stderr]    |
[INFO] [stderr] 38 |             let d: DateTime<Utc> = DateTime::from_utc(n, Utc);
[INFO] [stderr]    |                                              ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/../utils/get_articles.rs:16:9
[INFO] [stderr]    |
[INFO] [stderr] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stderr]    |         ----^^^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/edit_headlines.rs:31:9
[INFO] [stderr]    |
[INFO] [stderr] 31 |     let mut reg = Handlebars::new();
[INFO] [stderr]    |         ----^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/edit_profile.rs:26:9
[INFO] [stderr]    |
[INFO] [stderr] 26 |     let mut reg = Handlebars::new();
[INFO] [stderr]    |         ----^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/home.rs:31:9
[INFO] [stderr]    |
[INFO] [stderr] 31 |     let mut reg = Handlebars::new();
[INFO] [stderr]    |         ----^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/members.rs:22:9
[INFO] [stderr]    |
[INFO] [stderr] 22 |     let mut reg = Handlebars::new();
[INFO] [stderr]    |         ----^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/members.rs:47:9
[INFO] [stderr]    |
[INFO] [stderr] 47 |     let mut reg = Handlebars::new();
[INFO] [stderr]    |         ----^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/page_editor.rs:20:9
[INFO] [stderr]    |
[INFO] [stderr] 20 |     let mut reg = Handlebars::new();
[INFO] [stderr]    |         ----^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/page_editor.rs:52:9
[INFO] [stderr]    |
[INFO] [stderr] 52 |     let mut reg = Handlebars::new();
[INFO] [stderr]    |         ----^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./routes/page_editor.rs:60:9
[INFO] [stderr]    |
[INFO] [stderr] 60 |     let mut a = get_articles(State(&pool))
[INFO] [stderr]    |         ----^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated associated function `routes::article::chrono::NaiveDateTime::from_timestamp`: use `DateTime::from_timestamp` instead
[INFO] [stderr]   --> src/./utils/get_articles.rs:37:36
[INFO] [stderr]    |
[INFO] [stderr] 37 |             let n = NaiveDateTime::from_timestamp(o.time_created_unix, 0);
[INFO] [stderr]    |                                    ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated associated function `routes::article::chrono::DateTime::<Tz>::from_utc`: Use TimeZone::from_utc_datetime() or DateTime::from_naive_utc_and_offset instead
[INFO] [stderr]   --> src/./utils/get_articles.rs:38:46
[INFO] [stderr]    |
[INFO] [stderr] 38 |             let d: DateTime<Utc> = DateTime::from_utc(n, Utc);
[INFO] [stderr]    |                                              ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/./utils/get_articles.rs:16:9
[INFO] [stderr]    |
[INFO] [stderr] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stderr]    |         ----^^^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `chrono::prelude`
[INFO] [stderr]  --> src/./routes/../utils/get_authors.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use chrono::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `chrono::prelude`
[INFO] [stderr]  --> src/./utils/get_authors.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use chrono::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `zines`
[INFO] [stderr]   --> src/./utils/get_articles.rs:16:9
[INFO] [stderr]    |
[INFO] [stderr] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stderr]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_zines`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `pool`
[INFO] [stderr]   --> src/./routes/auth.rs:28:11
[INFO] [stderr]    |
[INFO] [stderr] 28 |     State(pool): State<Pool<Postgres>>,
[INFO] [stderr]    |           ^^^^ help: if this is intentional, prefix it with an underscore: `_pool`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `zines`
[INFO] [stderr]   --> src/./routes/../utils/get_articles.rs:16:9
[INFO] [stderr]    |
[INFO] [stderr] 16 |     let mut zines: Vec<Article> = Vec::new();
[INFO] [stderr]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_zines`
[INFO] [stderr] 
[INFO] [stderr] warning: function `editable` is never used
[INFO] [stderr]  --> src/./routes/../utils/authors_to_string.rs:1:8
[INFO] [stderr]   |
[INFO] [stderr] 1 | pub fn editable(authors: Vec<String>) -> String {
[INFO] [stderr]   |        ^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `fancy_html` is never used
[INFO] [stderr]   --> src/./routes/../utils/authors_to_string.rs:10:8
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub fn fancy_html(authors: String) -> String {
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_articles` is never used
[INFO] [stderr]   --> src/./routes/../utils/get_articles.rs:13:14
[INFO] [stderr]    |
[INFO] [stderr] 13 | pub async fn get_articles(State(pool): State<&Pool<Postgres>>) -> Vec<Article> {
[INFO] [stderr]    |              ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `format_url_text` is never used
[INFO] [stderr]   --> src/./routes/../utils/get_articles.rs:50:4
[INFO] [stderr]    |
[INFO] [stderr] 50 | fn format_url_text(t: String) -> String {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_authors` is never used
[INFO] [stderr]   --> src/./routes/../utils/get_authors.rs:10:14
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub async fn get_authors(State(pool): State<&Pool<Postgres>>) -> Vec<Author> {
[INFO] [stderr]    |              ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `editable` is never used
[INFO] [stderr]  --> src/./utils/authors_to_string.rs:1:8
[INFO] [stderr]   |
[INFO] [stderr] 1 | pub fn editable(authors: Vec<String>) -> String {
[INFO] [stderr]   |        ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]   --> src/main.rs:17:5
[INFO] [stderr]    |
[INFO] [stderr] 17 |     dotenvy::dotenv();
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]    |
[INFO] [stderr] 17 |     let _ = dotenvy::dotenv();
[INFO] [stderr]    |     +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `canUserEdit` should have a snake case name
[INFO] [stderr]   --> src/./routes/home.rs:27:5
[INFO] [stderr]    |
[INFO] [stderr] 27 |     canUserEdit: bool,
[INFO] [stderr]    |     ^^^^^^^^^^^ help: convert the identifier to snake case: `can_user_edit`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: module `Author` should have a snake case name
[INFO] [stderr]  --> src/./structs/mod.rs:1:9
[INFO] [stderr]   |
[INFO] [stderr] 1 | pub mod Author;
[INFO] [stderr]   |         ^^^^^^ help: convert the identifier to snake case: `author`
[INFO] [stderr] 
[INFO] [stderr] warning: module `PageEditInput` should have a snake case name
[INFO] [stderr]  --> src/./structs/mod.rs:2:9
[INFO] [stderr]   |
[INFO] [stderr] 2 | pub mod PageEditInput;
[INFO] [stderr]   |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `page_edit_input`
[INFO] [stderr] 
[INFO] [stderr] warning: `fang_rs` (bin "fang_rs" test) generated 51 warnings (run `cargo fix --bin "fang_rs" -p fang_rs --tests` to apply 33 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.33s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/fang_rs-516adfa239047872)
[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" "15b00f34cba6b973d3974565b70e53785e42b8199e618488b8d8caefb51bb47d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "15b00f34cba6b973d3974565b70e53785e42b8199e618488b8d8caefb51bb47d", kill_on_drop: false }`
[INFO] [stdout] 15b00f34cba6b973d3974565b70e53785e42b8199e618488b8d8caefb51bb47d
