[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] checking rustynik/auth_app against master#3aedcf06b73fc36feeebca3d579e1d2a6c40acc5 for pr-65819 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frustynik%2Fauth_app" "/workspace/builds/worker-13/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-13/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/rustynik/auth_app on toolchain 3aedcf06b73fc36feeebca3d579e1d2a6c40acc5 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+3aedcf06b73fc36feeebca3d579e1d2a6c40acc5" "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-13/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" "+3aedcf06b73fc36feeebca3d579e1d2a6c40acc5" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/jobserver:/tmp/crater-runner-fifo:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/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" "rustops/crates-build-env@sha256:c46a2d1a26fb48b37929c74ca49dd9409f2375a0a3bdb8fe07617f3ffccaa889" "/opt/rustwide/cargo-home/bin/cargo" "+3aedcf06b73fc36feeebca3d579e1d2a6c40acc5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 840e45a9ee53d4a3334fcbc32f70308e1f10961cf88aa542cfeae25822fe450d [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "840e45a9ee53d4a3334fcbc32f70308e1f10961cf88aa542cfeae25822fe450d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "840e45a9ee53d4a3334fcbc32f70308e1f10961cf88aa542cfeae25822fe450d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "840e45a9ee53d4a3334fcbc32f70308e1f10961cf88aa542cfeae25822fe450d", kill_on_drop: false }` [INFO] [stdout] 840e45a9ee53d4a3334fcbc32f70308e1f10961cf88aa542cfeae25822fe450d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/jobserver:/tmp/crater-runner-fifo:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-13/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" "RUSTUP_TOOLCHAIN=3aedcf06b73fc36feeebca3d579e1d2a6c40acc5" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "rustops/crates-build-env@sha256:c46a2d1a26fb48b37929c74ca49dd9409f2375a0a3bdb8fe07617f3ffccaa889" "/tmp/crater-runner-fifo/jobserver-crater-fwd" "/opt/rustwide/cargo-home/bin/cargo" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 048dc0b715c043f3d5cc7a5751f29b6dc91ce1f9496b19ca8e5691ff64e41342 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "048dc0b715c043f3d5cc7a5751f29b6dc91ce1f9496b19ca8e5691ff64e41342", kill_on_drop: false }` [INFO] [stderr] Checking byteorder v1.2.4 [INFO] [stderr] Checking futures v0.1.23 [INFO] [stderr] Compiling typenum v1.10.0 [INFO] [stderr] Compiling pkg-config v0.3.13 [INFO] [stderr] Compiling cc v1.0.18 [INFO] [stderr] Checking memoffset v0.2.1 [INFO] [stderr] Checking scopeguard v0.3.3 [INFO] [stderr] Checking byte-tools v0.2.0 [INFO] [stderr] Checking matches v0.1.7 [INFO] [stderr] Checking arrayref v0.3.4 [INFO] [stderr] Checking constant_time_eq v0.1.3 [INFO] [stderr] Compiling proc-macro2 v0.4.12 [INFO] [stderr] Compiling openssl v0.10.11 [INFO] [stderr] Checking fnv v1.0.6 [INFO] [stderr] Compiling httparse v1.3.2 [INFO] [stderr] Checking fallible-iterator v0.1.5 [INFO] [stderr] Compiling serde v1.0.71 [INFO] [stderr] Checking try-lock v0.2.2 [INFO] [stderr] Checking bitflags v1.0.3 [INFO] [stderr] Checking md5 v0.3.7 [INFO] [stderr] Compiling gcc v0.3.54 [INFO] [stderr] Checking indexmap v1.0.1 [INFO] [stderr] Compiling native-tls v0.2.1 [INFO] [stderr] Checking hex v0.2.0 [INFO] [stderr] Checking rustc-serialize v0.3.24 [INFO] [stderr] Checking rand v0.4.2 [INFO] [stderr] Checking memchr v1.0.2 [INFO] [stderr] Checking log v0.4.3 [INFO] [stderr] Checking crossbeam-utils v0.3.2 [INFO] [stderr] Checking socket2 v0.3.7 [INFO] [stderr] Checking tokio-executor v0.1.3 [INFO] [stderr] Checking unicode-bidi v0.3.4 [INFO] [stderr] Checking base64 v0.6.0 [INFO] [stderr] Checking block-buffer v0.3.3 [INFO] [stderr] Checking phf_shared v0.7.21 [INFO] [stderr] Checking bytes v0.4.9 [INFO] [stderr] Compiling openssl-sys v0.9.35 [INFO] [stderr] Checking futures-cpupool v0.1.8 [INFO] [stderr] Checking mio v0.6.15 [INFO] [stderr] Checking want v0.0.6 [INFO] [stderr] Checking tokio-timer v0.2.5 [INFO] [stderr] Checking rand v0.3.22 [INFO] [stderr] Checking uuid v0.6.5 [INFO] [stderr] Checking stringprep v0.1.2 [INFO] [stderr] Checking phf v0.7.21 [INFO] [stderr] Checking tokio-io v0.1.7 [INFO] [stderr] Checking http v0.1.10 [INFO] [stderr] Compiling rust-crypto v0.2.36 [INFO] [stderr] Checking generic-array v0.9.0 [INFO] [stderr] Checking crossbeam-epoch v0.4.3 [INFO] [stderr] Compiling quote v0.6.6 [INFO] [stderr] Checking digest v0.7.5 [INFO] [stderr] Checking tokio-reactor v0.1.3 [INFO] [stderr] Checking crypto-mac v0.5.2 [INFO] [stderr] Checking tokio-codec v0.1.0 [INFO] [stderr] Compiling syn v0.14.8 [INFO] [stderr] Checking sha2 v0.7.1 [INFO] [stderr] Checking crossbeam-deque v0.3.1 [INFO] [stderr] Checking hmac v0.5.0 [INFO] [stderr] Checking tokio-udp v0.1.1 [INFO] [stderr] Checking tokio-tcp v0.1.1 [INFO] [stderr] Checking tokio-threadpool v0.1.5 [INFO] [stderr] Checking postgres-protocol v0.3.2 [INFO] [stderr] Checking tokio-fs v0.1.3 [INFO] [stderr] Checking h2 v0.1.12 [INFO] [stderr] Checking tokio v0.1.7 [INFO] [stderr] Checking postgres-shared v0.4.1 [INFO] [stderr] Checking postgres v0.15.2 [INFO] [stderr] Checking serde_json v1.0.24 [INFO] [stderr] Checking hyper v0.12.8 [INFO] [stderr] Compiling serde_derive v1.0.71 [INFO] [stderr] Checking hyper-tls v0.3.0 [INFO] [stderr] Checking 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: 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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error=hyper::Error> + Send` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error=hyper::Error> + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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:235:38 [INFO] [stdout] | [INFO] [stdout] 235 | fn create_session(user: User) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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: 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: 25 warnings emitted [INFO] [stdout] [INFO] [stdout] [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: 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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error=hyper::Error> + Send` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error=hyper::Error> + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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:235:38 [INFO] [stdout] | [INFO] [stdout] 235 | fn create_session(user: User) -> Box + Send> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future + Send` [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: 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: 25 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 50.06s [INFO] running `Command { std: "docker" "inspect" "048dc0b715c043f3d5cc7a5751f29b6dc91ce1f9496b19ca8e5691ff64e41342", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "048dc0b715c043f3d5cc7a5751f29b6dc91ce1f9496b19ca8e5691ff64e41342", kill_on_drop: false }` [INFO] [stdout] 048dc0b715c043f3d5cc7a5751f29b6dc91ce1f9496b19ca8e5691ff64e41342