[INFO] updating cached repository SinimaWath/highload_dz1 [INFO] running `"git" "fetch" "--all"` [INFO] [stdout] Fetching origin [INFO] [stderr] From git://github.com/SinimaWath/highload_dz1 [INFO] [stderr] * branch HEAD -> FETCH_HEAD [INFO] running `"git" "clone" "work/cache/sources/gh/SinimaWath/highload_dz1" "work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/gh/SinimaWath/highload_dz1"` [INFO] [stderr] Cloning into 'work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/gh/SinimaWath/highload_dz1'... [INFO] [stderr] done. [INFO] running `"git" "clone" "work/cache/sources/gh/SinimaWath/highload_dz1" "work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/gh/SinimaWath/highload_dz1"` [INFO] [stderr] Cloning into 'work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/gh/SinimaWath/highload_dz1'... [INFO] [stderr] done. [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 0d3216be68743aa955e35689193fa26eea7d8b0c [INFO] sha for GitHub repo SinimaWath/highload_dz1: 0d3216be68743aa955e35689193fa26eea7d8b0c [INFO] validating manifest of SinimaWath/highload_dz1 on toolchain master#60960a260f7b5c695fd0717311d72ce62dd4eb43 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of SinimaWath/highload_dz1 on toolchain try#266783e4e09e4e9d5307c1c8e695659c58bbcac7 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+266783e4e09e4e9d5307c1c8e695659c58bbcac7-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing SinimaWath/highload_dz1 [INFO] finished frobbing SinimaWath/highload_dz1 [INFO] frobbed toml for SinimaWath/highload_dz1 written to work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/gh/SinimaWath/highload_dz1/Cargo.toml [INFO] started frobbing SinimaWath/highload_dz1 [INFO] finished frobbing SinimaWath/highload_dz1 [INFO] frobbed toml for SinimaWath/highload_dz1 written to work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/gh/SinimaWath/highload_dz1/Cargo.toml [INFO] crate SinimaWath/highload_dz1 already has a lockfile, it will not be regenerated [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+266783e4e09e4e9d5307c1c8e695659c58bbcac7-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] checking SinimaWath/highload_dz1 against try#266783e4e09e4e9d5307c1c8e695659c58bbcac7 for pr-63376 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/pr-63376/worker-5/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/gh/SinimaWath/highload_dz1:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+266783e4e09e4e9d5307c1c8e695659c58bbcac7-alt" "check" "--frozen" "--all" "--all-targets"` [INFO] [stdout] d1d4bc9406185b0173f5fe1c41b0093f1403d54de5b23b64c5e6bfe40fc5157f [INFO] running `"docker" "start" "-a" "d1d4bc9406185b0173f5fe1c41b0093f1403d54de5b23b64c5e6bfe40fc5157f"` [INFO] [stderr] Checking chrono v0.3.0 [INFO] [stderr] Checking dz1 v0.1.0 (/opt/crater/workdir) [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] = note: `#[warn(unused_parens)]` on by default [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 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] = note: `#[warn(unused_parens)]` on by default [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: consider prefixing 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:1 [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:1 [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:1 [INFO] [stderr] | [INFO] [stderr] 84 | fn test_invalid_format_thread_limit() { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never used: `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: 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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: consider prefixing 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:1 [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 used: `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: 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 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] Finished dev [unoptimized + debuginfo] target(s) in 3.72s [INFO] running `"docker" "inspect" "d1d4bc9406185b0173f5fe1c41b0093f1403d54de5b23b64c5e6bfe40fc5157f"` [INFO] running `"docker" "rm" "-f" "d1d4bc9406185b0173f5fe1c41b0093f1403d54de5b23b64c5e6bfe40fc5157f"` [INFO] [stdout] d1d4bc9406185b0173f5fe1c41b0093f1403d54de5b23b64c5e6bfe40fc5157f