[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#db823df02fd0c2cf67b43025ac3fef3f2d743245 for pr-150681
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmouhamedsylla%2Flocalhost" "/workspace/builds/worker-0-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-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-0-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/mouhamedsylla/localhost on toolchain db823df02fd0c2cf67b43025ac3fef3f2d743245
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "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" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] fc2117909e6b7ae15add6f5545d5711a2ff2f9374d539718b261001307754ffe
[INFO] running `Command { std: "docker" "start" "-a" "fc2117909e6b7ae15add6f5545d5711a2ff2f9374d539718b261001307754ffe", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "fc2117909e6b7ae15add6f5545d5711a2ff2f9374d539718b261001307754ffe", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fc2117909e6b7ae15add6f5545d5711a2ff2f9374d539718b261001307754ffe", kill_on_drop: false }`
[INFO] [stdout] fc2117909e6b7ae15add6f5545d5711a2ff2f9374d539718b261001307754ffe
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0ff843022be064f1e2a546640350accdc844b4a92e8051b7bf45c62c139156e0
[INFO] running `Command { std: "docker" "start" "-a" "0ff843022be064f1e2a546640350accdc844b4a92e8051b7bf45c62c139156e0", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.92
[INFO] [stderr]    Compiling unicode-ident v1.0.14
[INFO] [stderr]    Compiling libc v0.2.168
[INFO] [stderr]    Compiling getrandom v0.3.1
[INFO] [stderr]    Compiling once_cell v1.20.2
[INFO] [stderr]    Compiling unicode-width v0.2.0
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling utf8parse v0.2.2
[INFO] [stderr]    Compiling autocfg v1.4.0
[INFO] [stderr]    Compiling is_terminal_polyfill v1.70.1
[INFO] [stderr]    Compiling colorchoice v1.0.3
[INFO] [stderr]    Compiling anstyle-query v1.1.2
[INFO] [stderr]    Compiling portable-atomic v1.11.0
[INFO] [stderr]    Compiling linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling bitflags v2.9.0
[INFO] [stderr]    Compiling anstyle-parse v0.2.6
[INFO] [stderr]    Compiling zerocopy v0.8.21
[INFO] [stderr]    Compiling unicase v2.8.0
[INFO] [stderr]    Compiling anstyle v1.0.10
[INFO] [stderr]    Compiling serde v1.0.216
[INFO] [stderr]    Compiling clap_lex v0.7.4
[INFO] [stderr]    Compiling strsim v0.11.1
[INFO] [stderr]    Compiling serde_json v1.0.133
[INFO] [stderr]    Compiling anstream v0.6.18
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling httparse v1.9.5
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling iana-time-zone v0.1.61
[INFO] [stderr]    Compiling itoa v1.0.14
[INFO] [stderr]    Compiling ryu v1.0.18
[INFO] [stderr]    Compiling zeroize v1.8.1
[INFO] [stderr]    Compiling number_prefix v0.4.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling shell-words v1.1.0
[INFO] [stderr]    Compiling clap_builder v4.5.31
[INFO] [stderr]    Compiling memchr v2.7.4
[INFO] [stderr]    Compiling colored v2.2.0
[INFO] [stderr]    Compiling tabwriter v1.4.1
[INFO] [stderr]    Compiling quote v1.0.37
[INFO] [stderr]    Compiling syn v2.0.90
[INFO] [stderr]    Compiling console v0.15.11
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]    Compiling uuid v1.12.0
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling indicatif v0.17.11
[INFO] [stderr]    Compiling chrono v0.4.39
[INFO] [stderr]    Compiling tempfile v3.17.1
[INFO] [stderr]    Compiling zerocopy-derive v0.7.35
[INFO] [stderr]    Compiling serde_derive v1.0.216
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[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 ppv-lite86 v0.2.20
[INFO] [stderr]    Compiling clap v4.5.31
[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 11.37s
[INFO] running `Command { std: "docker" "inspect" "0ff843022be064f1e2a546640350accdc844b4a92e8051b7bf45c62c139156e0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0ff843022be064f1e2a546640350accdc844b4a92e8051b7bf45c62c139156e0", kill_on_drop: false }`
[INFO] [stdout] 0ff843022be064f1e2a546640350accdc844b4a92e8051b7bf45c62c139156e0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0c9b5f8cb8d7011b4d0ee2559950e9bf763e999863d31b3ba4ec617073e577e9
[INFO] running `Command { std: "docker" "start" "-a" "0c9b5f8cb8d7011b4d0ee2559950e9bf763e999863d31b3ba4ec617073e577e9", 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] [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] [stderr]    Compiling localhost v0.1.0 (/opt/rustwide/workdir)
[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 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: 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: 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.90s
[INFO] running `Command { std: "docker" "inspect" "0c9b5f8cb8d7011b4d0ee2559950e9bf763e999863d31b3ba4ec617073e577e9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0c9b5f8cb8d7011b4d0ee2559950e9bf763e999863d31b3ba4ec617073e577e9", kill_on_drop: false }`
[INFO] [stdout] 0c9b5f8cb8d7011b4d0ee2559950e9bf763e999863d31b3ba4ec617073e577e9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 8e46442a278881c1991daff062ff6c6cbc587f0c7c8ffa7f2ac6ca79c40f451f
[INFO] running `Command { std: "docker" "start" "-a" "8e46442a278881c1991daff062ff6c6cbc587f0c7c8ffa7f2ac6ca79c40f451f", kill_on_drop: false }`
[INFO] [stderr] warning: unused imports: `ContentType`, `HeaderName`, `HeaderParsedValue`, and `HeaderValue`
[INFO] [stderr]  --> src/http/response.rs:6:27
[INFO] [stderr]   |
[INFO] [stderr] 6 | use crate::http::header::{HeaderName, HeaderValue, HeaderParsedValue, ContentType, Cookie, CookieOptions};
[INFO] [stderr]   |                           ^^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `FormUrlEncoded`
[INFO] [stderr]  --> src/http/request.rs:2:31
[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.14s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/localhost-91ffd1aa90095ae4)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/cli.rs (/opt/rustwide/target/debug/deps/localhost_cli-6be6d00051c1303e)
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/server.rs (/opt/rustwide/target/debug/deps/localhost_server-ad3721c7e92b6998)
[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] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests localhost
[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/db823df02fd0c2cf67b43025ac3fef3f2d743245/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.30s
[INFO] [stdout] 
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] running `Command { std: "docker" "inspect" "8e46442a278881c1991daff062ff6c6cbc587f0c7c8ffa7f2ac6ca79c40f451f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8e46442a278881c1991daff062ff6c6cbc587f0c7c8ffa7f2ac6ca79c40f451f", kill_on_drop: false }`
[INFO] [stdout] 8e46442a278881c1991daff062ff6c6cbc587f0c7c8ffa7f2ac6ca79c40f451f
