[INFO] cloning repository https://github.com/iamlockon/Rapi [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/iamlockon/Rapi" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiamlockon%2FRapi", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiamlockon%2FRapi'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] aafde636e7d696f577f87809206789da282ea73e [INFO] checking iamlockon/Rapi against try#45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4 for pr-83744 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fiamlockon%2FRapi" "/workspace/builds/worker-3/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-3/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/iamlockon/Rapi on toolchain 45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/iamlockon/Rapi [INFO] finished tweaking git repo https://github.com/iamlockon/Rapi [INFO] tweaked toml for git repo https://github.com/iamlockon/Rapi written to /workspace/builds/worker-3/source/Cargo.toml [INFO] crate git repo https://github.com/iamlockon/Rapi already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/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:20528e8c29e4536546f0102ce88568b16ea7538393a33fcca951030f7af10457" "/opt/rustwide/cargo-home/bin/cargo" "+45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 77314b8eb92583cb8de4f9953f4323dceaf891f41036219635e92f802cc88e95 [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" "77314b8eb92583cb8de4f9953f4323dceaf891f41036219635e92f802cc88e95", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "77314b8eb92583cb8de4f9953f4323dceaf891f41036219635e92f802cc88e95", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "77314b8eb92583cb8de4f9953f4323dceaf891f41036219635e92f802cc88e95", kill_on_drop: false }` [INFO] [stdout] 77314b8eb92583cb8de4f9953f4323dceaf891f41036219635e92f802cc88e95 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "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:20528e8c29e4536546f0102ce88568b16ea7538393a33fcca951030f7af10457" "/opt/rustwide/cargo-home/bin/cargo" "+45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] b30488fd9c634cf4795fa36d52e2f52269b1ec4b94993864aa479e908eff1aa3 [INFO] running `Command { std: "docker" "start" "-a" "b30488fd9c634cf4795fa36d52e2f52269b1ec4b94993864aa479e908eff1aa3", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.68 [INFO] [stderr] Compiling memchr v2.3.3 [INFO] [stderr] Checking lazy_static v1.4.0 [INFO] [stderr] Compiling proc-macro-hack v0.5.14 [INFO] [stderr] Checking scopeguard v1.1.0 [INFO] [stderr] Compiling getrandom v0.1.14 [INFO] [stderr] Compiling bitflags v1.2.1 [INFO] [stderr] Compiling autocfg v0.1.7 [INFO] [stderr] Compiling serde v1.0.105 [INFO] [stderr] Checking rustc-demangle v0.1.16 [INFO] [stderr] Checking percent-encoding v2.1.0 [INFO] [stderr] Checking quick-error v1.2.3 [INFO] [stderr] Compiling byteorder v1.3.4 [INFO] [stderr] Checking base64 v0.11.0 [INFO] [stderr] Compiling syn v0.15.44 [INFO] [stderr] Compiling regex-syntax v0.6.17 [INFO] [stderr] Compiling num-traits v0.2.11 [INFO] [stderr] Compiling num-integer v0.1.42 [INFO] [stderr] Compiling indexmap v1.3.2 [INFO] [stderr] Checking http v0.2.1 [INFO] [stderr] Checking lock_api v0.3.3 [INFO] [stderr] Checking humantime v1.3.0 [INFO] [stderr] Checking thread_local v1.0.1 [INFO] [stderr] Checking log v0.4.8 [INFO] [stderr] Checking idna v0.2.0 [INFO] [stderr] Checking crc32fast v1.2.0 [INFO] [stderr] Checking encoding_rs v0.8.22 [INFO] [stderr] Compiling syn v1.0.17 [INFO] [stderr] Compiling rand_chacha v0.1.1 [INFO] [stderr] Compiling rand_pcg v0.1.2 [INFO] [stderr] Compiling rand v0.6.5 [INFO] [stderr] Checking aho-corasick v0.7.10 [INFO] [stderr] Checking fxhash v0.2.1 [INFO] [stderr] Checking url v2.1.1 [INFO] [stderr] Checking iovec v0.1.4 [INFO] [stderr] Checking net2 v0.2.33 [INFO] [stderr] Checking signal-hook-registry v1.2.0 [INFO] [stderr] Checking num_cpus v1.12.0 [INFO] [stderr] Checking parking_lot_core v0.7.0 [INFO] [stderr] Checking backtrace-sys v0.1.35 [INFO] [stderr] Checking hostname v0.3.1 [INFO] [stderr] Checking socket2 v0.3.11 [INFO] [stderr] Checking time v0.1.42 [INFO] [stderr] Checking brotli-sys v0.3.2 [INFO] [stderr] Checking flate2 v1.0.14 [INFO] [stderr] Checking rand_os v0.1.3 [INFO] [stderr] Checking atty v0.2.14 [INFO] [stderr] Checking listenfd v0.3.3 [INFO] [stderr] Checking threadpool v1.7.1 [INFO] [stderr] Checking backtrace v0.3.46 [INFO] [stderr] Checking resolv-conf v0.6.3 [INFO] [stderr] Checking rand_core v0.5.1 [INFO] [stderr] Checking parking_lot v0.10.0 [INFO] [stderr] Checking brotli2 v0.3.2 [INFO] [stderr] Checking mio v0.6.21 [INFO] [stderr] Checking regex v1.3.6 [INFO] [stderr] Checking chrono v0.4.11 [INFO] [stderr] Checking rand_chacha v0.2.2 [INFO] [stderr] Checking rand v0.7.3 [INFO] [stderr] Checking mio-uds v0.6.7 [INFO] [stderr] Checking tokio v0.2.13 [INFO] [stderr] Checking env_logger v0.7.1 [INFO] [stderr] Compiling derive_more v0.15.0 [INFO] [stderr] Checking tokio-util v0.2.0 [INFO] [stderr] Checking actix-codec v0.2.0 [INFO] [stderr] Compiling synstructure v0.12.3 [INFO] [stderr] Compiling futures-macro v0.3.4 [INFO] [stderr] Compiling derive_more v0.99.5 [INFO] [stderr] Compiling pin-project-internal v0.4.8 [INFO] [stderr] Compiling actix-macros v0.1.1 [INFO] [stderr] Compiling serde_derive v1.0.105 [INFO] [stderr] Compiling failure_derive v0.1.7 [INFO] [stderr] Compiling enum-as-inner v0.3.2 [INFO] [stderr] Compiling async-trait v0.1.27 [INFO] [stderr] Compiling actix-web-codegen v0.2.1 [INFO] [stderr] Checking failure v0.1.7 [INFO] [stderr] Checking futures-util v0.3.4 [INFO] [stderr] Checking pin-project v0.4.8 [INFO] [stderr] Checking futures-executor v0.3.4 [INFO] [stderr] Checking actix-service v1.0.5 [INFO] [stderr] Checking h2 v0.2.3 [INFO] [stderr] Checking futures v0.3.4 [INFO] [stderr] Checking trust-dns-proto v0.18.0-alpha.2 [INFO] [stderr] Checking actix-threadpool v0.3.1 [INFO] [stderr] Checking actix-rt v1.0.0 [INFO] [stderr] Checking actix-utils v1.0.6 [INFO] [stderr] Checking actix-server v1.0.2 [INFO] [stderr] Checking actix-tls v1.0.0 [INFO] [stderr] Checking trust-dns-resolver v0.18.0-alpha.2 [INFO] [stderr] Checking actix-testing v1.0.0 [INFO] [stderr] Checking actix-connect v1.0.2 [INFO] [stderr] Checking serde_urlencoded v0.6.1 [INFO] [stderr] Checking serde_json v1.0.50 [INFO] [stderr] Checking actix-router v0.2.4 [INFO] [stderr] Checking uuid v0.7.4 [INFO] [stderr] Checking actix-http v1.0.1 [INFO] [stderr] Checking awc v1.0.1 [INFO] [stderr] Checking actix-web v2.0.0 [INFO] [stderr] Checking api-rust v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `crate::config::error::UI` [INFO] [stdout] --> src/error.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::config::error::UI; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::config::error::UI` [INFO] [stdout] --> src/error.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use crate::config::error::UI; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `id` [INFO] [stdout] --> src/server/route/user.rs:9:3 [INFO] [stdout] | [INFO] [stdout] 9 | id: u32, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRINTERNAL` [INFO] [stdout] --> src/config/error.rs:2:3 [INFO] [stdout] | [INFO] [stdout] 2 | pub const ERRINTERNAL: &'static str = "An internal error occurred, please try again later."; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRVALIDFAIL` [INFO] [stdout] --> src/config/error.rs:3:3 [INFO] [stdout] | [INFO] [stdout] 3 | pub const ERRVALIDFAIL: &'static str = "Validation failed: {}"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRPERMDENIED` [INFO] [stdout] --> src/config/error.rs:4:3 [INFO] [stdout] | [INFO] [stdout] 4 | pub const ERRPERMDENIED: &'static str = "Permission denied."; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRAUTHFAIL` [INFO] [stdout] --> src/config/error.rs:5:3 [INFO] [stdout] | [INFO] [stdout] 5 | pub const ERRAUTHFAIL: &'static str = "Authorization failed."; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRTIMEOUT` [INFO] [stdout] --> src/config/error.rs:6:3 [INFO] [stdout] | [INFO] [stdout] 6 | pub const ERRTIMEOUT: &'static str = "Application timedout."; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRUNKNOWN` [INFO] [stdout] --> src/config/error.rs:10:3 [INFO] [stdout] | [INFO] [stdout] 10 | pub const ERRUNKNOWN: &'static str = "Unknown Error: {}"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRTIMEOUT` [INFO] [stdout] --> src/config/error.rs:11:3 [INFO] [stdout] | [INFO] [stdout] 11 | pub const ERRTIMEOUT: &'static str = "Timedout Error: {}"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `InternalError` [INFO] [stdout] --> src/error.rs:10:3 [INFO] [stdout] | [INFO] [stdout] 10 | InternalError, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `ValidationFailedError` [INFO] [stdout] --> src/error.rs:11:3 [INFO] [stdout] | [INFO] [stdout] 11 | ValidationFailedError [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `id` [INFO] [stdout] --> src/server/route/user.rs:9:3 [INFO] [stdout] | [INFO] [stdout] 9 | id: u32, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRINTERNAL` [INFO] [stdout] --> src/config/error.rs:2:3 [INFO] [stdout] | [INFO] [stdout] 2 | pub const ERRINTERNAL: &'static str = "An internal error occurred, please try again later."; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRVALIDFAIL` [INFO] [stdout] --> src/config/error.rs:3:3 [INFO] [stdout] | [INFO] [stdout] 3 | pub const ERRVALIDFAIL: &'static str = "Validation failed: {}"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRPERMDENIED` [INFO] [stdout] --> src/config/error.rs:4:3 [INFO] [stdout] | [INFO] [stdout] 4 | pub const ERRPERMDENIED: &'static str = "Permission denied."; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRAUTHFAIL` [INFO] [stdout] --> src/config/error.rs:5:3 [INFO] [stdout] | [INFO] [stdout] 5 | pub const ERRAUTHFAIL: &'static str = "Authorization failed."; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRTIMEOUT` [INFO] [stdout] --> src/config/error.rs:6:3 [INFO] [stdout] | [INFO] [stdout] 6 | pub const ERRTIMEOUT: &'static str = "Application timedout."; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRUNKNOWN` [INFO] [stdout] --> src/config/error.rs:10:3 [INFO] [stdout] | [INFO] [stdout] 10 | pub const ERRUNKNOWN: &'static str = "Unknown Error: {}"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant is never used: `ERRTIMEOUT` [INFO] [stdout] --> src/config/error.rs:11:3 [INFO] [stdout] | [INFO] [stdout] 11 | pub const ERRTIMEOUT: &'static str = "Timedout Error: {}"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `InternalError` [INFO] [stdout] --> src/error.rs:10:3 [INFO] [stdout] | [INFO] [stdout] 10 | InternalError, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `ValidationFailedError` [INFO] [stdout] --> src/error.rs:11:3 [INFO] [stdout] | [INFO] [stdout] 11 | ValidationFailedError [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: module `UI` should have a snake case name [INFO] [stdout] --> src/config/error.rs:1:9 [INFO] [stdout] | [INFO] [stdout] 1 | pub mod UI { /// User-facing errors [INFO] [stdout] | ^^ help: convert the identifier to snake case (notice the capitalization): `ui` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: module `SRV` should have a snake case name [INFO] [stdout] --> src/config/error.rs:9:9 [INFO] [stdout] | [INFO] [stdout] 9 | pub mod SRV { /// Dev-facing errors [INFO] [stdout] | ^^^ help: convert the identifier to snake case: `srv` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: module `UI` should have a snake case name [INFO] [stdout] --> src/config/error.rs:1:9 [INFO] [stdout] | [INFO] [stdout] 1 | pub mod UI { /// User-facing errors [INFO] [stdout] | ^^ help: convert the identifier to snake case (notice the capitalization): `ui` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: module `SRV` should have a snake case name [INFO] [stdout] --> src/config/error.rs:9:9 [INFO] [stdout] | [INFO] [stdout] 9 | pub mod SRV { /// Dev-facing errors [INFO] [stdout] | ^^^ help: convert the identifier to snake case: `srv` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 13 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 13 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 2m 28s [INFO] running `Command { std: "docker" "inspect" "b30488fd9c634cf4795fa36d52e2f52269b1ec4b94993864aa479e908eff1aa3", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "b30488fd9c634cf4795fa36d52e2f52269b1ec4b94993864aa479e908eff1aa3", kill_on_drop: false }` [INFO] [stdout] b30488fd9c634cf4795fa36d52e2f52269b1ec4b94993864aa479e908eff1aa3