[INFO] cloning repository https://github.com/mouhamedsylla/localhost
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/mouhamedsylla/localhost" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmouhamedsylla%2Flocalhost", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmouhamedsylla%2Flocalhost'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 57635194b6344ddb247bbe3c98df32d0a55bbc0a
[INFO] testing mouhamedsylla/localhost against try#bd7d74411512a3dd3b35d2f699c51dd2557c7e7e+cargoflags=-Zbuild-dir-new-layout for pr-149852-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmouhamedsylla%2Flocalhost" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/mouhamedsylla/localhost
[INFO] removed 1 missing tests
[INFO] finished tweaking git repo https://github.com/mouhamedsylla/localhost
[INFO] tweaked toml for git repo https://github.com/mouhamedsylla/localhost written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/mouhamedsylla/localhost on toolchain bd7d74411512a3dd3b35d2f699c51dd2557c7e7e
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/mouhamedsylla/localhost 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" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] e52d65662f93c826c3f54d80b09d33aa4880d0ebe1825665e052262a578bce30
[INFO] running `Command { std: "docker" "start" "-a" "e52d65662f93c826c3f54d80b09d33aa4880d0ebe1825665e052262a578bce30", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "e52d65662f93c826c3f54d80b09d33aa4880d0ebe1825665e052262a578bce30", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e52d65662f93c826c3f54d80b09d33aa4880d0ebe1825665e052262a578bce30", kill_on_drop: false }`
[INFO] [stdout] e52d65662f93c826c3f54d80b09d33aa4880d0ebe1825665e052262a578bce30
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "build" "--frozen" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] 9923ac12f18a9791c731bb666d69acc10c1eb7178730d1b35295781008d4f1f1
[INFO] running `Command { std: "docker" "start" "-a" "9923ac12f18a9791c731bb666d69acc10c1eb7178730d1b35295781008d4f1f1", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.90
[INFO] [stderr]    Compiling libc v0.2.168
[INFO] [stderr]    Compiling getrandom v0.3.1
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling unicode-width v0.2.0
[INFO] [stderr]    Compiling bitflags v2.9.0
[INFO] [stderr]    Compiling portable-atomic v1.11.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling zerocopy v0.8.21
[INFO] [stderr]    Compiling unicase v2.8.0
[INFO] [stderr]    Compiling serde v1.0.216
[INFO] [stderr]    Compiling serde_json v1.0.133
[INFO] [stderr]    Compiling httparse v1.9.5
[INFO] [stderr]    Compiling clap_builder v4.5.31
[INFO] [stderr]    Compiling ryu v1.0.18
[INFO] [stderr]    Compiling iana-time-zone v0.1.61
[INFO] [stderr]    Compiling shell-words v1.1.0
[INFO] [stderr]    Compiling itoa v1.0.14
[INFO] [stderr]    Compiling colored v2.2.0
[INFO] [stderr]    Compiling tabwriter v1.4.1
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling console v0.15.11
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]    Compiling uuid v1.12.0
[INFO] [stderr]    Compiling chrono v0.4.39
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling indicatif v0.17.11
[INFO] [stderr]    Compiling tempfile v3.17.1
[INFO] [stderr]    Compiling zerocopy-derive v0.7.35
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling serde_derive v1.0.216
[INFO] [stderr]    Compiling clap_derive v4.5.28
[INFO] [stderr]    Compiling zerocopy v0.7.35
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling dialoguer v0.11.0
[INFO] [stderr]    Compiling clap v4.5.31
[INFO] [stderr]    Compiling ppv-lite86 v0.2.20
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand v0.9.0
[INFO] [stderr]    Compiling localhost v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `ContentType`, `HeaderName`, `HeaderParsedValue`, and `HeaderValue`
[INFO] [stdout]  --> src/http/response.rs:6:27
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::http::header::{HeaderName, HeaderValue, HeaderParsedValue, ContentType, Cookie, CookieOptions};
[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: `FormUrlEncoded`
[INFO] [stdout]  --> src/http/request.rs:2:31
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::http::body::{Body, FormUrlEncoded, BodyError};
[INFO] [stdout]   |                               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HeaderParsedValue` and `HeaderValue`
[INFO] [stdout]  --> src/http/request.rs:3:39
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::http::header::{HeaderName, HeaderParsedValue, HeaderValue, ContentType};
[INFO] [stdout]   |                                       ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::hash::Hash`
[INFO] [stdout]  --> src/http/header.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::hash::Hash;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]  --> src/http/header.rs:8:9
[INFO] [stdout]   |
[INFO] [stdout] 8 |     use super::*;
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HeaderName`, `HeaderParsedValue`, `HeaderValue`, and `Header`
[INFO] [stdout]   --> src/http/header.rs:11:21
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub use super::{Header, HeaderValue, HeaderName, HeaderParsedValue};
[INFO] [stdout]    |                     ^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]   --> src/http/header.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     use super::*;
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ContentType`, `ParsedContentDisposition`, and `ParsedContentType`
[INFO] [stdout]   --> src/http/header.rs:18:21
[INFO] [stdout]    |
[INFO] [stdout] 18 |     pub use super::{ParsedContentType, ParsedContentDisposition, ContentType};
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]   --> src/http/header.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 |     use super::*;
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CookieOptions`, `Cookie`, and `SameSitePolicy`
[INFO] [stdout]   --> src/http/header.rs:25:21
[INFO] [stdout]    |
[INFO] [stdout] 25 |     pub use super::{Cookie, CookieOptions, SameSitePolicy};
[INFO] [stdout]    |                     ^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ParsedContentType`
[INFO] [stdout]  --> src/http/body.rs:6:53
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::http::header::{ParsedContentDisposition, ParsedContentType, Header, HeaderName, ContentType};
[INFO] [stdout]   |                                                     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt`
[INFO] [stdout]  --> src/http/status.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::fmt;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SessionError`
[INFO] [stdout]   --> src/server/server.rs:19:40
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::server::errors::{HttpError, SessionError};
[INFO] [stdout]    |                                        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SessionError`
[INFO] [stdout]   --> src/server/host.rs:24:40
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::server::errors::{HttpError, SessionError};
[INFO] [stdout]    |                                        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `mime` should have an upper camel case name
[INFO] [stdout]   --> src/server/static_files.rs:15:10
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub type mime = String;
[INFO] [stdout]    |          ^^^^ help: convert the identifier to upper camel case: `Mime`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PathBuf`
[INFO] [stdout]  --> src/server/cgi.rs:8:23
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::path::{Path, PathBuf};
[INFO] [stdout]   |                       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/server/cgi.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 |         if (!script_path.exists()) {
[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] 106 -         if (!script_path.exists()) {
[INFO] [stdout] 106 +         if !script_path.exists()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/server/cgi.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout] 110 |         if (!self.is_allowed_extension(script_path)) {
[INFO] [stdout]     |            ^                                       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 110 -         if (!self.is_allowed_extension(script_path)) {
[INFO] [stdout] 110 +         if !self.is_allowed_extension(script_path)  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HttpError`
[INFO] [stdout]   --> src/server/handlers.rs:33:50
[INFO] [stdout]    |
[INFO] [stdout] 33 |         use crate::server::errors::{ServerError, HttpError};
[INFO] [stdout]    |                                                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Session`
[INFO] [stdout]    --> src/server/handlers.rs:314:47
[INFO] [stdout]     |
[INFO] [stdout] 314 |         use crate::server::session::session::{Session, SessionManager};
[INFO] [stdout]     |                                               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SessionError`
[INFO] [stdout]    --> src/server/handlers.rs:324:61
[INFO] [stdout]     |
[INFO] [stdout] 324 |         use crate::server::errors::{ServerError, HttpError, SessionError};
[INFO] [stdout]     |                                                             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/server/uploader.rs:121:12
[INFO] [stdout]     |
[INFO] [stdout] 121 |         if (!self.is_allowed_mime_type(mime_type)) {
[INFO] [stdout]     |            ^                                     ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 121 -         if (!self.is_allowed_mime_type(mime_type)) {
[INFO] [stdout] 121 +         if !self.is_allowed_mime_type(mime_type)  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/http/response.rs:105:13
[INFO] [stdout]     |
[INFO] [stdout] 105 |         let mut headers = vec![
[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/http/response.rs:120:13
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let mut headers = vec![
[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/http/body.rs:373:9
[INFO] [stdout]     |
[INFO] [stdout] 373 |     let mut pos = 0;
[INFO] [stdout]     |         ----^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pos`
[INFO] [stdout]    --> src/http/body.rs:373:9
[INFO] [stdout]     |
[INFO] [stdout] 373 |     let mut pos = 0;
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pos`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `s`
[INFO] [stdout]    --> src/server/server.rs:164:53
[INFO] [stdout]     |
[INFO] [stdout] 164 | ...                   if let Some(s) = session {
[INFO] [stdout]     |                                   ^ help: if this is intentional, prefix it with an underscore: `_s`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `should_close` is never read
[INFO] [stdout]    --> src/server/server.rs:171:49
[INFO] [stdout]     |
[INFO] [stdout] 171 | ...                   should_close = true;
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `should_close` is never read
[INFO] [stdout]    --> src/server/server.rs:219:45
[INFO] [stdout]     |
[INFO] [stdout] 219 | ...                   should_close = true;
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `should_close` is never read
[INFO] [stdout]    --> src/server/server.rs:239:34
[INFO] [stdout]     |
[INFO] [stdout] 239 | ...                   should_close = true;
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/server/static_files.rs:133:23
[INFO] [stdout]     |
[INFO] [stdout] 133 |             .map_err(|e| ServerError::FileNotFound(path.to_path_buf()))?;
[INFO] [stdout]     |                       ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `route`
[INFO] [stdout]   --> src/server/handlers.rs:43:57
[INFO] [stdout]    |
[INFO] [stdout] 43 |             fn serve_http(&mut self, request: &Request, route: &Route) -> Result<Response, ServerError> {
[INFO] [stdout]    |                                                         ^^^^^ help: if this is intentional, prefix it with an underscore: `_route`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `route`
[INFO] [stdout]    --> src/server/handlers.rs:104:57
[INFO] [stdout]     |
[INFO] [stdout] 104 |             fn serve_http(&mut self, request: &Request, route: &Route) -> Result<Response, ServerError> {
[INFO] [stdout]     |                                                         ^^^^^ help: if this is intentional, prefix it with an underscore: `_route`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]   --> src/server/uploader.rs:70:46
[INFO] [stdout]    |
[INFO] [stdout] 70 |         fs::remove_file(&file.path).map_err(|e| 
[INFO] [stdout]    |                                              ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `path`
[INFO] [stdout]    --> src/config/config.rs:129:22
[INFO] [stdout]     |
[INFO] [stdout] 129 |         for (status, path) in &self.custom_pages {
[INFO] [stdout]     |                      ^^^^ help: if this is intentional, prefix it with an underscore: `_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `version` is never read
[INFO] [stdout]   --> src/http/response.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct ResponseBuilder { 
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] 18 |     version: String,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ResponseBuilder` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_text_content_type` is never used
[INFO] [stdout]    --> src/http/body.rs:405:4
[INFO] [stdout]     |
[INFO] [stdout] 405 | fn is_text_content_type(content_type: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `process_part_data` is never used
[INFO] [stdout]    --> src/http/body.rs:414:4
[INFO] [stdout]     |
[INFO] [stdout] 414 | fn process_part_data(data: &[u8], content_type: &str) -> Vec<u8> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `defaultPath` should have a snake case name
[INFO] [stdout]   --> src/server/static_files.rs:80:13
[INFO] [stdout]    |
[INFO] [stdout] 80 |         let defaultPath = self.directory.join(".default/index.html");
[INFO] [stdout]    |             ^^^^^^^^^^^ help: convert the identifier to snake case: `default_path`
[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 `unifiedReader` should have a snake case name
[INFO] [stdout]   --> src/server/stream.rs:87:13
[INFO] [stdout]    |
[INFO] [stdout] 87 |     pub mod unifiedReader {
[INFO] [stdout]    |             ^^^^^^^^^^^^^ help: convert the identifier to snake case: `unified_reader`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]    --> src/bin/cli.rs:136:18
[INFO] [stdout]     |
[INFO] [stdout] 136 | fn create_server(args: CreateArgs) {
[INFO] [stdout]     |                  ^^^^ help: if this is intentional, prefix it with an underscore: `_args`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 21.38s
[INFO] running `Command { std: "docker" "inspect" "9923ac12f18a9791c731bb666d69acc10c1eb7178730d1b35295781008d4f1f1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9923ac12f18a9791c731bb666d69acc10c1eb7178730d1b35295781008d4f1f1", kill_on_drop: false }`
[INFO] [stdout] 9923ac12f18a9791c731bb666d69acc10c1eb7178730d1b35295781008d4f1f1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "--no-run" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] f1e2b694c1ea7fbf3f2bdc721de8067803a2e73160011ce5e16096e856b72eb6
[INFO] running `Command { std: "docker" "start" "-a" "f1e2b694c1ea7fbf3f2bdc721de8067803a2e73160011ce5e16096e856b72eb6", kill_on_drop: false }`
[INFO] [stdout] warning: unused imports: `ContentType`, `HeaderName`, `HeaderParsedValue`, and `HeaderValue`
[INFO] [stdout]  --> src/http/response.rs:6:27
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::http::header::{HeaderName, HeaderValue, HeaderParsedValue, ContentType, Cookie, CookieOptions};
[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: `FormUrlEncoded`
[INFO] [stdout]  --> src/http/request.rs:2:31
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::http::body::{Body, FormUrlEncoded, BodyError};
[INFO] [stdout]   |                               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HeaderParsedValue` and `HeaderValue`
[INFO] [stdout]  --> src/http/request.rs:3:39
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::http::header::{HeaderName, HeaderParsedValue, HeaderValue, ContentType};
[INFO] [stdout]   |                                       ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::hash::Hash`
[INFO] [stdout]  --> src/http/header.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::hash::Hash;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]  --> src/http/header.rs:8:9
[INFO] [stdout]   |
[INFO] [stdout] 8 |     use super::*;
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HeaderName`, `HeaderParsedValue`, `HeaderValue`, and `Header`
[INFO] [stdout]   --> src/http/header.rs:11:21
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub use super::{Header, HeaderValue, HeaderName, HeaderParsedValue};
[INFO] [stdout]    |                     ^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]   --> src/http/header.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     use super::*;
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ContentType`, `ParsedContentDisposition`, and `ParsedContentType`
[INFO] [stdout]   --> src/http/header.rs:18:21
[INFO] [stdout]    |
[INFO] [stdout] 18 |     pub use super::{ParsedContentType, ParsedContentDisposition, ContentType};
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]   --> src/http/header.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 |     use super::*;
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CookieOptions`, `Cookie`, and `SameSitePolicy`
[INFO] [stdout]   --> src/http/header.rs:25:21
[INFO] [stdout]    |
[INFO] [stdout] 25 |     pub use super::{Cookie, CookieOptions, SameSitePolicy};
[INFO] [stdout]    |                     ^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ParsedContentType`
[INFO] [stdout]  --> src/http/body.rs:6:53
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::http::header::{ParsedContentDisposition, ParsedContentType, Header, HeaderName, ContentType};
[INFO] [stdout]   |                                                     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt`
[INFO] [stdout]  --> src/http/status.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::fmt;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SessionError`
[INFO] [stdout]   --> src/server/server.rs:19:40
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::server::errors::{HttpError, SessionError};
[INFO] [stdout]    |                                        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SessionError`
[INFO] [stdout]   --> src/server/host.rs:24:40
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::server::errors::{HttpError, SessionError};
[INFO] [stdout]    |                                        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `mime` should have an upper camel case name
[INFO] [stdout]   --> src/server/static_files.rs:15:10
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub type mime = String;
[INFO] [stdout]    |          ^^^^ help: convert the identifier to upper camel case: `Mime`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PathBuf`
[INFO] [stdout]  --> src/server/cgi.rs:8:23
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::path::{Path, PathBuf};
[INFO] [stdout]   |                       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling localhost v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/server/cgi.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 |         if (!script_path.exists()) {
[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] 106 -         if (!script_path.exists()) {
[INFO] [stdout] 106 +         if !script_path.exists()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/server/cgi.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout] 110 |         if (!self.is_allowed_extension(script_path)) {
[INFO] [stdout]     |            ^                                       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 110 -         if (!self.is_allowed_extension(script_path)) {
[INFO] [stdout] 110 +         if !self.is_allowed_extension(script_path)  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HttpError`
[INFO] [stdout]   --> src/server/handlers.rs:33:50
[INFO] [stdout]    |
[INFO] [stdout] 33 |         use crate::server::errors::{ServerError, HttpError};
[INFO] [stdout]    |                                                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Session`
[INFO] [stdout]    --> src/server/handlers.rs:314:47
[INFO] [stdout]     |
[INFO] [stdout] 314 |         use crate::server::session::session::{Session, SessionManager};
[INFO] [stdout]     |                                               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SessionError`
[INFO] [stdout]    --> src/server/handlers.rs:324:61
[INFO] [stdout]     |
[INFO] [stdout] 324 |         use crate::server::errors::{ServerError, HttpError, SessionError};
[INFO] [stdout]     |                                                             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/server/uploader.rs:121:12
[INFO] [stdout]     |
[INFO] [stdout] 121 |         if (!self.is_allowed_mime_type(mime_type)) {
[INFO] [stdout]     |            ^                                     ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 121 -         if (!self.is_allowed_mime_type(mime_type)) {
[INFO] [stdout] 121 +         if !self.is_allowed_mime_type(mime_type)  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/http/response.rs:105:13
[INFO] [stdout]     |
[INFO] [stdout] 105 |         let mut headers = vec![
[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/http/response.rs:120:13
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let mut headers = vec![
[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/http/body.rs:373:9
[INFO] [stdout]     |
[INFO] [stdout] 373 |     let mut pos = 0;
[INFO] [stdout]     |         ----^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pos`
[INFO] [stdout]    --> src/http/body.rs:373:9
[INFO] [stdout]     |
[INFO] [stdout] 373 |     let mut pos = 0;
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pos`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `s`
[INFO] [stdout]    --> src/server/server.rs:164:53
[INFO] [stdout]     |
[INFO] [stdout] 164 | ...                   if let Some(s) = session {
[INFO] [stdout]     |                                   ^ help: if this is intentional, prefix it with an underscore: `_s`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `should_close` is never read
[INFO] [stdout]    --> src/server/server.rs:171:49
[INFO] [stdout]     |
[INFO] [stdout] 171 | ...                   should_close = true;
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `should_close` is never read
[INFO] [stdout]    --> src/server/server.rs:219:45
[INFO] [stdout]     |
[INFO] [stdout] 219 | ...                   should_close = true;
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `should_close` is never read
[INFO] [stdout]    --> src/server/server.rs:239:34
[INFO] [stdout]     |
[INFO] [stdout] 239 | ...                   should_close = true;
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/server/static_files.rs:133:23
[INFO] [stdout]     |
[INFO] [stdout] 133 |             .map_err(|e| ServerError::FileNotFound(path.to_path_buf()))?;
[INFO] [stdout]     |                       ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `route`
[INFO] [stdout]   --> src/server/handlers.rs:43:57
[INFO] [stdout]    |
[INFO] [stdout] 43 |             fn serve_http(&mut self, request: &Request, route: &Route) -> Result<Response, ServerError> {
[INFO] [stdout]    |                                                         ^^^^^ help: if this is intentional, prefix it with an underscore: `_route`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `route`
[INFO] [stdout]    --> src/server/handlers.rs:104:57
[INFO] [stdout]     |
[INFO] [stdout] 104 |             fn serve_http(&mut self, request: &Request, route: &Route) -> Result<Response, ServerError> {
[INFO] [stdout]     |                                                         ^^^^^ help: if this is intentional, prefix it with an underscore: `_route`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]   --> src/server/uploader.rs:70:46
[INFO] [stdout]    |
[INFO] [stdout] 70 |         fs::remove_file(&file.path).map_err(|e| 
[INFO] [stdout]    |                                              ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `path`
[INFO] [stdout]    --> src/config/config.rs:129:22
[INFO] [stdout]     |
[INFO] [stdout] 129 |         for (status, path) in &self.custom_pages {
[INFO] [stdout]     |                      ^^^^ help: if this is intentional, prefix it with an underscore: `_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `version` is never read
[INFO] [stdout]   --> src/http/response.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct ResponseBuilder { 
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] 18 |     version: String,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ResponseBuilder` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_text_content_type` is never used
[INFO] [stdout]    --> src/http/body.rs:405:4
[INFO] [stdout]     |
[INFO] [stdout] 405 | fn is_text_content_type(content_type: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `process_part_data` is never used
[INFO] [stdout]    --> src/http/body.rs:414:4
[INFO] [stdout]     |
[INFO] [stdout] 414 | fn process_part_data(data: &[u8], content_type: &str) -> Vec<u8> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `defaultPath` should have a snake case name
[INFO] [stdout]   --> src/server/static_files.rs:80:13
[INFO] [stdout]    |
[INFO] [stdout] 80 |         let defaultPath = self.directory.join(".default/index.html");
[INFO] [stdout]    |             ^^^^^^^^^^^ help: convert the identifier to snake case: `default_path`
[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 `unifiedReader` should have a snake case name
[INFO] [stdout]   --> src/server/stream.rs:87:13
[INFO] [stdout]    |
[INFO] [stdout] 87 |     pub mod unifiedReader {
[INFO] [stdout]    |             ^^^^^^^^^^^^^ help: convert the identifier to snake case: `unified_reader`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]    --> src/bin/cli.rs:136:18
[INFO] [stdout]     |
[INFO] [stdout] 136 | fn create_server(args: CreateArgs) {
[INFO] [stdout]     |                  ^^^^ help: if this is intentional, prefix it with an underscore: `_args`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ContentType`, `HeaderName`, `HeaderParsedValue`, and `HeaderValue`
[INFO] [stdout]  --> src/http/response.rs:6:27
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::http::header::{HeaderName, HeaderValue, HeaderParsedValue, ContentType, Cookie, CookieOptions};
[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: `FormUrlEncoded`
[INFO] [stdout]  --> src/http/request.rs:2:31
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::http::body::{Body, FormUrlEncoded, BodyError};
[INFO] [stdout]   |                               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HeaderParsedValue` and `HeaderValue`
[INFO] [stdout]  --> src/http/request.rs:3:39
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::http::header::{HeaderName, HeaderParsedValue, HeaderValue, ContentType};
[INFO] [stdout]   |                                       ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::hash::Hash`
[INFO] [stdout]  --> src/http/header.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::hash::Hash;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]  --> src/http/header.rs:8:9
[INFO] [stdout]   |
[INFO] [stdout] 8 |     use super::*;
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HeaderName`, `HeaderParsedValue`, `HeaderValue`, and `Header`
[INFO] [stdout]   --> src/http/header.rs:11:21
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub use super::{Header, HeaderValue, HeaderName, HeaderParsedValue};
[INFO] [stdout]    |                     ^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]   --> src/http/header.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     use super::*;
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ContentType`, `ParsedContentDisposition`, and `ParsedContentType`
[INFO] [stdout]   --> src/http/header.rs:18:21
[INFO] [stdout]    |
[INFO] [stdout] 18 |     pub use super::{ParsedContentType, ParsedContentDisposition, ContentType};
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]   --> src/http/header.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 |     use super::*;
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CookieOptions`, `Cookie`, and `SameSitePolicy`
[INFO] [stdout]   --> src/http/header.rs:25:21
[INFO] [stdout]    |
[INFO] [stdout] 25 |     pub use super::{Cookie, CookieOptions, SameSitePolicy};
[INFO] [stdout]    |                     ^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ParsedContentType`
[INFO] [stdout]  --> src/http/body.rs:6:53
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::http::header::{ParsedContentDisposition, ParsedContentType, Header, HeaderName, ContentType};
[INFO] [stdout]   |                                                     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt`
[INFO] [stdout]  --> src/http/status.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::fmt;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SessionError`
[INFO] [stdout]   --> src/server/server.rs:19:40
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::server::errors::{HttpError, SessionError};
[INFO] [stdout]    |                                        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SessionError`
[INFO] [stdout]   --> src/server/host.rs:24:40
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::server::errors::{HttpError, SessionError};
[INFO] [stdout]    |                                        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `mime` should have an upper camel case name
[INFO] [stdout]   --> src/server/static_files.rs:15:10
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub type mime = String;
[INFO] [stdout]    |          ^^^^ help: convert the identifier to upper camel case: `Mime`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PathBuf`
[INFO] [stdout]  --> src/server/cgi.rs:8:23
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::path::{Path, PathBuf};
[INFO] [stdout]   |                       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/server/cgi.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 |         if (!script_path.exists()) {
[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] 106 -         if (!script_path.exists()) {
[INFO] [stdout] 106 +         if !script_path.exists()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/server/cgi.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout] 110 |         if (!self.is_allowed_extension(script_path)) {
[INFO] [stdout]     |            ^                                       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 110 -         if (!self.is_allowed_extension(script_path)) {
[INFO] [stdout] 110 +         if !self.is_allowed_extension(script_path)  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HttpError`
[INFO] [stdout]   --> src/server/handlers.rs:33:50
[INFO] [stdout]    |
[INFO] [stdout] 33 |         use crate::server::errors::{ServerError, HttpError};
[INFO] [stdout]    |                                                  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Session`
[INFO] [stdout]    --> src/server/handlers.rs:314:47
[INFO] [stdout]     |
[INFO] [stdout] 314 |         use crate::server::session::session::{Session, SessionManager};
[INFO] [stdout]     |                                               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SessionError`
[INFO] [stdout]    --> src/server/handlers.rs:324:61
[INFO] [stdout]     |
[INFO] [stdout] 324 |         use crate::server::errors::{ServerError, HttpError, SessionError};
[INFO] [stdout]     |                                                             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/server/uploader.rs:121:12
[INFO] [stdout]     |
[INFO] [stdout] 121 |         if (!self.is_allowed_mime_type(mime_type)) {
[INFO] [stdout]     |            ^                                     ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 121 -         if (!self.is_allowed_mime_type(mime_type)) {
[INFO] [stdout] 121 +         if !self.is_allowed_mime_type(mime_type)  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/http/response.rs:105:13
[INFO] [stdout]     |
[INFO] [stdout] 105 |         let mut headers = vec![
[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/http/response.rs:120:13
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let mut headers = vec![
[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/http/body.rs:373:9
[INFO] [stdout]     |
[INFO] [stdout] 373 |     let mut pos = 0;
[INFO] [stdout]     |         ----^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pos`
[INFO] [stdout]    --> src/http/body.rs:373:9
[INFO] [stdout]     |
[INFO] [stdout] 373 |     let mut pos = 0;
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pos`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `s`
[INFO] [stdout]    --> src/server/server.rs:164:53
[INFO] [stdout]     |
[INFO] [stdout] 164 | ...                   if let Some(s) = session {
[INFO] [stdout]     |                                   ^ help: if this is intentional, prefix it with an underscore: `_s`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `should_close` is never read
[INFO] [stdout]    --> src/server/server.rs:171:49
[INFO] [stdout]     |
[INFO] [stdout] 171 | ...                   should_close = true;
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `should_close` is never read
[INFO] [stdout]    --> src/server/server.rs:219:45
[INFO] [stdout]     |
[INFO] [stdout] 219 | ...                   should_close = true;
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `should_close` is never read
[INFO] [stdout]    --> src/server/server.rs:239:34
[INFO] [stdout]     |
[INFO] [stdout] 239 | ...                   should_close = true;
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/server/static_files.rs:133:23
[INFO] [stdout]     |
[INFO] [stdout] 133 |             .map_err(|e| ServerError::FileNotFound(path.to_path_buf()))?;
[INFO] [stdout]     |                       ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `route`
[INFO] [stdout]   --> src/server/handlers.rs:43:57
[INFO] [stdout]    |
[INFO] [stdout] 43 |             fn serve_http(&mut self, request: &Request, route: &Route) -> Result<Response, ServerError> {
[INFO] [stdout]    |                                                         ^^^^^ help: if this is intentional, prefix it with an underscore: `_route`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `route`
[INFO] [stdout]    --> src/server/handlers.rs:104:57
[INFO] [stdout]     |
[INFO] [stdout] 104 |             fn serve_http(&mut self, request: &Request, route: &Route) -> Result<Response, ServerError> {
[INFO] [stdout]     |                                                         ^^^^^ help: if this is intentional, prefix it with an underscore: `_route`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]   --> src/server/uploader.rs:70:46
[INFO] [stdout]    |
[INFO] [stdout] 70 |         fs::remove_file(&file.path).map_err(|e| 
[INFO] [stdout]    |                                              ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `path`
[INFO] [stdout]    --> src/config/config.rs:129:22
[INFO] [stdout]     |
[INFO] [stdout] 129 |         for (status, path) in &self.custom_pages {
[INFO] [stdout]     |                      ^^^^ help: if this is intentional, prefix it with an underscore: `_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `version` is never read
[INFO] [stdout]   --> src/http/response.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct ResponseBuilder { 
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] 18 |     version: String,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ResponseBuilder` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_text_content_type` is never used
[INFO] [stdout]    --> src/http/body.rs:405:4
[INFO] [stdout]     |
[INFO] [stdout] 405 | fn is_text_content_type(content_type: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `process_part_data` is never used
[INFO] [stdout]    --> src/http/body.rs:414:4
[INFO] [stdout]     |
[INFO] [stdout] 414 | fn process_part_data(data: &[u8], content_type: &str) -> Vec<u8> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `defaultPath` should have a snake case name
[INFO] [stdout]   --> src/server/static_files.rs:80:13
[INFO] [stdout]    |
[INFO] [stdout] 80 |         let defaultPath = self.directory.join(".default/index.html");
[INFO] [stdout]    |             ^^^^^^^^^^^ help: convert the identifier to snake case: `default_path`
[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 `unifiedReader` should have a snake case name
[INFO] [stdout]   --> src/server/stream.rs:87:13
[INFO] [stdout]    |
[INFO] [stdout] 87 |     pub mod unifiedReader {
[INFO] [stdout]    |             ^^^^^^^^^^^^^ help: convert the identifier to snake case: `unified_reader`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.47s
[INFO] running `Command { std: "docker" "inspect" "f1e2b694c1ea7fbf3f2bdc721de8067803a2e73160011ce5e16096e856b72eb6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f1e2b694c1ea7fbf3f2bdc721de8067803a2e73160011ce5e16096e856b72eb6", kill_on_drop: false }`
[INFO] [stdout] f1e2b694c1ea7fbf3f2bdc721de8067803a2e73160011ce5e16096e856b72eb6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] ae91e7db95a81cbdea96c794a4d0555eefd8d83db83b54dcdc47e3f455546e3d
[INFO] running `Command { std: "docker" "start" "-a" "ae91e7db95a81cbdea96c794a4d0555eefd8d83db83b54dcdc47e3f455546e3d", kill_on_drop: false }`
[INFO] [stderr] warning: unused imports: `ContentType`, `HeaderName`, `HeaderParsedValue`, and `HeaderValue`
[INFO] [stdout] 
[INFO] [stderr]  --> src/http/response.rs:6:27
[INFO] [stdout] running 0 tests
[INFO] [stderr]   |
[INFO] [stdout] 
[INFO] [stderr] 6 | use crate::http::header::{HeaderName, HeaderValue, HeaderParsedValue, ContentType, Cookie, CookieOptions};
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stderr]   |                           ^^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stderr]   |
[INFO] [stdout] 
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] running 0 tests
[INFO] [stderr] 
[INFO] [stdout] 
[INFO] [stderr] warning: unused import: `FormUrlEncoded`
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stderr]  --> src/http/request.rs:2:31
[INFO] [stdout] 
[INFO] [stderr]   |
[INFO] [stderr] 2 | use crate::http::body::{Body, FormUrlEncoded, BodyError};
[INFO] [stderr]   |                               ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `HeaderParsedValue` and `HeaderValue`
[INFO] [stderr]  --> src/http/request.rs:3:39
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::http::header::{HeaderName, HeaderParsedValue, HeaderValue, ContentType};
[INFO] [stderr]   |                                       ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::hash::Hash`
[INFO] [stderr]  --> src/http/header.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::hash::Hash;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `super::*`
[INFO] [stderr]  --> src/http/header.rs:8:9
[INFO] [stderr]   |
[INFO] [stderr] 8 |     use super::*;
[INFO] [stderr]   |         ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `HeaderName`, `HeaderParsedValue`, `HeaderValue`, and `Header`
[INFO] [stderr]   --> src/http/header.rs:11:21
[INFO] [stderr]    |
[INFO] [stderr] 11 |     pub use super::{Header, HeaderValue, HeaderName, HeaderParsedValue};
[INFO] [stderr]    |                     ^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `super::*`
[INFO] [stderr]   --> src/http/header.rs:16:9
[INFO] [stderr]    |
[INFO] [stderr] 16 |     use super::*;
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `ContentType`, `ParsedContentDisposition`, and `ParsedContentType`
[INFO] [stderr]   --> src/http/header.rs:18:21
[INFO] [stderr]    |
[INFO] [stderr] 18 |     pub use super::{ParsedContentType, ParsedContentDisposition, ContentType};
[INFO] [stderr]    |                     ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `super::*`
[INFO] [stderr]   --> src/http/header.rs:23:9
[INFO] [stderr]    |
[INFO] [stderr] 23 |     use super::*;
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `CookieOptions`, `Cookie`, and `SameSitePolicy`
[INFO] [stderr]   --> src/http/header.rs:25:21
[INFO] [stderr]    |
[INFO] [stderr] 25 |     pub use super::{Cookie, CookieOptions, SameSitePolicy};
[INFO] [stderr]    |                     ^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ParsedContentType`
[INFO] [stderr]  --> src/http/body.rs:6:53
[INFO] [stderr]   |
[INFO] [stderr] 6 | use crate::http::header::{ParsedContentDisposition, ParsedContentType, Header, HeaderName, ContentType};
[INFO] [stderr]   |                                                     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::fmt`
[INFO] [stderr]  --> src/http/status.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::fmt;
[INFO] [stderr]   |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `SessionError`
[INFO] [stderr]   --> src/server/server.rs:19:40
[INFO] [stderr]    |
[INFO] [stderr] 19 | use crate::server::errors::{HttpError, SessionError};
[INFO] [stderr]    |                                        ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `SessionError`
[INFO] [stderr]   --> src/server/host.rs:24:40
[INFO] [stderr]    |
[INFO] [stderr] 24 | use crate::server::errors::{HttpError, SessionError};
[INFO] [stderr]    |                                        ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type `mime` should have an upper camel case name
[INFO] [stderr]   --> src/server/static_files.rs:15:10
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub type mime = String;
[INFO] [stderr]    |          ^^^^ help: convert the identifier to upper camel case: `Mime`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `PathBuf`
[INFO] [stderr]  --> src/server/cgi.rs:8:23
[INFO] [stderr]   |
[INFO] [stderr] 8 | use std::path::{Path, PathBuf};
[INFO] [stderr]   |                       ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/server/cgi.rs:106:12
[INFO] [stderr]     |
[INFO] [stderr] 106 |         if (!script_path.exists()) {
[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] 106 -         if (!script_path.exists()) {
[INFO] [stderr] 106 +         if !script_path.exists()  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/server/cgi.rs:110:12
[INFO] [stderr]     |
[INFO] [stderr] 110 |         if (!self.is_allowed_extension(script_path)) {
[INFO] [stderr]     |            ^                                       ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 110 -         if (!self.is_allowed_extension(script_path)) {
[INFO] [stderr] 110 +         if !self.is_allowed_extension(script_path)  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `HttpError`
[INFO] [stderr]   --> src/server/handlers.rs:33:50
[INFO] [stderr]    |
[INFO] [stderr] 33 |         use crate::server::errors::{ServerError, HttpError};
[INFO] [stderr]    |                                                  ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Session`
[INFO] [stderr]    --> src/server/handlers.rs:314:47
[INFO] [stderr]     |
[INFO] [stderr] 314 |         use crate::server::session::session::{Session, SessionManager};
[INFO] [stderr]     |                                               ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `SessionError`
[INFO] [stderr]    --> src/server/handlers.rs:324:61
[INFO] [stderr]     |
[INFO] [stderr] 324 |         use crate::server::errors::{ServerError, HttpError, SessionError};
[INFO] [stderr]     |                                                             ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/server/uploader.rs:121:12
[INFO] [stderr]     |
[INFO] [stderr] 121 |         if (!self.is_allowed_mime_type(mime_type)) {
[INFO] [stderr]     |            ^                                     ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 121 -         if (!self.is_allowed_mime_type(mime_type)) {
[INFO] [stderr] 121 +         if !self.is_allowed_mime_type(mime_type)  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/http/response.rs:105:13
[INFO] [stderr]     |
[INFO] [stderr] 105 |         let mut headers = vec![
[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/http/response.rs:120:13
[INFO] [stderr]     |
[INFO] [stderr] 120 |         let mut headers = vec![
[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/http/body.rs:373:9
[INFO] [stderr]     |
[INFO] [stderr] 373 |     let mut pos = 0;
[INFO] [stderr]     |         ----^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `pos`
[INFO] [stderr]    --> src/http/body.rs:373:9
[INFO] [stderr]     |
[INFO] [stderr] 373 |     let mut pos = 0;
[INFO] [stderr]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pos`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `s`
[INFO] [stderr]    --> src/server/server.rs:164:53
[INFO] [stderr]     |
[INFO] [stderr] 164 | ...                   if let Some(s) = session {
[INFO] [stderr]     |                                   ^ help: if this is intentional, prefix it with an underscore: `_s`
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `should_close` is never read
[INFO] [stderr]    --> src/server/server.rs:171:49
[INFO] [stderr]     |
[INFO] [stderr] 171 | ...                   should_close = true;
[INFO] [stderr]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `should_close` is never read
[INFO] [stderr]    --> src/server/server.rs:219:45
[INFO] [stderr]     |
[INFO] [stderr] 219 | ...                   should_close = true;
[INFO] [stderr]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `should_close` is never read
[INFO] [stderr]    --> src/server/server.rs:239:34
[INFO] [stderr]     |
[INFO] [stderr] 239 | ...                   should_close = true;
[INFO] [stderr]     |                       ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]    --> src/server/static_files.rs:133:23
[INFO] [stderr]     |
[INFO] [stderr] 133 |             .map_err(|e| ServerError::FileNotFound(path.to_path_buf()))?;
[INFO] [stderr]     |                       ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `route`
[INFO] [stderr]   --> src/server/handlers.rs:43:57
[INFO] [stderr]    |
[INFO] [stderr] 43 |             fn serve_http(&mut self, request: &Request, route: &Route) -> Result<Response, ServerError> {
[INFO] [stderr]    |                                                         ^^^^^ help: if this is intentional, prefix it with an underscore: `_route`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `route`
[INFO] [stderr]    --> src/server/handlers.rs:104:57
[INFO] [stderr]     |
[INFO] [stderr] 104 |             fn serve_http(&mut self, request: &Request, route: &Route) -> Result<Response, ServerError> {
[INFO] [stderr]     |                                                         ^^^^^ help: if this is intentional, prefix it with an underscore: `_route`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]   --> src/server/uploader.rs:70:46
[INFO] [stderr]    |
[INFO] [stderr] 70 |         fs::remove_file(&file.path).map_err(|e| 
[INFO] [stderr]    |                                              ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `path`
[INFO] [stderr]    --> src/config/config.rs:129:22
[INFO] [stderr]     |
[INFO] [stderr] 129 |         for (status, path) in &self.custom_pages {
[INFO] [stderr]     |                      ^^^^ help: if this is intentional, prefix it with an underscore: `_path`
[INFO] [stderr] 
[INFO] [stderr] warning: field `version` is never read
[INFO] [stderr]   --> src/http/response.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub struct ResponseBuilder { 
[INFO] [stderr]    |            --------------- field in this struct
[INFO] [stderr] 18 |     version: String,
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ResponseBuilder` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `is_text_content_type` is never used
[INFO] [stderr]    --> src/http/body.rs:405:4
[INFO] [stderr]     |
[INFO] [stderr] 405 | fn is_text_content_type(content_type: &str) -> bool {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `process_part_data` is never used
[INFO] [stderr]    --> src/http/body.rs:414:4
[INFO] [stderr]     |
[INFO] [stderr] 414 | fn process_part_data(data: &[u8], content_type: &str) -> Vec<u8> {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable `defaultPath` should have a snake case name
[INFO] [stderr]   --> src/server/static_files.rs:80:13
[INFO] [stderr]    |
[INFO] [stderr] 80 |         let defaultPath = self.directory.join(".default/index.html");
[INFO] [stderr]    |             ^^^^^^^^^^^ help: convert the identifier to snake case: `default_path`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: module `unifiedReader` should have a snake case name
[INFO] [stderr]   --> src/server/stream.rs:87:13
[INFO] [stderr]    |
[INFO] [stderr] 87 |     pub mod unifiedReader {
[INFO] [stderr]    |             ^^^^^^^^^^^^^ help: convert the identifier to snake case: `unified_reader`
[INFO] [stderr] 
[INFO] [stderr] warning: `localhost` (lib) generated 40 warnings (run `cargo fix --lib -p localhost` to apply 31 suggestions)
[INFO] [stderr] warning: `localhost` (lib test) generated 40 warnings (40 duplicates)
[INFO] [stderr] warning: unused variable: `args`
[INFO] [stderr]    --> src/bin/cli.rs:136:18
[INFO] [stderr]     |
[INFO] [stderr] 136 | fn create_server(args: CreateArgs) {
[INFO] [stderr]     |                  ^^^^ help: if this is intentional, prefix it with an underscore: `_args`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `localhost` (bin "localhost-cli" test) generated 1 warning (run `cargo fix --bin "localhost-cli" -p localhost --tests` to apply 1 suggestion)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.11s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/build/localhost/91ffd1aa90095ae4/deps/localhost-91ffd1aa90095ae4)
[INFO] [stderr]      Running unittests src/bin/cli.rs (/opt/rustwide/target/debug/build/localhost/6be6d00051c1303e/deps/localhost_cli-6be6d00051c1303e)
[INFO] [stderr]      Running unittests src/bin/server.rs (/opt/rustwide/target/debug/build/localhost/ad3721c7e92b6998/deps/localhost_server-ad3721c7e92b6998)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stderr]    Doc-tests localhost
[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] [stderr] warning: type `mime` should have an upper camel case name
[INFO] [stderr]   --> src/server/static_files.rs:15:10
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub type mime = String;
[INFO] [stderr]    |          ^^^^ help: convert the identifier to upper camel case: `Mime`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/server/cgi.rs:106:12
[INFO] [stderr]     |
[INFO] [stderr] 106 |         if (!script_path.exists()) {
[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] 106 -         if (!script_path.exists()) {
[INFO] [stderr] 106 +         if !script_path.exists()  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/server/cgi.rs:110:12
[INFO] [stderr]     |
[INFO] [stderr] 110 |         if (!self.is_allowed_extension(script_path)) {
[INFO] [stderr]     |            ^                                       ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 110 -         if (!self.is_allowed_extension(script_path)) {
[INFO] [stderr] 110 +         if !self.is_allowed_extension(script_path)  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/server/uploader.rs:121:12
[INFO] [stderr]     |
[INFO] [stderr] 121 |         if (!self.is_allowed_mime_type(mime_type)) {
[INFO] [stderr]     |            ^                                     ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 121 -         if (!self.is_allowed_mime_type(mime_type)) {
[INFO] [stderr] 121 +         if !self.is_allowed_mime_type(mime_type)  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: 4 warnings emitted
[INFO] [stderr] 
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test src/server/stream.rs - server::stream::request_stream::unifiedReader::UnifiedReader<S> (line 115) ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- src/server/stream.rs - server::stream::request_stream::unifiedReader::UnifiedReader<S> (line 115) stdout ----
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `UnifiedReader`
[INFO] [stdout]    --> src/server/stream.rs:119:14
[INFO] [stdout]     |
[INFO] [stdout] 119 | let reader = UnifiedReader::new(stream);
[INFO] [stdout]     |              ^^^^^^^^^^^^^ use of undeclared type `UnifiedReader`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 115 + use localhost::server::stream::request_stream::UnifiedReader;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `UnifiedReader`
[INFO] [stdout]    --> src/server/stream.rs:121:14
[INFO] [stdout]     |
[INFO] [stdout] 121 | let reader = UnifiedReader::with_max_size(stream, 5 * 1024 * 1024);
[INFO] [stdout]     |              ^^^^^^^^^^^^^ use of undeclared type `UnifiedReader`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]     |
[INFO] [stdout] 115 + use localhost::server::stream::request_stream::UnifiedReader;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no function or associated item named `new` found for struct `TcpStream` in the current scope
[INFO] [stdout]    --> src/server/stream.rs:118:25
[INFO] [stdout]     |
[INFO] [stdout] 118 | let stream = TcpStream::new();
[INFO] [stdout]     |                         ^^^ function or associated item not found in `TcpStream`
[INFO] [stdout]     |
[INFO] [stdout] note: if you're trying to build a new `TcpStream` consider using one of the following associated functions:
[INFO] [stdout]       TcpStream::connect
[INFO] [stdout]       TcpStream::connect_timeout
[INFO] [stdout]    --> /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/net/tcp.rs:168:4
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0433, E0599.
[INFO] [stdout] For more information about an error, try `rustc --explain E0433`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     src/server/stream.rs - server::stream::request_stream::unifiedReader::UnifiedReader<S> (line 115)
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.27s
[INFO] [stdout] 
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] running `Command { std: "docker" "inspect" "ae91e7db95a81cbdea96c794a4d0555eefd8d83db83b54dcdc47e3f455546e3d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ae91e7db95a81cbdea96c794a4d0555eefd8d83db83b54dcdc47e3f455546e3d", kill_on_drop: false }`
[INFO] [stdout] ae91e7db95a81cbdea96c794a4d0555eefd8d83db83b54dcdc47e3f455546e3d
