[INFO] cloning repository https://github.com/rustynik/auth_app [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/rustynik/auth_app" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frustynik%2Fauth_app", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frustynik%2Fauth_app'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] f8f687cfa1bca7c62c4b1bfee049ef1f006df974 [INFO] testing rustynik/auth_app against 1.63.0 for beta-1.64-2 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frustynik%2Fauth_app" "/workspace/builds/worker-4/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-4/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/rustynik/auth_app on toolchain 1.63.0 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.63.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/rustynik/auth_app [INFO] finished tweaking git repo https://github.com/rustynik/auth_app [INFO] tweaked toml for git repo https://github.com/rustynik/auth_app written to /workspace/builds/worker-4/source/Cargo.toml [INFO] crate git repo https://github.com/rustynik/auth_app already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.63.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded md5 v0.3.7 [INFO] [stderr] Downloaded arrayref v0.3.4 [INFO] [stderr] Downloaded vcpkg v0.2.4 [INFO] [stderr] Downloaded postgres-shared v0.4.1 [INFO] [stderr] Downloaded proc-macro2 v0.4.12 [INFO] running `Command { std: "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" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:824c28ce115f6b999260af6986f3384c158e782489540e41c0b698ca1d9fd927" "/opt/rustwide/cargo-home/bin/cargo" "+1.63.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] c37d4b9f2b5cd9a35cd636fcad4aec74483a1936ef35a2c7e19f3e7f6a7aeca1 [INFO] running `Command { std: "docker" "start" "-a" "c37d4b9f2b5cd9a35cd636fcad4aec74483a1936ef35a2c7e19f3e7f6a7aeca1", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "c37d4b9f2b5cd9a35cd636fcad4aec74483a1936ef35a2c7e19f3e7f6a7aeca1", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c37d4b9f2b5cd9a35cd636fcad4aec74483a1936ef35a2c7e19f3e7f6a7aeca1", kill_on_drop: false }` [INFO] [stdout] c37d4b9f2b5cd9a35cd636fcad4aec74483a1936ef35a2c7e19f3e7f6a7aeca1 [INFO] running `Command { std: "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" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:824c28ce115f6b999260af6986f3384c158e782489540e41c0b698ca1d9fd927" "/opt/rustwide/cargo-home/bin/cargo" "+1.63.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 2044b04e54c3bc20d0ed81c867a2d71e742d4ef4d05c90632d65e59bb9f9a477 [INFO] running `Command { std: "docker" "start" "-a" "2044b04e54c3bc20d0ed81c867a2d71e742d4ef4d05c90632d65e59bb9f9a477", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.43 [INFO] [stderr] Compiling cfg-if v0.1.5 [INFO] [stderr] Compiling byteorder v1.2.4 [INFO] [stderr] Compiling futures v0.1.23 [INFO] [stderr] Compiling version_check v0.1.4 [INFO] [stderr] Compiling typenum v1.10.0 [INFO] [stderr] Compiling nodrop v0.1.12 [INFO] [stderr] Compiling slab v0.4.1 [INFO] [stderr] Compiling cc v1.0.18 [INFO] [stderr] Compiling pkg-config v0.3.13 [INFO] [stderr] Compiling lazycell v0.6.0 [INFO] [stderr] Compiling memoffset v0.2.1 [INFO] [stderr] Compiling scopeguard v0.3.3 [INFO] [stderr] Compiling proc-macro2 v0.4.12 [INFO] [stderr] Compiling itoa v0.4.2 [INFO] [stderr] Compiling byte-tools v0.2.0 [INFO] [stderr] Compiling matches v0.1.7 [INFO] [stderr] Compiling arrayref v0.3.4 [INFO] [stderr] Compiling constant_time_eq v0.1.3 [INFO] [stderr] Compiling httparse v1.3.2 [INFO] [stderr] Compiling fnv v1.0.6 [INFO] [stderr] Compiling unicode-normalization v0.1.7 [INFO] [stderr] Compiling fake-simd v0.1.2 [INFO] [stderr] Compiling safemem v0.2.0 [INFO] [stderr] Compiling unicode-xid v0.1.0 [INFO] [stderr] Compiling foreign-types-shared v0.1.1 [INFO] [stderr] Compiling openssl v0.10.11 [INFO] [stderr] Compiling siphasher v0.2.3 [INFO] [stderr] Compiling gcc v0.3.54 [INFO] [stderr] Compiling indexmap v1.0.1 [INFO] [stderr] Compiling string v0.1.1 [INFO] [stderr] Compiling native-tls v0.2.1 [INFO] [stderr] Compiling fallible-iterator v0.1.5 [INFO] [stderr] Compiling serde v1.0.71 [INFO] [stderr] Compiling bitflags v1.0.3 [INFO] [stderr] Compiling try-lock v0.2.2 [INFO] [stderr] Compiling md5 v0.3.7 [INFO] [stderr] Compiling openssl-probe v0.1.2 [INFO] [stderr] Compiling hex v0.2.0 [INFO] [stderr] Compiling rustc-serialize v0.3.24 [INFO] [stderr] Compiling dtoa v0.4.3 [INFO] [stderr] Compiling log v0.4.3 [INFO] [stderr] Compiling crossbeam-utils v0.3.2 [INFO] [stderr] Compiling arrayvec v0.4.7 [INFO] [stderr] Compiling lazy_static v1.1.0 [INFO] [stderr] Compiling unicode-bidi v0.3.4 [INFO] [stderr] Compiling iovec v0.1.2 [INFO] [stderr] Compiling rand v0.4.2 [INFO] [stderr] Compiling net2 v0.2.33 [INFO] [stderr] Compiling num_cpus v1.8.0 [INFO] [stderr] Compiling time v0.1.40 [INFO] [stderr] Compiling memchr v1.0.2 [INFO] [stderr] Compiling socket2 v0.3.7 [INFO] [stderr] Compiling block-buffer v0.3.3 [INFO] [stderr] Compiling base64 v0.6.0 [INFO] [stderr] Compiling foreign-types v0.3.2 [INFO] [stderr] Compiling phf_shared v0.7.21 [INFO] [stderr] Compiling tokio-executor v0.1.3 [INFO] [stderr] Compiling openssl-sys v0.9.35 [INFO] [stderr] Compiling want v0.0.6 [INFO] [stderr] Compiling bytes v0.4.9 [INFO] [stderr] Compiling stringprep v0.1.2 [INFO] [stderr] Compiling futures-cpupool v0.1.8 [INFO] [stderr] Compiling rust-crypto v0.2.36 [INFO] [stderr] Compiling mio v0.6.15 [INFO] [stderr] Compiling rand v0.3.22 [INFO] [stderr] Compiling uuid v0.6.5 [INFO] [stderr] Compiling phf v0.7.21 [INFO] [stderr] Compiling tokio-timer v0.2.5 [INFO] [stderr] Compiling tokio-io v0.1.7 [INFO] [stderr] Compiling http v0.1.10 [INFO] [stderr] Compiling quote v0.6.6 [INFO] [stderr] Compiling generic-array v0.9.0 [INFO] [stderr] Compiling crossbeam-epoch v0.4.3 [INFO] [stderr] Compiling syn v0.14.8 [INFO] [stderr] Compiling digest v0.7.5 [INFO] [stderr] Compiling crypto-mac v0.5.2 [INFO] [stderr] Compiling tokio-reactor v0.1.3 [INFO] [stderr] Compiling tokio-codec v0.1.0 [INFO] [stderr] Compiling crossbeam-deque v0.3.1 [INFO] [stderr] Compiling sha2 v0.7.1 [INFO] [stderr] Compiling hmac v0.5.0 [INFO] [stderr] Compiling tokio-tcp v0.1.1 [INFO] [stderr] Compiling tokio-udp v0.1.1 [INFO] [stderr] Compiling tokio-threadpool v0.1.5 [INFO] [stderr] Compiling postgres-protocol v0.3.2 [INFO] [stderr] Compiling postgres-shared v0.4.1 [INFO] [stderr] Compiling h2 v0.1.12 [INFO] [stderr] Compiling tokio-fs v0.1.3 [INFO] [stderr] Compiling postgres v0.15.2 [INFO] [stderr] Compiling tokio v0.1.7 [INFO] [stderr] Compiling serde_json v1.0.24 [INFO] [stderr] Compiling serde_derive v1.0.71 [INFO] [stderr] Compiling hyper v0.12.8 [INFO] [stderr] Compiling hyper-tls v0.3.0 [INFO] [stderr] Compiling auth_server v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `crypto::digest::Digest` [INFO] [stdout] --> src/main.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use crypto::digest::Digest; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `STANDARD`, `ToBase64` [INFO] [stdout] --> src/main.rs:14:25 [INFO] [stdout] | [INFO] [stdout] 14 | use serialize::base64::{STANDARD, ToBase64}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `uuid::Uuid` [INFO] [stdout] --> src/main.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use uuid::Uuid; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `params::ConnectParams` [INFO] [stdout] --> src/main.rs:16:37 [INFO] [stdout] | [INFO] [stdout] 16 | use postgres::{Connection, TlsMode, params::ConnectParams}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `hyper::Error` [INFO] [stdout] --> src/main.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | use hyper::Error; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `service::Service` [INFO] [stdout] --> src/main.rs:28:54 [INFO] [stdout] | [INFO] [stdout] 28 | use hyper::{Body, Request, Response, Server, Method, service::Service}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crypto::mac::MacResult` [INFO] [stdout] --> src/main.rs:216:9 [INFO] [stdout] | [INFO] [stdout] 216 | use crypto::mac::MacResult; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `STANDARD` [INFO] [stdout] --> src/main.rs:217:29 [INFO] [stdout] | [INFO] [stdout] 217 | use serialize::base64::{STANDARD, ToBase64, Config, CharacterSet, Newline}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:92:46 [INFO] [stdout] | [INFO] [stdout] 92 | fn error_to_response(error: AppError) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 92 - fn error_to_response(error: AppError) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] 92 + fn error_to_response(error: AppError) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:102:45 [INFO] [stdout] | [INFO] [stdout] 102 | fn handle_basic_login(body: Vec) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 102 - fn handle_basic_login(body: Vec) -> Box + Send> { [INFO] [stdout] 102 + fn handle_basic_login(body: Vec) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:108:42 [INFO] [stdout] | [INFO] [stdout] 108 | fn handle_fb_login(body: Vec) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 108 - fn handle_fb_login(body: Vec) -> Box + Send> { [INFO] [stdout] 108 + fn handle_fb_login(body: Vec) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:114:45 [INFO] [stdout] | [INFO] [stdout] 114 | fn authorize_fb(req: FBLoginRequest) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 114 - fn authorize_fb(req: FBLoginRequest) -> Box + Send> { [INFO] [stdout] 114 + fn authorize_fb(req: FBLoginRequest) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:184:46 [INFO] [stdout] | [INFO] [stdout] 184 | fn successful_login(session: Session) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 184 - fn successful_login(session: Session) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] 184 + fn successful_login(session: Session) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:196:51 [INFO] [stdout] | [INFO] [stdout] 196 | fn authorize_basic(req: BasicLoginRequest) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 196 - fn authorize_basic(req: BasicLoginRequest) -> Box + Send> { [INFO] [stdout] 196 + fn authorize_basic(req: BasicLoginRequest) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:202:59 [INFO] [stdout] | [INFO] [stdout] 202 | fn validate_password(user: User, password: String) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 202 - fn validate_password(user: User, password: String) -> Box + Send> { [INFO] [stdout] 202 + fn validate_password(user: User, password: String) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:235:38 [INFO] [stdout] | [INFO] [stdout] 235 | fn create_session(user: User) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 235 - fn create_session(user: User) -> Box + Send> { [INFO] [stdout] 235 + fn create_session(user: User) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:246:43 [INFO] [stdout] | [INFO] [stdout] 246 | fn find_user_by_email(email: &str) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 246 - fn find_user_by_email(email: &str) -> Box + Send> { [INFO] [stdout] 246 + fn find_user_by_email(email: &str) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated associated function `std::error::Error::description`: use the Display impl or to_string() [INFO] [stdout] --> src/main.rs:130:57 [INFO] [stdout] | [INFO] [stdout] 130 | Some(err) => println!("{}", err.description()), [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crypto::digest::Digest` [INFO] [stdout] --> src/main.rs:212:9 [INFO] [stdout] | [INFO] [stdout] 212 | use crypto::digest::Digest; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `err` [INFO] [stdout] --> src/main.rs:159:19 [INFO] [stdout] | [INFO] [stdout] 159 | .map_err(|err| AppError::ApplicationError) [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_err` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `error` [INFO] [stdout] --> src/main.rs:87:13 [INFO] [stdout] | [INFO] [stdout] 87 | fn from(error: AppError) -> Self { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `formatter` [INFO] [stdout] --> src/main.rs:299:19 [INFO] [stdout] | [INFO] [stdout] 299 | fn fmt(&self, formatter: &mut std::fmt::Formatter<'_>) -> Result<(), std::fmt::Error> { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_formatter` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/main.rs:220:13 [INFO] [stdout] | [INFO] [stdout] 220 | let mut sha = Sha256::new(); [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `email` is never read [INFO] [stdout] --> src/main.rs:310:5 [INFO] [stdout] | [INFO] [stdout] 308 | struct User { [INFO] [stdout] | ---- field in this struct [INFO] [stdout] 309 | pub id: String, [INFO] [stdout] 310 | pub email: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `upsertUser` should have a snake case name [INFO] [stdout] --> src/main.rs:170:4 [INFO] [stdout] | [INFO] [stdout] 170 | fn upsertUser(user: User) -> impl Future + Send { [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `upsert_user` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `statusCode` should have a snake case name [INFO] [stdout] --> src/main.rs:280:13 [INFO] [stdout] | [INFO] [stdout] 280 | fn from(statusCode: hyper::StatusCode) -> AppError { [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `status_code` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 26 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 1m 32s [INFO] running `Command { std: "docker" "inspect" "2044b04e54c3bc20d0ed81c867a2d71e742d4ef4d05c90632d65e59bb9f9a477", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "2044b04e54c3bc20d0ed81c867a2d71e742d4ef4d05c90632d65e59bb9f9a477", kill_on_drop: false }` [INFO] [stdout] 2044b04e54c3bc20d0ed81c867a2d71e742d4ef4d05c90632d65e59bb9f9a477 [INFO] running `Command { std: "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" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:824c28ce115f6b999260af6986f3384c158e782489540e41c0b698ca1d9fd927" "/opt/rustwide/cargo-home/bin/cargo" "+1.63.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] cd9aff18c57f64a7d97a6033d0a34ecd886e079337bd6f677a6d3d61ea9416cc [INFO] running `Command { std: "docker" "start" "-a" "cd9aff18c57f64a7d97a6033d0a34ecd886e079337bd6f677a6d3d61ea9416cc", kill_on_drop: false }` [INFO] [stderr] Compiling auth_server v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `crypto::digest::Digest` [INFO] [stdout] --> src/main.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 12 | use crypto::digest::Digest; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `STANDARD`, `ToBase64` [INFO] [stdout] --> src/main.rs:14:25 [INFO] [stdout] | [INFO] [stdout] 14 | use serialize::base64::{STANDARD, ToBase64}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `uuid::Uuid` [INFO] [stdout] --> src/main.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 15 | use uuid::Uuid; [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `params::ConnectParams` [INFO] [stdout] --> src/main.rs:16:37 [INFO] [stdout] | [INFO] [stdout] 16 | use postgres::{Connection, TlsMode, params::ConnectParams}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `hyper::Error` [INFO] [stdout] --> src/main.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 23 | use hyper::Error; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `service::Service` [INFO] [stdout] --> src/main.rs:28:54 [INFO] [stdout] | [INFO] [stdout] 28 | use hyper::{Body, Request, Response, Server, Method, service::Service}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crypto::mac::MacResult` [INFO] [stdout] --> src/main.rs:216:9 [INFO] [stdout] | [INFO] [stdout] 216 | use crypto::mac::MacResult; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `STANDARD` [INFO] [stdout] --> src/main.rs:217:29 [INFO] [stdout] | [INFO] [stdout] 217 | use serialize::base64::{STANDARD, ToBase64, Config, CharacterSet, Newline}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:92:46 [INFO] [stdout] | [INFO] [stdout] 92 | fn error_to_response(error: AppError) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 92 - fn error_to_response(error: AppError) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] 92 + fn error_to_response(error: AppError) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:102:45 [INFO] [stdout] | [INFO] [stdout] 102 | fn handle_basic_login(body: Vec) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 102 - fn handle_basic_login(body: Vec) -> Box + Send> { [INFO] [stdout] 102 + fn handle_basic_login(body: Vec) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:108:42 [INFO] [stdout] | [INFO] [stdout] 108 | fn handle_fb_login(body: Vec) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 108 - fn handle_fb_login(body: Vec) -> Box + Send> { [INFO] [stdout] 108 + fn handle_fb_login(body: Vec) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:114:45 [INFO] [stdout] | [INFO] [stdout] 114 | fn authorize_fb(req: FBLoginRequest) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 114 - fn authorize_fb(req: FBLoginRequest) -> Box + Send> { [INFO] [stdout] 114 + fn authorize_fb(req: FBLoginRequest) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:184:46 [INFO] [stdout] | [INFO] [stdout] 184 | fn successful_login(session: Session) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 184 - fn successful_login(session: Session) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] 184 + fn successful_login(session: Session) -> Box, Error=hyper::Error> + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:196:51 [INFO] [stdout] | [INFO] [stdout] 196 | fn authorize_basic(req: BasicLoginRequest) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 196 - fn authorize_basic(req: BasicLoginRequest) -> Box + Send> { [INFO] [stdout] 196 + fn authorize_basic(req: BasicLoginRequest) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:202:59 [INFO] [stdout] | [INFO] [stdout] 202 | fn validate_password(user: User, password: String) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 202 - fn validate_password(user: User, password: String) -> Box + Send> { [INFO] [stdout] 202 + fn validate_password(user: User, password: String) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:235:38 [INFO] [stdout] | [INFO] [stdout] 235 | fn create_session(user: User) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 235 - fn create_session(user: User) -> Box + Send> { [INFO] [stdout] 235 + fn create_session(user: User) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:246:43 [INFO] [stdout] | [INFO] [stdout] 246 | fn find_user_by_email(email: &str) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] help: use `dyn` [INFO] [stdout] | [INFO] [stdout] 246 - fn find_user_by_email(email: &str) -> Box + Send> { [INFO] [stdout] 246 + fn find_user_by_email(email: &str) -> Box + Send> { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated associated function `std::error::Error::description`: use the Display impl or to_string() [INFO] [stdout] --> src/main.rs:130:57 [INFO] [stdout] | [INFO] [stdout] 130 | Some(err) => println!("{}", err.description()), [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crypto::digest::Digest` [INFO] [stdout] --> src/main.rs:212:9 [INFO] [stdout] | [INFO] [stdout] 212 | use crypto::digest::Digest; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `err` [INFO] [stdout] --> src/main.rs:159:19 [INFO] [stdout] | [INFO] [stdout] 159 | .map_err(|err| AppError::ApplicationError) [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_err` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `error` [INFO] [stdout] --> src/main.rs:87:13 [INFO] [stdout] | [INFO] [stdout] 87 | fn from(error: AppError) -> Self { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `formatter` [INFO] [stdout] --> src/main.rs:299:19 [INFO] [stdout] | [INFO] [stdout] 299 | fn fmt(&self, formatter: &mut std::fmt::Formatter<'_>) -> Result<(), std::fmt::Error> { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_formatter` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/main.rs:220:13 [INFO] [stdout] | [INFO] [stdout] 220 | let mut sha = Sha256::new(); [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `email` is never read [INFO] [stdout] --> src/main.rs:310:5 [INFO] [stdout] | [INFO] [stdout] 308 | struct User { [INFO] [stdout] | ---- field in this struct [INFO] [stdout] 309 | pub id: String, [INFO] [stdout] 310 | pub email: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `upsertUser` should have a snake case name [INFO] [stdout] --> src/main.rs:170:4 [INFO] [stdout] | [INFO] [stdout] 170 | fn upsertUser(user: User) -> impl Future + Send { [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `upsert_user` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `statusCode` should have a snake case name [INFO] [stdout] --> src/main.rs:280:13 [INFO] [stdout] | [INFO] [stdout] 280 | fn from(statusCode: hyper::StatusCode) -> AppError { [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to snake case: `status_code` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 26 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 1.19s [INFO] running `Command { std: "docker" "inspect" "cd9aff18c57f64a7d97a6033d0a34ecd886e079337bd6f677a6d3d61ea9416cc", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "cd9aff18c57f64a7d97a6033d0a34ecd886e079337bd6f677a6d3d61ea9416cc", kill_on_drop: false }` [INFO] [stdout] cd9aff18c57f64a7d97a6033d0a34ecd886e079337bd6f677a6d3d61ea9416cc [INFO] running `Command { std: "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" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:824c28ce115f6b999260af6986f3384c158e782489540e41c0b698ca1d9fd927" "/opt/rustwide/cargo-home/bin/cargo" "+1.63.0" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] ad3fb217057431584e8328d455da512671fe46bff80f5aa0e342863b5ec16472 [INFO] running `Command { std: "docker" "start" "-a" "ad3fb217057431584e8328d455da512671fe46bff80f5aa0e342863b5ec16472", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `crypto::digest::Digest` [INFO] [stderr] --> src/main.rs:12:5 [INFO] [stderr] | [INFO] [stderr] 12 | use crypto::digest::Digest; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused imports: `STANDARD`, `ToBase64` [INFO] [stderr] --> src/main.rs:14:25 [INFO] [stderr] | [INFO] [stderr] 14 | use serialize::base64::{STANDARD, ToBase64}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `uuid::Uuid` [INFO] [stderr] --> src/main.rs:15:5 [INFO] [stderr] | [INFO] [stderr] 15 | use uuid::Uuid; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `params::ConnectParams` [INFO] [stderr] --> src/main.rs:16:37 [INFO] [stderr] | [INFO] [stderr] 16 | use postgres::{Connection, TlsMode, params::ConnectParams}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `hyper::Error` [INFO] [stderr] --> src/main.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | use hyper::Error; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `service::Service` [INFO] [stderr] --> src/main.rs:28:54 [INFO] [stderr] | [INFO] [stderr] 28 | use hyper::{Body, Request, Response, Server, Method, service::Service}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `crypto::mac::MacResult` [INFO] [stderr] --> src/main.rs:216:9 [INFO] [stderr] | [INFO] [stderr] 216 | use crypto::mac::MacResult; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `STANDARD` [INFO] [stderr] --> src/main.rs:217:29 [INFO] [stderr] | [INFO] [stderr] 217 | use serialize::base64::{STANDARD, ToBase64, Config, CharacterSet, Newline}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/main.rs:92:46 [INFO] [stderr] | [INFO] [stderr] 92 | fn error_to_response(error: AppError) -> Box, Error=hyper::Error> + Send> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 92 - fn error_to_response(error: AppError) -> Box, Error=hyper::Error> + Send> { [INFO] [stderr] 92 + fn error_to_response(error: AppError) -> Box, Error=hyper::Error> + Send> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/main.rs:102:45 [INFO] [stderr] | [INFO] [stderr] 102 | fn handle_basic_login(body: Vec) -> Box + Send> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 102 - fn handle_basic_login(body: Vec) -> Box + Send> { [INFO] [stderr] 102 + fn handle_basic_login(body: Vec) -> Box + Send> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/main.rs:108:42 [INFO] [stderr] | [INFO] [stderr] 108 | fn handle_fb_login(body: Vec) -> Box + Send> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 108 - fn handle_fb_login(body: Vec) -> Box + Send> { [INFO] [stderr] 108 + fn handle_fb_login(body: Vec) -> Box + Send> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/main.rs:114:45 [INFO] [stderr] | [INFO] [stderr] 114 | fn authorize_fb(req: FBLoginRequest) -> Box + Send> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 114 - fn authorize_fb(req: FBLoginRequest) -> Box + Send> { [INFO] [stderr] 114 + fn authorize_fb(req: FBLoginRequest) -> Box + Send> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/main.rs:184:46 [INFO] [stderr] | [INFO] [stderr] 184 | fn successful_login(session: Session) -> Box, Error=hyper::Error> + Send> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 184 - fn successful_login(session: Session) -> Box, Error=hyper::Error> + Send> { [INFO] [stderr] 184 + fn successful_login(session: Session) -> Box, Error=hyper::Error> + Send> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/main.rs:196:51 [INFO] [stderr] | [INFO] [stderr] 196 | fn authorize_basic(req: BasicLoginRequest) -> Box + Send> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 196 - fn authorize_basic(req: BasicLoginRequest) -> Box + Send> { [INFO] [stderr] 196 + fn authorize_basic(req: BasicLoginRequest) -> Box + Send> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/main.rs:202:59 [INFO] [stderr] | [INFO] [stderr] 202 | fn validate_password(user: User, password: String) -> Box + Send> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 202 - fn validate_password(user: User, password: String) -> Box + Send> { [INFO] [stderr] 202 + fn validate_password(user: User, password: String) -> Box + Send> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/main.rs:235:38 [INFO] [stderr] | [INFO] [stderr] 235 | fn create_session(user: User) -> Box + Send> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 235 - fn create_session(user: User) -> Box + Send> { [INFO] [stderr] 235 + fn create_session(user: User) -> Box + Send> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/main.rs:246:43 [INFO] [stderr] | [INFO] [stderr] 246 | fn find_user_by_email(email: &str) -> Box + Send> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021! [INFO] [stderr] = note: for more information, see [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 246 - fn find_user_by_email(email: &str) -> Box + Send> { [INFO] [stderr] 246 + fn find_user_by_email(email: &str) -> Box + Send> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: use of deprecated associated function `std::error::Error::description`: use the Display impl or to_string() [INFO] [stderr] --> src/main.rs:130:57 [INFO] [stderr] | [INFO] [stderr] 130 | Some(err) => println!("{}", err.description()), [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `crypto::digest::Digest` [INFO] [stderr] --> src/main.rs:212:9 [INFO] [stderr] | [INFO] [stderr] 212 | use crypto::digest::Digest; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `err` [INFO] [stderr] --> src/main.rs:159:19 [INFO] [stderr] | [INFO] [stderr] 159 | .map_err(|err| AppError::ApplicationError) [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: unused variable: `error` [INFO] [stderr] --> src/main.rs:87:13 [INFO] [stderr] | [INFO] [stderr] 87 | fn from(error: AppError) -> Self { [INFO] [stderr] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_error` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `formatter` [INFO] [stderr] --> src/main.rs:299:19 [INFO] [stderr] | [INFO] [stderr] 299 | fn fmt(&self, formatter: &mut std::fmt::Formatter<'_>) -> Result<(), std::fmt::Error> { [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_formatter` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/main.rs:220:13 [INFO] [stderr] | [INFO] [stderr] 220 | let mut sha = Sha256::new(); [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field `email` is never read [INFO] [stderr] --> src/main.rs:310:5 [INFO] [stderr] | [INFO] [stderr] 308 | struct User { [INFO] [stderr] | ---- field in this struct [INFO] [stderr] 309 | pub id: String, [INFO] [stderr] 310 | pub email: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: function `upsertUser` should have a snake case name [INFO] [stderr] --> src/main.rs:170:4 [INFO] [stderr] | [INFO] [stderr] 170 | fn upsertUser(user: User) -> impl Future + Send { [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `upsert_user` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable `statusCode` should have a snake case name [INFO] [stderr] --> src/main.rs:280:13 [INFO] [stderr] | [INFO] [stderr] 280 | fn from(statusCode: hyper::StatusCode) -> AppError { [INFO] [stderr] | ^^^^^^^^^^ help: convert the identifier to snake case: `status_code` [INFO] [stderr] [INFO] [stderr] warning: `auth_server` (bin "auth_server" test) generated 26 warnings [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.12s [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/auth_server-71adc218b481c398) [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "ad3fb217057431584e8328d455da512671fe46bff80f5aa0e342863b5ec16472", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "ad3fb217057431584e8328d455da512671fe46bff80f5aa0e342863b5ec16472", kill_on_drop: false }` [INFO] [stdout] ad3fb217057431584e8328d455da512671fe46bff80f5aa0e342863b5ec16472