[INFO] cloning repository https://github.com/SinimaWath/highload_dz1 [INFO] running `"git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/SinimaWath/highload_dz1" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSinimaWath%2Fhighload_dz1"` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSinimaWath%2Fhighload_dz1'... [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 0d3216be68743aa955e35689193fa26eea7d8b0c [INFO] testing SinimaWath/highload_dz1 against 1.44.0 for beta-1.45-1 [INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSinimaWath%2Fhighload_dz1" "/workspace/builds/worker-4/source"` [INFO] [stderr] Cloning into '/workspace/builds/worker-4/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/SinimaWath/highload_dz1 on toolchain 1.44.0 [INFO] running `"/workspace/cargo-home/bin/cargo" "+1.44.0" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started tweaking git repo https://github.com/SinimaWath/highload_dz1 [INFO] finished tweaking git repo https://github.com/SinimaWath/highload_dz1 [INFO] tweaked toml for git repo https://github.com/SinimaWath/highload_dz1 written to /workspace/builds/worker-4/source/Cargo.toml [INFO] crate git repo https://github.com/SinimaWath/highload_dz1 already has a lockfile, it will not be regenerated [INFO] running `"/workspace/cargo-home/bin/cargo" "+1.44.0" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+1.44.0" "build" "--frozen"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 4f3e422f6d6a82584a7e83974928f1ed7f35b058f65a0ddaa48265db60fac07f [INFO] running `"docker" "start" "-a" "4f3e422f6d6a82584a7e83974928f1ed7f35b058f65a0ddaa48265db60fac07f"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] Compiling libc v0.2.50 [INFO] [stderr] Compiling num-traits v0.2.6 [INFO] [stderr] Compiling num-iter v0.1.37 [INFO] [stderr] Compiling num-integer v0.1.39 [INFO] [stderr] Compiling atty v0.2.11 [INFO] [stderr] Compiling time v0.1.42 [INFO] [stderr] Compiling clap v2.32.0 [INFO] [stderr] Compiling num v0.1.42 [INFO] [stderr] Compiling chrono v0.3.0 [INFO] [stderr] Compiling dz1 v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: unnecessary parentheses around type [INFO] [stderr] --> src/http/request.rs:20:43 [INFO] [stderr] | [INFO] [stderr] 20 | pub fn parse(buffer: &[u8]) -> Result<(HTTPRequest), ()> { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DateTime`, `NaiveDateTime`, `TimeZone` [INFO] [stderr] --> src/http/response.rs:10:14 [INFO] [stderr] | [INFO] [stderr] 10 | use chrono::{DateTime, TimeZone, NaiveDateTime, UTC}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::error::Error` [INFO] [stderr] --> src/config/config.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::error::Error; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fmt::Display` [INFO] [stderr] --> src/config/config.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::fmt::Display; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/config/config.rs:42:12 [INFO] [stderr] | [INFO] [stderr] 42 | if (document_root_pair.len() != 2) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/config/config.rs:51:12 [INFO] [stderr] | [INFO] [stderr] 51 | if (thread_limit_pair.len() != 2) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unused import: `HashMap` [INFO] [stderr] --> src/server/server.rs:8:24 [INFO] [stderr] | [INFO] [stderr] 8 | use std::collections::{HashMap}; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/server/server.rs:127:20 [INFO] [stderr] | [INFO] [stderr] 127 | if (isAutoIndex) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/server/server.rs:152:20 [INFO] [stderr] | [INFO] [stderr] 152 | if (isAutoIndex) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::thread` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::thread; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Task` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:3:42 [INFO] [stderr] | [INFO] [stderr] 3 | use crate::thread_pool::worker::{Worker, Task, Message}; [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/thread_pool/worker.rs:23:21 [INFO] [stderr] | [INFO] [stderr] 23 | pub type Task = Box; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnBox + Send + 'static` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `err` [INFO] [stderr] --> src/server/server.rs:126:17 [INFO] [stderr] | [INFO] [stderr] 126 | Err(err) => { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_err` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `TestCase` [INFO] [stderr] --> src/http/request_test.rs:4:8 [INFO] [stderr] | [INFO] [stderr] 4 | struct TestCase { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `TestCase` [INFO] [stderr] --> src/config/config_test.rs:3:8 [INFO] [stderr] | [INFO] [stderr] 3 | struct TestCase { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `test_invalid_format_thread_limit` [INFO] [stderr] --> src/config/config_test.rs:84:4 [INFO] [stderr] | [INFO] [stderr] 84 | fn test_invalid_format_thread_limit() { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `workers` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | workers: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/http/request.rs:8:9 [INFO] [stderr] | [INFO] [stderr] 8 | pub isAutoIndex: bool, [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable `stringRaw` should have a snake case name [INFO] [stderr] --> src/http/request.rs:21:13 [INFO] [stderr] | [INFO] [stderr] 21 | let stringRaw = std::str::from_utf8(buffer).unwrap(); [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `string_raw` [INFO] [stderr] [INFO] [stderr] warning: variable `firstLine` should have a snake case name [INFO] [stderr] --> src/http/request.rs:22:13 [INFO] [stderr] | [INFO] [stderr] 22 | let firstLine = stringRaw.split("\r\n").nth(0).unwrap(); [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `first_line` [INFO] [stderr] [INFO] [stderr] warning: variable `requestVec` should have a snake case name [INFO] [stderr] --> src/http/request.rs:28:13 [INFO] [stderr] | [INFO] [stderr] 28 | let requestVec: Vec<&str> = firstLine.split(" ").collect(); [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `request_vec` [INFO] [stderr] [INFO] [stderr] warning: variable `parsedPath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:34:14 [INFO] [stderr] | [INFO] [stderr] 34 | let (parsedPath, isAutoIndex) = match parsePath(requestVec[1]) { [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `parsed_path` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/http/request.rs:34:26 [INFO] [stderr] | [INFO] [stderr] 34 | let (parsedPath, isAutoIndex) = match parsePath(requestVec[1]) { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: function `parsePath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:52:4 [INFO] [stderr] | [INFO] [stderr] 52 | fn parsePath(path: &str) -> Result<(String, bool), ()> { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `parse_path` [INFO] [stderr] [INFO] [stderr] warning: variable `rawPath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:53:9 [INFO] [stderr] | [INFO] [stderr] 53 | let rawPath = path.split("?").nth(0).unwrap(); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `raw_path` [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/http/response.rs:55:29 [INFO] [stderr] | [INFO] [stderr] 55 | ... f.seek(SeekFrom::Start(n as u64)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: method `setContentType` should have a snake case name [INFO] [stderr] --> src/http/response.rs:65:12 [INFO] [stderr] | [INFO] [stderr] 65 | pub fn setContentType(&mut self, path: &Path) { [INFO] [stderr] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_content_type` [INFO] [stderr] [INFO] [stderr] warning: method `setContentLength` should have a snake case name [INFO] [stderr] --> src/http/response.rs:87:12 [INFO] [stderr] | [INFO] [stderr] 87 | pub fn setContentLength(&mut self, path: &Path) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_content_length` [INFO] [stderr] [INFO] [stderr] warning: method `setOk` should have a snake case name [INFO] [stderr] --> src/http/response.rs:101:12 [INFO] [stderr] | [INFO] [stderr] 101 | pub fn setOk(&mut self, file: Option) { [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `set_ok` [INFO] [stderr] [INFO] [stderr] warning: method `setNotFound` should have a snake case name [INFO] [stderr] --> src/http/response.rs:110:12 [INFO] [stderr] | [INFO] [stderr] 110 | pub fn setNotFound(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `set_not_found` [INFO] [stderr] [INFO] [stderr] warning: method `setBadRequest` should have a snake case name [INFO] [stderr] --> src/http/response.rs:115:12 [INFO] [stderr] | [INFO] [stderr] 115 | pub fn setBadRequest(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_bad_request` [INFO] [stderr] [INFO] [stderr] warning: method `setNotAllowed` should have a snake case name [INFO] [stderr] --> src/http/response.rs:120:12 [INFO] [stderr] | [INFO] [stderr] 120 | pub fn setNotAllowed(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_not_allowed` [INFO] [stderr] [INFO] [stderr] warning: method `setDate` should have a snake case name [INFO] [stderr] --> src/http/response.rs:130:12 [INFO] [stderr] | [INFO] [stderr] 130 | pub fn setDate(&mut self) { [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_date` [INFO] [stderr] [INFO] [stderr] warning: method `setServer` should have a snake case name [INFO] [stderr] --> src/http/response.rs:135:12 [INFO] [stderr] | [INFO] [stderr] 135 | pub fn setServer(&mut self, server: &str) { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `set_server` [INFO] [stderr] [INFO] [stderr] warning: method `setConnection` should have a snake case name [INFO] [stderr] --> src/http/response.rs:139:12 [INFO] [stderr] | [INFO] [stderr] 139 | pub fn setConnection(&mut self, conn: &str) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_connection` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/server/server.rs:115:48 [INFO] [stderr] | [INFO] [stderr] 115 | fn handle_get(path: String, root: &String, isAutoIndex: bool) -> HTTPResponse { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/server/server.rs:138:49 [INFO] [stderr] | [INFO] [stderr] 138 | fn handle_head(path: String, root: &String, isAutoIndex: bool) -> HTTPResponse { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: 37 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::env` [INFO] [stderr] --> src/main.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use std::env; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: 1 warning emitted [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 21.32s [INFO] running `"docker" "inspect" "4f3e422f6d6a82584a7e83974928f1ed7f35b058f65a0ddaa48265db60fac07f"` [INFO] running `"docker" "rm" "-f" "4f3e422f6d6a82584a7e83974928f1ed7f35b058f65a0ddaa48265db60fac07f"` [INFO] [stdout] 4f3e422f6d6a82584a7e83974928f1ed7f35b058f65a0ddaa48265db60fac07f [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+1.44.0" "test" "--frozen" "--no-run"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] d3044f3d4c1688f3716873a8e6f1edb0fc34fde60b3acca2a1d36fe6cde12cee [INFO] running `"docker" "start" "-a" "d3044f3d4c1688f3716873a8e6f1edb0fc34fde60b3acca2a1d36fe6cde12cee"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] Compiling dz1 v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: unnecessary parentheses around type [INFO] [stderr] --> src/http/request.rs:20:43 [INFO] [stderr] | [INFO] [stderr] 20 | pub fn parse(buffer: &[u8]) -> Result<(HTTPRequest), ()> { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DateTime`, `NaiveDateTime`, `TimeZone` [INFO] [stderr] --> src/http/response.rs:10:14 [INFO] [stderr] | [INFO] [stderr] 10 | use chrono::{DateTime, TimeZone, NaiveDateTime, UTC}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::error::Error` [INFO] [stderr] --> src/config/config.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::error::Error; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fmt::Display` [INFO] [stderr] --> src/config/config.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::fmt::Display; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/config/config.rs:42:12 [INFO] [stderr] | [INFO] [stderr] 42 | if (document_root_pair.len() != 2) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/config/config.rs:51:12 [INFO] [stderr] | [INFO] [stderr] 51 | if (thread_limit_pair.len() != 2) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unused import: `HashMap` [INFO] [stderr] --> src/server/server.rs:8:24 [INFO] [stderr] | [INFO] [stderr] 8 | use std::collections::{HashMap}; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/server/server.rs:127:20 [INFO] [stderr] | [INFO] [stderr] 127 | if (isAutoIndex) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/server/server.rs:152:20 [INFO] [stderr] | [INFO] [stderr] 152 | if (isAutoIndex) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::thread` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::thread; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Task` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:3:42 [INFO] [stderr] | [INFO] [stderr] 3 | use crate::thread_pool::worker::{Worker, Task, Message}; [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/thread_pool/worker.rs:23:21 [INFO] [stderr] | [INFO] [stderr] 23 | pub type Task = Box; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnBox + Send + 'static` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `err` [INFO] [stderr] --> src/server/server.rs:126:17 [INFO] [stderr] | [INFO] [stderr] 126 | Err(err) => { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_err` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `TestCase` [INFO] [stderr] --> src/http/request_test.rs:4:8 [INFO] [stderr] | [INFO] [stderr] 4 | struct TestCase { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `TestCase` [INFO] [stderr] --> src/config/config_test.rs:3:8 [INFO] [stderr] | [INFO] [stderr] 3 | struct TestCase { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `test_invalid_format_thread_limit` [INFO] [stderr] --> src/config/config_test.rs:84:4 [INFO] [stderr] | [INFO] [stderr] 84 | fn test_invalid_format_thread_limit() { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `workers` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | workers: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/http/request.rs:8:9 [INFO] [stderr] | [INFO] [stderr] 8 | pub isAutoIndex: bool, [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable `stringRaw` should have a snake case name [INFO] [stderr] --> src/http/request.rs:21:13 [INFO] [stderr] | [INFO] [stderr] 21 | let stringRaw = std::str::from_utf8(buffer).unwrap(); [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `string_raw` [INFO] [stderr] [INFO] [stderr] warning: variable `firstLine` should have a snake case name [INFO] [stderr] --> src/http/request.rs:22:13 [INFO] [stderr] | [INFO] [stderr] 22 | let firstLine = stringRaw.split("\r\n").nth(0).unwrap(); [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `first_line` [INFO] [stderr] [INFO] [stderr] warning: variable `requestVec` should have a snake case name [INFO] [stderr] --> src/http/request.rs:28:13 [INFO] [stderr] | [INFO] [stderr] 28 | let requestVec: Vec<&str> = firstLine.split(" ").collect(); [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `request_vec` [INFO] [stderr] [INFO] [stderr] warning: variable `parsedPath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:34:14 [INFO] [stderr] | [INFO] [stderr] 34 | let (parsedPath, isAutoIndex) = match parsePath(requestVec[1]) { [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `parsed_path` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/http/request.rs:34:26 [INFO] [stderr] | [INFO] [stderr] 34 | let (parsedPath, isAutoIndex) = match parsePath(requestVec[1]) { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: function `parsePath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:52:4 [INFO] [stderr] | [INFO] [stderr] 52 | fn parsePath(path: &str) -> Result<(String, bool), ()> { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `parse_path` [INFO] [stderr] [INFO] [stderr] warning: variable `rawPath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:53:9 [INFO] [stderr] | [INFO] [stderr] 53 | let rawPath = path.split("?").nth(0).unwrap(); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `raw_path` [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/http/response.rs:55:29 [INFO] [stderr] | [INFO] [stderr] 55 | ... f.seek(SeekFrom::Start(n as u64)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: method `setContentType` should have a snake case name [INFO] [stderr] --> src/http/response.rs:65:12 [INFO] [stderr] | [INFO] [stderr] 65 | pub fn setContentType(&mut self, path: &Path) { [INFO] [stderr] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_content_type` [INFO] [stderr] [INFO] [stderr] warning: method `setContentLength` should have a snake case name [INFO] [stderr] --> src/http/response.rs:87:12 [INFO] [stderr] | [INFO] [stderr] 87 | pub fn setContentLength(&mut self, path: &Path) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_content_length` [INFO] [stderr] [INFO] [stderr] warning: method `setOk` should have a snake case name [INFO] [stderr] --> src/http/response.rs:101:12 [INFO] [stderr] | [INFO] [stderr] 101 | pub fn setOk(&mut self, file: Option) { [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `set_ok` [INFO] [stderr] [INFO] [stderr] warning: method `setNotFound` should have a snake case name [INFO] [stderr] --> src/http/response.rs:110:12 [INFO] [stderr] | [INFO] [stderr] 110 | pub fn setNotFound(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `set_not_found` [INFO] [stderr] [INFO] [stderr] warning: method `setBadRequest` should have a snake case name [INFO] [stderr] --> src/http/response.rs:115:12 [INFO] [stderr] | [INFO] [stderr] 115 | pub fn setBadRequest(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_bad_request` [INFO] [stderr] [INFO] [stderr] warning: method `setNotAllowed` should have a snake case name [INFO] [stderr] --> src/http/response.rs:120:12 [INFO] [stderr] | [INFO] [stderr] 120 | pub fn setNotAllowed(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_not_allowed` [INFO] [stderr] [INFO] [stderr] warning: method `setDate` should have a snake case name [INFO] [stderr] --> src/http/response.rs:130:12 [INFO] [stderr] | [INFO] [stderr] 130 | pub fn setDate(&mut self) { [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_date` [INFO] [stderr] [INFO] [stderr] warning: method `setServer` should have a snake case name [INFO] [stderr] --> src/http/response.rs:135:12 [INFO] [stderr] | [INFO] [stderr] 135 | pub fn setServer(&mut self, server: &str) { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `set_server` [INFO] [stderr] [INFO] [stderr] warning: method `setConnection` should have a snake case name [INFO] [stderr] --> src/http/response.rs:139:12 [INFO] [stderr] | [INFO] [stderr] 139 | pub fn setConnection(&mut self, conn: &str) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_connection` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/server/server.rs:115:48 [INFO] [stderr] | [INFO] [stderr] 115 | fn handle_get(path: String, root: &String, isAutoIndex: bool) -> HTTPResponse { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/server/server.rs:138:49 [INFO] [stderr] | [INFO] [stderr] 138 | fn handle_head(path: String, root: &String, isAutoIndex: bool) -> HTTPResponse { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: 37 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::env` [INFO] [stderr] --> src/main.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use std::env; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around type [INFO] [stderr] --> src/http/request.rs:20:43 [INFO] [stderr] | [INFO] [stderr] 20 | pub fn parse(buffer: &[u8]) -> Result<(HTTPRequest), ()> { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DateTime`, `NaiveDateTime`, `TimeZone` [INFO] [stderr] --> src/http/response.rs:10:14 [INFO] [stderr] | [INFO] [stderr] 10 | use chrono::{DateTime, TimeZone, NaiveDateTime, UTC}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::error::Error` [INFO] [stderr] --> src/config/config.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::error::Error; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fmt::Display` [INFO] [stderr] --> src/config/config.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::fmt::Display; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/config/config.rs:42:12 [INFO] [stderr] | [INFO] [stderr] 42 | if (document_root_pair.len() != 2) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/config/config.rs:51:12 [INFO] [stderr] | [INFO] [stderr] 51 | if (thread_limit_pair.len() != 2) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unused import: `HashMap` [INFO] [stderr] --> src/server/server.rs:8:24 [INFO] [stderr] | [INFO] [stderr] 8 | use std::collections::{HashMap}; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/server/server.rs:127:20 [INFO] [stderr] | [INFO] [stderr] 127 | if (isAutoIndex) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/server/server.rs:152:20 [INFO] [stderr] | [INFO] [stderr] 152 | if (isAutoIndex) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::thread` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::thread; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Task` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:3:42 [INFO] [stderr] | [INFO] [stderr] 3 | use crate::thread_pool::worker::{Worker, Task, Message}; [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/thread_pool/worker.rs:23:21 [INFO] [stderr] | [INFO] [stderr] 23 | pub type Task = Box; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnBox + Send + 'static` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:16:9 [INFO] [stderr] | [INFO] [stderr] 16 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:29:9 [INFO] [stderr] | [INFO] [stderr] 29 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:42:9 [INFO] [stderr] | [INFO] [stderr] 42 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:55:9 [INFO] [stderr] | [INFO] [stderr] 55 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:68:9 [INFO] [stderr] | [INFO] [stderr] 68 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `req` [INFO] [stderr] --> src/http/request_test.rs:69:12 [INFO] [stderr] | [INFO] [stderr] 69 | Ok(req) => panic!("Unexpected header"), [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_req` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:81:9 [INFO] [stderr] | [INFO] [stderr] 81 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:94:9 [INFO] [stderr] | [INFO] [stderr] 94 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:107:9 [INFO] [stderr] | [INFO] [stderr] 107 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:121:9 [INFO] [stderr] | [INFO] [stderr] 121 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:134:9 [INFO] [stderr] | [INFO] [stderr] 134 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:148:9 [INFO] [stderr] | [INFO] [stderr] 148 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:161:9 [INFO] [stderr] | [INFO] [stderr] 161 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:174:9 [INFO] [stderr] | [INFO] [stderr] 174 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `req` [INFO] [stderr] --> src/http/request_test.rs:175:12 [INFO] [stderr] | [INFO] [stderr] 175 | Ok(req) => panic!("Unexpected OK"), [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_req` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:187:9 [INFO] [stderr] | [INFO] [stderr] 187 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `err` [INFO] [stderr] --> src/server/server.rs:126:17 [INFO] [stderr] | [INFO] [stderr] 126 | Err(err) => { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_err` [INFO] [stderr] [INFO] [stderr] warning: function is never used: `test_invalid_format_thread_limit` [INFO] [stderr] --> src/config/config_test.rs:84:4 [INFO] [stderr] | [INFO] [stderr] 84 | fn test_invalid_format_thread_limit() { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `workers` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | workers: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/http/request.rs:8:9 [INFO] [stderr] | [INFO] [stderr] 8 | pub isAutoIndex: bool, [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable `stringRaw` should have a snake case name [INFO] [stderr] --> src/http/request.rs:21:13 [INFO] [stderr] | [INFO] [stderr] 21 | let stringRaw = std::str::from_utf8(buffer).unwrap(); [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `string_raw` [INFO] [stderr] [INFO] [stderr] warning: variable `firstLine` should have a snake case name [INFO] [stderr] --> src/http/request.rs:22:13 [INFO] [stderr] | [INFO] [stderr] 22 | let firstLine = stringRaw.split("\r\n").nth(0).unwrap(); [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `first_line` [INFO] [stderr] [INFO] [stderr] warning: variable `requestVec` should have a snake case name [INFO] [stderr] --> src/http/request.rs:28:13 [INFO] [stderr] | [INFO] [stderr] 28 | let requestVec: Vec<&str> = firstLine.split(" ").collect(); [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `request_vec` [INFO] [stderr] [INFO] [stderr] warning: variable `parsedPath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:34:14 [INFO] [stderr] | [INFO] [stderr] 34 | let (parsedPath, isAutoIndex) = match parsePath(requestVec[1]) { [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `parsed_path` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/http/request.rs:34:26 [INFO] [stderr] | [INFO] [stderr] 34 | let (parsedPath, isAutoIndex) = match parsePath(requestVec[1]) { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: function `parsePath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:52:4 [INFO] [stderr] | [INFO] [stderr] 52 | fn parsePath(path: &str) -> Result<(String, bool), ()> { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `parse_path` [INFO] [stderr] [INFO] [stderr] warning: variable `rawPath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:53:9 [INFO] [stderr] | [INFO] [stderr] 53 | let rawPath = path.split("?").nth(0).unwrap(); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `raw_path` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:11:9 [INFO] [stderr] | [INFO] [stderr] 11 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:24:9 [INFO] [stderr] | [INFO] [stderr] 24 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:37:9 [INFO] [stderr] | [INFO] [stderr] 37 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:50:9 [INFO] [stderr] | [INFO] [stderr] 50 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:63:9 [INFO] [stderr] | [INFO] [stderr] 63 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:76:9 [INFO] [stderr] | [INFO] [stderr] 76 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:89:9 [INFO] [stderr] | [INFO] [stderr] 89 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:102:9 [INFO] [stderr] | [INFO] [stderr] 102 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:116:9 [INFO] [stderr] | [INFO] [stderr] 116 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:129:9 [INFO] [stderr] | [INFO] [stderr] 129 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:143:9 [INFO] [stderr] | [INFO] [stderr] 143 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:156:9 [INFO] [stderr] | [INFO] [stderr] 156 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:169:9 [INFO] [stderr] | [INFO] [stderr] 169 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:182:9 [INFO] [stderr] | [INFO] [stderr] 182 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/http/response.rs:55:29 [INFO] [stderr] | [INFO] [stderr] 55 | ... f.seek(SeekFrom::Start(n as u64)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: method `setContentType` should have a snake case name [INFO] [stderr] --> src/http/response.rs:65:12 [INFO] [stderr] | [INFO] [stderr] 65 | pub fn setContentType(&mut self, path: &Path) { [INFO] [stderr] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_content_type` [INFO] [stderr] [INFO] [stderr] warning: method `setContentLength` should have a snake case name [INFO] [stderr] --> src/http/response.rs:87:12 [INFO] [stderr] | [INFO] [stderr] 87 | pub fn setContentLength(&mut self, path: &Path) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_content_length` [INFO] [stderr] [INFO] [stderr] warning: method `setOk` should have a snake case name [INFO] [stderr] --> src/http/response.rs:101:12 [INFO] [stderr] | [INFO] [stderr] 101 | pub fn setOk(&mut self, file: Option) { [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `set_ok` [INFO] [stderr] [INFO] [stderr] warning: method `setNotFound` should have a snake case name [INFO] [stderr] --> src/http/response.rs:110:12 [INFO] [stderr] | [INFO] [stderr] 110 | pub fn setNotFound(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `set_not_found` [INFO] [stderr] [INFO] [stderr] warning: method `setBadRequest` should have a snake case name [INFO] [stderr] --> src/http/response.rs:115:12 [INFO] [stderr] | [INFO] [stderr] 115 | pub fn setBadRequest(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_bad_request` [INFO] [stderr] [INFO] [stderr] warning: method `setNotAllowed` should have a snake case name [INFO] [stderr] --> src/http/response.rs:120:12 [INFO] [stderr] | [INFO] [stderr] 120 | pub fn setNotAllowed(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_not_allowed` [INFO] [stderr] [INFO] [stderr] warning: method `setDate` should have a snake case name [INFO] [stderr] --> src/http/response.rs:130:12 [INFO] [stderr] | [INFO] [stderr] 130 | pub fn setDate(&mut self) { [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_date` [INFO] [stderr] [INFO] [stderr] warning: method `setServer` should have a snake case name [INFO] [stderr] --> src/http/response.rs:135:12 [INFO] [stderr] | [INFO] [stderr] 135 | pub fn setServer(&mut self, server: &str) { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `set_server` [INFO] [stderr] [INFO] [stderr] warning: method `setConnection` should have a snake case name [INFO] [stderr] --> src/http/response.rs:139:12 [INFO] [stderr] | [INFO] [stderr] 139 | pub fn setConnection(&mut self, conn: &str) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_connection` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/server/server.rs:115:48 [INFO] [stderr] | [INFO] [stderr] 115 | fn handle_get(path: String, root: &String, isAutoIndex: bool) -> HTTPResponse { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/server/server.rs:138:49 [INFO] [stderr] | [INFO] [stderr] 138 | fn handle_head(path: String, root: &String, isAutoIndex: bool) -> HTTPResponse { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: 1 warning emitted [INFO] [stderr] [INFO] [stderr] warning: 65 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 1.71s [INFO] running `"docker" "inspect" "d3044f3d4c1688f3716873a8e6f1edb0fc34fde60b3acca2a1d36fe6cde12cee"` [INFO] running `"docker" "rm" "-f" "d3044f3d4c1688f3716873a8e6f1edb0fc34fde60b3acca2a1d36fe6cde12cee"` [INFO] [stdout] d3044f3d4c1688f3716873a8e6f1edb0fc34fde60b3acca2a1d36fe6cde12cee [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+1.44.0" "test" "--frozen"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] bbf01f39113ac71c68d7f4f4229801f1f6b8dccbaeea193a069ce0bb5486bf4c [INFO] running `"docker" "start" "-a" "bbf01f39113ac71c68d7f4f4229801f1f6b8dccbaeea193a069ce0bb5486bf4c"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] warning: unnecessary parentheses around type [INFO] [stderr] --> src/http/request.rs:20:43 [INFO] [stderr] | [INFO] [stderr] 20 | pub fn parse(buffer: &[u8]) -> Result<(HTTPRequest), ()> { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DateTime`, `NaiveDateTime`, `TimeZone` [INFO] [stderr] --> src/http/response.rs:10:14 [INFO] [stderr] | [INFO] [stderr] 10 | use chrono::{DateTime, TimeZone, NaiveDateTime, UTC}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::error::Error` [INFO] [stderr] --> src/config/config.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::error::Error; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fmt::Display` [INFO] [stderr] --> src/config/config.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::fmt::Display; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/config/config.rs:42:12 [INFO] [stderr] | [INFO] [stderr] 42 | if (document_root_pair.len() != 2) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/config/config.rs:51:12 [INFO] [stderr] | [INFO] [stderr] 51 | if (thread_limit_pair.len() != 2) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unused import: `HashMap` [INFO] [stderr] --> src/server/server.rs:8:24 [INFO] [stderr] | [INFO] [stderr] 8 | use std::collections::{HashMap}; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/server/server.rs:127:20 [INFO] [stderr] | [INFO] [stderr] 127 | if (isAutoIndex) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/server/server.rs:152:20 [INFO] [stderr] | [INFO] [stderr] 152 | if (isAutoIndex) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::thread` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::thread; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Task` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:3:42 [INFO] [stderr] | [INFO] [stderr] 3 | use crate::thread_pool::worker::{Worker, Task, Message}; [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/thread_pool/worker.rs:23:21 [INFO] [stderr] | [INFO] [stderr] 23 | pub type Task = Box; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnBox + Send + 'static` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `err` [INFO] [stderr] --> src/server/server.rs:126:17 [INFO] [stderr] | [INFO] [stderr] 126 | Err(err) => { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_err` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `TestCase` [INFO] [stderr] --> src/http/request_test.rs:4:8 [INFO] [stderr] | [INFO] [stderr] 4 | struct TestCase { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `TestCase` [INFO] [stderr] --> src/config/config_test.rs:3:8 [INFO] [stderr] | [INFO] [stderr] 3 | struct TestCase { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `test_invalid_format_thread_limit` [INFO] [stderr] --> src/config/config_test.rs:84:4 [INFO] [stderr] | [INFO] [stderr] 84 | fn test_invalid_format_thread_limit() { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `workers` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | workers: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/http/request.rs:8:9 [INFO] [stderr] | [INFO] [stderr] 8 | pub isAutoIndex: bool, [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable `stringRaw` should have a snake case name [INFO] [stderr] --> src/http/request.rs:21:13 [INFO] [stderr] | [INFO] [stderr] 21 | let stringRaw = std::str::from_utf8(buffer).unwrap(); [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `string_raw` [INFO] [stderr] [INFO] [stderr] warning: variable `firstLine` should have a snake case name [INFO] [stderr] --> src/http/request.rs:22:13 [INFO] [stderr] | [INFO] [stderr] 22 | let firstLine = stringRaw.split("\r\n").nth(0).unwrap(); [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `first_line` [INFO] [stderr] [INFO] [stderr] warning: variable `requestVec` should have a snake case name [INFO] [stderr] --> src/http/request.rs:28:13 [INFO] [stderr] | [INFO] [stderr] 28 | let requestVec: Vec<&str> = firstLine.split(" ").collect(); [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `request_vec` [INFO] [stderr] [INFO] [stderr] warning: variable `parsedPath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:34:14 [INFO] [stderr] | [INFO] [stderr] 34 | let (parsedPath, isAutoIndex) = match parsePath(requestVec[1]) { [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `parsed_path` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/http/request.rs:34:26 [INFO] [stderr] | [INFO] [stderr] 34 | let (parsedPath, isAutoIndex) = match parsePath(requestVec[1]) { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: function `parsePath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:52:4 [INFO] [stderr] | [INFO] [stderr] 52 | fn parsePath(path: &str) -> Result<(String, bool), ()> { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `parse_path` [INFO] [stderr] [INFO] [stderr] warning: variable `rawPath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:53:9 [INFO] [stderr] | [INFO] [stderr] 53 | let rawPath = path.split("?").nth(0).unwrap(); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `raw_path` [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/http/response.rs:55:29 [INFO] [stderr] | [INFO] [stderr] 55 | ... f.seek(SeekFrom::Start(n as u64)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: method `setContentType` should have a snake case name [INFO] [stderr] --> src/http/response.rs:65:12 [INFO] [stderr] | [INFO] [stderr] 65 | pub fn setContentType(&mut self, path: &Path) { [INFO] [stderr] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_content_type` [INFO] [stderr] [INFO] [stderr] warning: method `setContentLength` should have a snake case name [INFO] [stderr] --> src/http/response.rs:87:12 [INFO] [stderr] | [INFO] [stderr] 87 | pub fn setContentLength(&mut self, path: &Path) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_content_length` [INFO] [stderr] [INFO] [stderr] warning: method `setOk` should have a snake case name [INFO] [stderr] --> src/http/response.rs:101:12 [INFO] [stderr] | [INFO] [stderr] 101 | pub fn setOk(&mut self, file: Option) { [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `set_ok` [INFO] [stderr] [INFO] [stderr] warning: method `setNotFound` should have a snake case name [INFO] [stderr] --> src/http/response.rs:110:12 [INFO] [stderr] | [INFO] [stderr] 110 | pub fn setNotFound(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `set_not_found` [INFO] [stderr] [INFO] [stderr] warning: method `setBadRequest` should have a snake case name [INFO] [stderr] --> src/http/response.rs:115:12 [INFO] [stderr] | [INFO] [stderr] 115 | pub fn setBadRequest(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_bad_request` [INFO] [stderr] [INFO] [stderr] warning: method `setNotAllowed` should have a snake case name [INFO] [stderr] --> src/http/response.rs:120:12 [INFO] [stderr] | [INFO] [stderr] 120 | pub fn setNotAllowed(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_not_allowed` [INFO] [stderr] [INFO] [stderr] warning: method `setDate` should have a snake case name [INFO] [stderr] --> src/http/response.rs:130:12 [INFO] [stderr] | [INFO] [stderr] 130 | pub fn setDate(&mut self) { [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_date` [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around type [INFO] [stderr] --> src/http/request.rs:20:43 [INFO] [stderr] | [INFO] [stderr] 20 | pub fn parse(buffer: &[u8]) -> Result<(HTTPRequest), ()> { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DateTime`, `NaiveDateTime`, `TimeZone` [INFO] [stderr] --> src/http/response.rs:10:14 [INFO] [stderr] | [INFO] [stderr] 10 | use chrono::{DateTime, TimeZone, NaiveDateTime, UTC}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::error::Error` [INFO] [stderr] --> src/config/config.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::error::Error; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fmt::Display` [INFO] [stderr] --> src/config/config.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use std::fmt::Display; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/config/config.rs:42:12 [INFO] [stderr] | [INFO] [stderr] 42 | if (document_root_pair.len() != 2) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: method `setServer` should have a snake case name [INFO] [stderr] --> src/http/response.rs:135:12 [INFO] [stderr] | [INFO] [stderr] 135 | pub fn setServer(&mut self, server: &str) { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `set_server` [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/config/config.rs:51:12 [INFO] [stderr] | [INFO] [stderr] 51 | if (thread_limit_pair.len() != 2) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unused import: `HashMap` [INFO] [stderr] --> src/server/server.rs:8:24 [INFO] [stderr] | [INFO] [stderr] 8 | use std::collections::{HashMap}; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/server/server.rs:127:20 [INFO] [stderr] | [INFO] [stderr] 127 | if (isAutoIndex) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: method `setConnection` should have a snake case name [INFO] [stderr] --> src/http/response.rs:139:12 [INFO] [stderr] | [INFO] [stderr] 139 | pub fn setConnection(&mut self, conn: &str) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_connection` [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `if` condition [INFO] [stderr] --> src/server/server.rs:152:20 [INFO] [stderr] | [INFO] [stderr] 152 | if (isAutoIndex) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::thread` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::thread; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/server/server.rs:115:48 [INFO] [stderr] | [INFO] [stderr] 115 | fn handle_get(path: String, root: &String, isAutoIndex: bool) -> HTTPResponse { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: unused import: `Task` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:3:42 [INFO] [stderr] | [INFO] [stderr] 3 | use crate::thread_pool::worker::{Worker, Task, Message}; [INFO] [stderr] | ^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/thread_pool/worker.rs:23:21 [INFO] [stderr] | [INFO] [stderr] 23 | pub type Task = Box; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnBox + Send + 'static` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/server/server.rs:138:49 [INFO] [stderr] | [INFO] [stderr] 138 | fn handle_head(path: String, root: &String, isAutoIndex: bool) -> HTTPResponse { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: 37 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:16:9 [INFO] [stderr] | [INFO] [stderr] 16 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:29:9 [INFO] [stderr] | [INFO] [stderr] 29 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:42:9 [INFO] [stderr] | [INFO] [stderr] 42 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:55:9 [INFO] [stderr] | [INFO] [stderr] 55 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:68:9 [INFO] [stderr] | [INFO] [stderr] 68 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `req` [INFO] [stderr] --> src/http/request_test.rs:69:12 [INFO] [stderr] | [INFO] [stderr] 69 | Ok(req) => panic!("Unexpected header"), [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_req` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:81:9 [INFO] [stderr] | [INFO] [stderr] 81 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:94:9 [INFO] [stderr] | [INFO] [stderr] 94 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:107:9 [INFO] [stderr] | [INFO] [stderr] 107 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:121:9 [INFO] [stderr] | [INFO] [stderr] 121 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:134:9 [INFO] [stderr] | [INFO] [stderr] 134 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:148:9 [INFO] [stderr] | [INFO] [stderr] 148 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:161:9 [INFO] [stderr] | [INFO] [stderr] 161 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::env` [INFO] [stderr] --> src/main.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use std::env; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:174:9 [INFO] [stderr] | [INFO] [stderr] 174 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `req` [INFO] [stderr] --> src/http/request_test.rs:175:12 [INFO] [stderr] | [INFO] [stderr] 175 | Ok(req) => panic!("Unexpected OK"), [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_req` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `result` [INFO] [stderr] --> src/http/request_test.rs:187:9 [INFO] [stderr] | [INFO] [stderr] 187 | let result = match request::HTTPRequest::parse(testCase.raw_http) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `err` [INFO] [stderr] --> src/server/server.rs:126:17 [INFO] [stderr] | [INFO] [stderr] 126 | Err(err) => { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_err` [INFO] [stderr] [INFO] [stderr] warning: function is never used: `test_invalid_format_thread_limit` [INFO] [stderr] --> src/config/config_test.rs:84:4 [INFO] [stderr] | [INFO] [stderr] 84 | fn test_invalid_format_thread_limit() { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `workers` [INFO] [stderr] --> src/thread_pool/thread_pool.rs:7:5 [INFO] [stderr] | [INFO] [stderr] 7 | workers: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: 1 warning emitted [INFO] [stderr] [INFO] [stderr] warning: structure field `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/http/request.rs:8:9 [INFO] [stderr] | [INFO] [stderr] 8 | pub isAutoIndex: bool, [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable `stringRaw` should have a snake case name [INFO] [stderr] --> src/http/request.rs:21:13 [INFO] [stderr] | [INFO] [stderr] 21 | let stringRaw = std::str::from_utf8(buffer).unwrap(); [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `string_raw` [INFO] [stderr] [INFO] [stderr] warning: variable `firstLine` should have a snake case name [INFO] [stderr] --> src/http/request.rs:22:13 [INFO] [stderr] | [INFO] [stderr] 22 | let firstLine = stringRaw.split("\r\n").nth(0).unwrap(); [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `first_line` [INFO] [stderr] [INFO] [stderr] warning: variable `requestVec` should have a snake case name [INFO] [stderr] --> src/http/request.rs:28:13 [INFO] [stderr] | [INFO] [stderr] 28 | let requestVec: Vec<&str> = firstLine.split(" ").collect(); [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `request_vec` [INFO] [stderr] [INFO] [stderr] warning: variable `parsedPath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:34:14 [INFO] [stderr] | [INFO] [stderr] 34 | let (parsedPath, isAutoIndex) = match parsePath(requestVec[1]) { [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `parsed_path` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/http/request.rs:34:26 [INFO] [stderr] | [INFO] [stderr] 34 | let (parsedPath, isAutoIndex) = match parsePath(requestVec[1]) { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: function `parsePath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:52:4 [INFO] [stderr] | [INFO] [stderr] 52 | fn parsePath(path: &str) -> Result<(String, bool), ()> { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `parse_path` [INFO] [stderr] [INFO] [stderr] warning: variable `rawPath` should have a snake case name [INFO] [stderr] --> src/http/request.rs:53:9 [INFO] [stderr] | [INFO] [stderr] 53 | let rawPath = path.split("?").nth(0).unwrap(); [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `raw_path` [INFO] [stderr] [INFO] [stdout] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stdout] running 19 tests [INFO] [stderr] --> src/http/request_test.rs:11:9 [INFO] [stdout] test config::config_test::test_not_contains_document_root ... ok [INFO] [stderr] | [INFO] [stdout] test config::config_test::test_not_contains_thread_limit ... ok [INFO] [stderr] 11 | let testCase = TestCase{ [INFO] [stdout] test config::config_test::test_valid_config ... ok [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stdout] test config::config_test::test_valid_ok ... ok [INFO] [stderr] [INFO] [stdout] test config::config_test::test_invalid_format_document_root ... ok [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stdout] test http::request_test::url_encode_query_valid_path_parse ... ok [INFO] [stderr] --> src/http/request_test.rs:24:9 [INFO] [stdout] test http::request_test::url_encode_valid_path_parse ... ok [INFO] [stderr] | [INFO] [stdout] test http::request_test::valid_path_parse ... ok [INFO] [stderr] 24 | let testCase = TestCase{ [INFO] [stdout] test http::request_test::dot_escape_not_valid_path_parse ... ok [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:37:9 [INFO] [stderr] | [INFO] [stderr] 37 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:50:9 [INFO] [stderr] | [INFO] [stderr] 50 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:63:9 [INFO] [stderr] | [INFO] [stderr] 63 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:76:9 [INFO] [stderr] | [INFO] [stderr] 76 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:89:9 [INFO] [stderr] | [INFO] [stderr] 89 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:102:9 [INFO] [stderr] | [INFO] [stderr] 102 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:116:9 [INFO] [stderr] | [INFO] [stderr] 116 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:129:9 [INFO] [stderr] | [INFO] [stderr] 129 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:143:9 [INFO] [stderr] | [INFO] [stderr] 143 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:156:9 [INFO] [stderr] | [INFO] [stderr] 156 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:169:9 [INFO] [stderr] | [INFO] [stderr] 169 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: variable `testCase` should have a snake case name [INFO] [stderr] --> src/http/request_test.rs:182:9 [INFO] [stderr] | [INFO] [stderr] 182 | let testCase = TestCase{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to snake case: `test_case` [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/http/response.rs:55:29 [INFO] [stderr] | [INFO] [stderr] 55 | ... f.seek(SeekFrom::Start(n as u64)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: method `setContentType` should have a snake case name [INFO] [stderr] --> src/http/response.rs:65:12 [INFO] [stderr] | [INFO] [stderr] 65 | pub fn setContentType(&mut self, path: &Path) { [INFO] [stderr] | ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_content_type` [INFO] [stderr] [INFO] [stderr] warning: method `setContentLength` should have a snake case name [INFO] [stderr] --> src/http/response.rs:87:12 [INFO] [stderr] | [INFO] [stderr] 87 | pub fn setContentLength(&mut self, path: &Path) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_content_length` [INFO] [stderr] [INFO] [stderr] warning: method `setOk` should have a snake case name [INFO] [stderr] --> src/http/response.rs:101:12 [INFO] [stderr] | [INFO] [stderr] 101 | pub fn setOk(&mut self, file: Option) { [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `set_ok` [INFO] [stderr] [INFO] [stderr] warning: method `setNotFound` should have a snake case name [INFO] [stderr] --> src/http/response.rs:110:12 [INFO] [stderr] | [INFO] [stderr] 110 | pub fn setNotFound(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `set_not_found` [INFO] [stderr] [INFO] [stderr] warning: method `setBadRequest` should have a snake case name [INFO] [stderr] --> src/http/response.rs:115:12 [INFO] [stderr] | [INFO] [stderr] 115 | pub fn setBadRequest(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_bad_request` [INFO] [stderr] [INFO] [stderr] warning: method `setNotAllowed` should have a snake case name [INFO] [stderr] --> src/http/response.rs:120:12 [INFO] [stderr] | [INFO] [stderr] 120 | pub fn setNotAllowed(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_not_allowed` [INFO] [stderr] [INFO] [stderr] warning: method `setDate` should have a snake case name [INFO] [stderr] --> src/http/response.rs:130:12 [INFO] [stderr] | [INFO] [stderr] 130 | pub fn setDate(&mut self) { [INFO] [stderr] | ^^^^^^^ help: convert the identifier to snake case: `set_date` [INFO] [stderr] [INFO] [stderr] warning: method `setServer` should have a snake case name [INFO] [stderr] --> src/http/response.rs:135:12 [INFO] [stderr] | [INFO] [stderr] 135 | pub fn setServer(&mut self, server: &str) { [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `set_server` [INFO] [stderr] [INFO] [stderr] warning: method `setConnection` should have a snake case name [INFO] [stderr] --> src/http/response.rs:139:12 [INFO] [stderr] | [INFO] [stderr] 139 | pub fn setConnection(&mut self, conn: &str) { [INFO] [stderr] | ^^^^^^^^^^^^^ help: convert the identifier to snake case: `set_connection` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/server/server.rs:115:48 [INFO] [stderr] | [INFO] [stderr] 115 | fn handle_get(path: String, root: &String, isAutoIndex: bool) -> HTTPResponse { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: variable `isAutoIndex` should have a snake case name [INFO] [stderr] --> src/server/server.rs:138:49 [INFO] [stderr] | [INFO] [stderr] 138 | fn handle_head(path: String, root: &String, isAutoIndex: bool) -> HTTPResponse { [INFO] [stderr] | ^^^^^^^^^^^ help: convert the identifier to snake case: `is_auto_index` [INFO] [stderr] [INFO] [stderr] warning: 65 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.09s [INFO] [stderr] Running /opt/rustwide/target/debug/deps/dz1-26830f2e1906e173 [INFO] [stdout] test http::request_test::get_method_parse ... ok [INFO] [stdout] test http::request_test::file_with_dot_valid_path_parse ... ok [INFO] [stdout] test http::request_test::with_space_valid_path_parse ... ok [INFO] [stdout] test http::request_test::head_method_parse ... ok [INFO] [stdout] test http::request_test::index_valid_path_parse ... ok [INFO] [stdout] test http::request_test::test_auto_index_true ... ok [INFO] [stdout] test http::request_test::not_valid_method_parse ... ok [INFO] [stdout] test http::request_test::with_query_valid_path_parse ... ok [INFO] [stdout] test http::request_test::with_space_query_valid_path_parse ... ok [INFO] [stdout] test http::request_test::test_auto_index_false ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 19 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] [stderr] Running /opt/rustwide/target/debug/deps/dz1-4a47fcdc2f876525 [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 [INFO] [stdout] [INFO] [stderr] Doc-tests dz1 [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 [INFO] [stdout] [INFO] running `"docker" "inspect" "bbf01f39113ac71c68d7f4f4229801f1f6b8dccbaeea193a069ce0bb5486bf4c"` [INFO] running `"docker" "rm" "-f" "bbf01f39113ac71c68d7f4f4229801f1f6b8dccbaeea193a069ce0bb5486bf4c"` [INFO] [stdout] bbf01f39113ac71c68d7f4f4229801f1f6b8dccbaeea193a069ce0bb5486bf4c