[INFO] updating cached repository https://github.com/maelstrom-rs/maelstrom [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "-c" "remote.origin.fetch=refs/heads/*:refs/heads/*" "fetch" "origin" "--force" "--prune", kill_on_drop: false }` [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 843a452a9a3c32216b367085c8c561afd54ada4f [INFO] testing maelstrom-rs/maelstrom against 1.45.2 for beta-1.46-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmaelstrom-rs%2Fmaelstrom" "/workspace/builds/worker-14/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-14/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/maelstrom-rs/maelstrom on toolchain 1.45.2 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.45.2" "read-manifest" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/maelstrom-rs/maelstrom [INFO] finished tweaking git repo https://github.com/maelstrom-rs/maelstrom [INFO] tweaked toml for git repo https://github.com/maelstrom-rs/maelstrom written to /workspace/builds/worker-14/source/Cargo.toml [INFO] crate git repo https://github.com/maelstrom-rs/maelstrom already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+1.45.2" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-14/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-14/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+1.45.2" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] a9bbf4c956688d9a1778e185167b37abfcbcca96bad143c060e3738a3ae352ce [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" "a9bbf4c956688d9a1778e185167b37abfcbcca96bad143c060e3738a3ae352ce", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "a9bbf4c956688d9a1778e185167b37abfcbcca96bad143c060e3738a3ae352ce", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "a9bbf4c956688d9a1778e185167b37abfcbcca96bad143c060e3738a3ae352ce", kill_on_drop: false }` [INFO] [stdout] a9bbf4c956688d9a1778e185167b37abfcbcca96bad143c060e3738a3ae352ce [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-14/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-14/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+1.45.2" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 2d099aaaebe69d67999db33a7a1346d44cd15fa5d9f7b46c6e2c18726de9f5b2 [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" "2d099aaaebe69d67999db33a7a1346d44cd15fa5d9f7b46c6e2c18726de9f5b2", kill_on_drop: false }` [INFO] [stderr] Compiling smallvec v1.3.0 [INFO] [stderr] Compiling base64 v0.12.0 [INFO] [stderr] Compiling bytestring v0.1.5 [INFO] [stderr] Compiling backtrace-sys v0.1.35 [INFO] [stderr] Compiling brotli-sys v0.3.2 [INFO] [stderr] Compiling yaml-rust v0.4.3 [INFO] [stderr] Compiling hostname v0.3.1 [INFO] [stderr] Compiling time v0.1.42 [INFO] [stderr] Compiling socket2 v0.3.12 [INFO] [stderr] Compiling ring v0.16.12 [INFO] [stderr] Compiling flate2 v1.0.14 [INFO] [stderr] Compiling lexical-core v0.6.2 [INFO] [stderr] Compiling digest v0.8.1 [INFO] [stderr] Compiling crypto-mac v0.7.0 [INFO] [stderr] Compiling openssl-sys v0.9.55 [INFO] [stderr] Compiling threadpool v1.7.1 [INFO] [stderr] Compiling synstructure v0.12.3 [INFO] [stderr] Compiling derive_more v0.99.5 [INFO] [stderr] Compiling pin-project-internal v0.4.9 [INFO] [stderr] Compiling actix-macros v0.1.1 [INFO] [stderr] Compiling enum-as-inner v0.3.2 [INFO] [stderr] Compiling async-trait v0.1.30 [INFO] [stderr] Compiling thiserror-impl v1.0.15 [INFO] [stderr] Compiling actix-web-codegen v0.2.1 [INFO] [stderr] Compiling actix_derive v0.5.0 [INFO] [stderr] Compiling resolv-conf v0.6.3 [INFO] [stderr] Compiling hmac v0.7.1 [INFO] [stderr] Compiling sha2 v0.8.1 [INFO] [stderr] Compiling md-5 v0.8.0 [INFO] [stderr] Compiling sha-1 v0.8.2 [INFO] [stderr] Compiling pem v0.7.0 [INFO] [stderr] Compiling ahash v0.3.2 [INFO] [stderr] Compiling futures-util v0.3.4 [INFO] [stderr] Compiling unicode-normalization v0.1.12 [INFO] [stderr] Compiling parking_lot_core v0.7.1 [INFO] [stderr] Compiling tokio v0.2.18 [INFO] [stderr] Compiling chrono v0.4.11 [INFO] [stderr] Compiling openssl v0.10.29 [INFO] [stderr] Compiling serde_json v1.0.51 [INFO] [stderr] Compiling actix-router v0.2.4 [INFO] [stderr] Compiling serde_test v1.0.106 [INFO] [stderr] Compiling uuid v0.8.1 [INFO] [stderr] Compiling ruma-identifiers v0.15.1 [INFO] [stderr] Compiling dashmap v3.11.0 [INFO] [stderr] Compiling parking_lot v0.10.2 [INFO] [stderr] Compiling idna v0.2.0 [INFO] [stderr] Compiling simple_asn1 v0.4.0 [INFO] [stderr] Compiling failure_derive v0.1.7 [INFO] [stderr] Compiling thiserror v1.0.15 [INFO] [stderr] Compiling backtrace v0.3.46 [INFO] [stderr] Compiling linear-map v1.2.0 [INFO] [stderr] Compiling jsonwebtoken v7.1.0 [INFO] [stderr] Compiling url v2.1.1 [INFO] [stderr] Compiling futures-executor v0.3.4 [INFO] [stderr] Compiling pin-project v0.4.9 [INFO] [stderr] Compiling native-tls v0.2.4 [INFO] [stderr] Compiling actix-service v1.0.5 [INFO] [stderr] Compiling serde_urlencoded v0.6.1 [INFO] [stderr] Compiling futures v0.3.4 [INFO] [stderr] Compiling nom v5.1.1 [INFO] [stderr] Compiling failure v0.1.7 [INFO] [stderr] Compiling brotli2 v0.3.2 [INFO] [stderr] Compiling actix-threadpool v0.3.1 [INFO] [stderr] Compiling tokio-util v0.2.0 [INFO] [stderr] Compiling trust-dns-proto v0.18.0-alpha.2 [INFO] [stderr] Compiling tokio-util v0.3.1 [INFO] [stderr] Compiling async-native-tls v0.3.3 [INFO] [stderr] Compiling actix-rt v1.1.0 [INFO] [stderr] Compiling sqlx-core v0.3.4 [INFO] [stderr] Compiling h2 v0.2.4 [INFO] [stderr] Compiling actix-codec v0.2.0 [INFO] [stderr] Compiling actix-utils v1.0.6 [INFO] [stderr] Compiling actix-server v1.0.2 [INFO] [stderr] Compiling actix-tls v1.0.0 [INFO] [stderr] Compiling config v0.10.1 [INFO] [stderr] Compiling actix-testing v1.0.0 [INFO] [stderr] Compiling trust-dns-resolver v0.18.0-alpha.2 [INFO] [stderr] Compiling sqlx-macros v0.3.4 [INFO] [stderr] Compiling actix-connect v1.0.2 [INFO] [stderr] Compiling actix-http v1.0.1 [INFO] [stderr] Compiling awc v1.0.1 [INFO] [stderr] Compiling actix v0.9.0 [INFO] [stderr] Compiling actix-web v2.0.0 [INFO] [stderr] Compiling sqlx v0.3.4 [INFO] [stderr] Compiling actix-ratelimit v0.2.1 [INFO] [stderr] Compiling actix-cors v0.2.0 [INFO] [stderr] Compiling maelstrom v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `actix_web::dev::Url` [INFO] [stdout] --> src/config/mod.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use actix_web::dev::Url; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::warn` [INFO] [stdout] --> src/config/mod.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use log::warn; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Serialize` [INFO] [stdout] --> src/config/mod.rs:9:26 [INFO] [stdout] | [INFO] [stdout] 9 | use serde::{Deserialize, Serialize}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> src/config/mod.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `InteractiveLoginFlow`, `LoginFlow`, `LoginType` [INFO] [stdout] --> src/server/mod.rs:8:27 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::models::auth::{InteractiveLoginFlow, LoginFlow, LoginType}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::json` [INFO] [stdout] --> src/server/handlers/admin.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use serde_json::json; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `jsonwebtoken as jwt` [INFO] [stdout] --> src/server/handlers/auth.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use jsonwebtoken as jwt; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DeviceId`, `UserId` [INFO] [stdout] --> src/server/handlers/auth.rs:9:24 [INFO] [stdout] | [INFO] [stdout] 9 | use ruma_identifiers::{DeviceId, UserId}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `PostgresStore` [INFO] [stdout] --> src/server/middleware/auth_checker.rs:9:27 [INFO] [stdout] | [INFO] [stdout] 9 | db::{mock::MockStore, PostgresStore, Store}, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ruma_identifiers::DeviceId` [INFO] [stdout] --> src/server/middleware/auth_checker.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | use ruma_identifiers::DeviceId; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/mock.rs:67:9 [INFO] [stdout] | [INFO] [stdout] 67 | user_id: &'a UserIdentifier, [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/mock.rs:82:9 [INFO] [stdout] | [INFO] [stdout] 82 | user_id: &UserId, [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `device_id` [INFO] [stdout] --> src/db/mock.rs:83:9 [INFO] [stdout] | [INFO] [stdout] 83 | device_id: &DeviceId, [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `device_id` [INFO] [stdout] --> src/db/mock.rs:90:38 [INFO] [stdout] | [INFO] [stdout] 90 | async fn remove_device_id(&self, device_id: &DeviceId, user_id: &UserId) -> Result<(), Error> { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/mock.rs:90:60 [INFO] [stdout] | [INFO] [stdout] 90 | async fn remove_device_id(&self, device_id: &DeviceId, user_id: &UserId) -> Result<(), Error> { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/mock.rs:96:43 [INFO] [stdout] | [INFO] [stdout] 96 | async fn remove_all_device_ids(&self, user_id: &UserId) -> Result<(), Error> { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/postgres.rs:66:9 [INFO] [stdout] | [INFO] [stdout] 66 | user_id: &'a UserIdentifier, [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/postgres.rs:71:41 [INFO] [stdout] | [INFO] [stdout] 71 | async fn fetch_password_hash(&self, user_id: &UserId) -> Result { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/postgres.rs:75:38 [INFO] [stdout] | [INFO] [stdout] 75 | async fn check_otp_exists(&self, user_id: &UserId, otp: &str) -> Result { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `otp` [INFO] [stdout] --> src/db/postgres.rs:75:56 [INFO] [stdout] | [INFO] [stdout] 75 | async fn check_otp_exists(&self, user_id: &UserId, otp: &str) -> Result { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_otp` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/postgres.rs:116:9 [INFO] [stdout] | [INFO] [stdout] 116 | user_id: &UserId, [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `device_id` [INFO] [stdout] --> src/db/postgres.rs:117:9 [INFO] [stdout] | [INFO] [stdout] 117 | device_id: &DeviceId, [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `display_name` [INFO] [stdout] --> src/db/postgres.rs:118:9 [INFO] [stdout] | [INFO] [stdout] 118 | display_name: Option<&str>, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_display_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `a` [INFO] [stdout] --> src/models/auth.rs:55:30 [INFO] [stdout] | [INFO] [stdout] 55 | .unwrap_or_else(|a| 0); [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `a` [INFO] [stdout] --> src/models/auth.rs:76:30 [INFO] [stdout] | [INFO] [stdout] 76 | .unwrap_or_else(|a| 0); [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `pw` [INFO] [stdout] --> src/models/auth.rs:359:27 [INFO] [stdout] | [INFO] [stdout] 359 | pub fn matches(&self, pw: &str) -> bool { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_pw` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `with_username_exists_resp` [INFO] [stdout] --> src/db/mock.rs:24:12 [INFO] [stdout] | [INFO] [stdout] 24 | pub fn with_username_exists_resp(self, resp: Result) -> MockStore { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `with_check_device_id_exists_resp` [INFO] [stdout] --> src/db/mock.rs:31:12 [INFO] [stdout] | [INFO] [stdout] 31 | pub fn with_check_device_id_exists_resp(self, resp: Result) -> MockStore { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `with_remove_device_id_resp` [INFO] [stdout] --> src/db/mock.rs:38:12 [INFO] [stdout] | [INFO] [stdout] 38 | pub fn with_remove_device_id_resp(self, resp: Result<(), Error>) -> MockStore { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `with_remove_all_device_ids_resp` [INFO] [stdout] --> src/db/mock.rs:45:12 [INFO] [stdout] | [INFO] [stdout] 45 | pub fn with_remove_all_device_ids_resp(self, resp: Result<(), Error>) -> MockStore { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `AuthFailed` [INFO] [stdout] --> src/db/mod.rs:93:5 [INFO] [stdout] | [INFO] [stdout] 93 | AuthFailed, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `DuplicateViolation` [INFO] [stdout] --> src/db/mod.rs:97:5 [INFO] [stdout] | [INFO] [stdout] 97 | DuplicateViolation, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `NullViolation` [INFO] [stdout] --> src/db/mod.rs:99:5 [INFO] [stdout] | [INFO] [stdout] 99 | NullViolation, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `Session` [INFO] [stdout] --> src/models/auth.rs:33:5 [INFO] [stdout] | [INFO] [stdout] 33 | Session, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `session` [INFO] [stdout] --> src/models/auth.rs:68:12 [INFO] [stdout] | [INFO] [stdout] 68 | pub fn session( [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `update` [INFO] [stdout] --> src/models/auth.rs:117:18 [INFO] [stdout] | [INFO] [stdout] 117 | pub async fn update( [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `is_complete` [INFO] [stdout] --> src/models/auth.rs:130:12 [INFO] [stdout] | [INFO] [stdout] 130 | pub fn is_complete(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `handle` [INFO] [stdout] --> src/models/auth.rs:173:18 [INFO] [stdout] | [INFO] [stdout] 173 | pub async fn handle(mut self, store: &T) -> Result<(), actix_web::Error> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `from_str` [INFO] [stdout] --> src/models/registration.rs:20:12 [INFO] [stdout] | [INFO] [stdout] 20 | pub fn from_str(kind: &str) -> Self { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `mock_store` [INFO] [stdout] --> src/server/middleware/auth_checker.rs:34:12 [INFO] [stdout] | [INFO] [stdout] 34 | pub fn mock_store() -> Self { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 40 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 2m 47s [INFO] running `Command { std: "docker" "inspect" "2d099aaaebe69d67999db33a7a1346d44cd15fa5d9f7b46c6e2c18726de9f5b2", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "2d099aaaebe69d67999db33a7a1346d44cd15fa5d9f7b46c6e2c18726de9f5b2", kill_on_drop: false }` [INFO] [stdout] 2d099aaaebe69d67999db33a7a1346d44cd15fa5d9f7b46c6e2c18726de9f5b2 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-14/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-14/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+1.45.2" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 32a11eb5da6c869706db5183a4a37cb3a444f2fcd96c99b1762930d90d700a6a [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" "32a11eb5da6c869706db5183a4a37cb3a444f2fcd96c99b1762930d90d700a6a", kill_on_drop: false }` [INFO] [stderr] Compiling maelstrom v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `actix_web::dev::Url` [INFO] [stdout] --> src/config/mod.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use actix_web::dev::Url; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::warn` [INFO] [stdout] --> src/config/mod.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use log::warn; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Serialize` [INFO] [stdout] --> src/config/mod.rs:9:26 [INFO] [stdout] | [INFO] [stdout] 9 | use serde::{Deserialize, Serialize}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::error::Error` [INFO] [stdout] --> src/config/mod.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use std::error::Error; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `InteractiveLoginFlow`, `LoginFlow`, `LoginType` [INFO] [stdout] --> src/server/mod.rs:8:27 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::models::auth::{InteractiveLoginFlow, LoginFlow, LoginType}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::json` [INFO] [stdout] --> src/server/handlers/admin.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use serde_json::json; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `jsonwebtoken as jwt` [INFO] [stdout] --> src/server/handlers/auth.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use jsonwebtoken as jwt; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DeviceId`, `UserId` [INFO] [stdout] --> src/server/handlers/auth.rs:9:24 [INFO] [stdout] | [INFO] [stdout] 9 | use ruma_identifiers::{DeviceId, UserId}; [INFO] [stdout] | ^^^^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `PostgresStore` [INFO] [stdout] --> src/server/middleware/auth_checker.rs:9:27 [INFO] [stdout] | [INFO] [stdout] 9 | db::{mock::MockStore, PostgresStore, Store}, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `ruma_identifiers::DeviceId` [INFO] [stdout] --> src/server/middleware/auth_checker.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | use ruma_identifiers::DeviceId; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/mock.rs:67:9 [INFO] [stdout] | [INFO] [stdout] 67 | user_id: &'a UserIdentifier, [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/mock.rs:82:9 [INFO] [stdout] | [INFO] [stdout] 82 | user_id: &UserId, [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `device_id` [INFO] [stdout] --> src/db/mock.rs:83:9 [INFO] [stdout] | [INFO] [stdout] 83 | device_id: &DeviceId, [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `device_id` [INFO] [stdout] --> src/db/mock.rs:90:38 [INFO] [stdout] | [INFO] [stdout] 90 | async fn remove_device_id(&self, device_id: &DeviceId, user_id: &UserId) -> Result<(), Error> { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/mock.rs:90:60 [INFO] [stdout] | [INFO] [stdout] 90 | async fn remove_device_id(&self, device_id: &DeviceId, user_id: &UserId) -> Result<(), Error> { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/mock.rs:96:43 [INFO] [stdout] | [INFO] [stdout] 96 | async fn remove_all_device_ids(&self, user_id: &UserId) -> Result<(), Error> { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/postgres.rs:66:9 [INFO] [stdout] | [INFO] [stdout] 66 | user_id: &'a UserIdentifier, [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/postgres.rs:71:41 [INFO] [stdout] | [INFO] [stdout] 71 | async fn fetch_password_hash(&self, user_id: &UserId) -> Result { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/postgres.rs:75:38 [INFO] [stdout] | [INFO] [stdout] 75 | async fn check_otp_exists(&self, user_id: &UserId, otp: &str) -> Result { [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `otp` [INFO] [stdout] --> src/db/postgres.rs:75:56 [INFO] [stdout] | [INFO] [stdout] 75 | async fn check_otp_exists(&self, user_id: &UserId, otp: &str) -> Result { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_otp` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `user_id` [INFO] [stdout] --> src/db/postgres.rs:116:9 [INFO] [stdout] | [INFO] [stdout] 116 | user_id: &UserId, [INFO] [stdout] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `device_id` [INFO] [stdout] --> src/db/postgres.rs:117:9 [INFO] [stdout] | [INFO] [stdout] 117 | device_id: &DeviceId, [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `display_name` [INFO] [stdout] --> src/db/postgres.rs:118:9 [INFO] [stdout] | [INFO] [stdout] 118 | display_name: Option<&str>, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_display_name` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `a` [INFO] [stdout] --> src/models/auth.rs:55:30 [INFO] [stdout] | [INFO] [stdout] 55 | .unwrap_or_else(|a| 0); [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `a` [INFO] [stdout] --> src/models/auth.rs:76:30 [INFO] [stdout] | [INFO] [stdout] 76 | .unwrap_or_else(|a| 0); [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `pw` [INFO] [stdout] --> src/models/auth.rs:359:27 [INFO] [stdout] | [INFO] [stdout] 359 | pub fn matches(&self, pw: &str) -> bool { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_pw` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `with_username_exists_resp` [INFO] [stdout] --> src/db/mock.rs:24:12 [INFO] [stdout] | [INFO] [stdout] 24 | pub fn with_username_exists_resp(self, resp: Result) -> MockStore { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `AuthFailed` [INFO] [stdout] --> src/db/mod.rs:93:5 [INFO] [stdout] | [INFO] [stdout] 93 | AuthFailed, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `DuplicateViolation` [INFO] [stdout] --> src/db/mod.rs:97:5 [INFO] [stdout] | [INFO] [stdout] 97 | DuplicateViolation, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `NullViolation` [INFO] [stdout] --> src/db/mod.rs:99:5 [INFO] [stdout] | [INFO] [stdout] 99 | NullViolation, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `Session` [INFO] [stdout] --> src/models/auth.rs:33:5 [INFO] [stdout] | [INFO] [stdout] 33 | Session, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `session` [INFO] [stdout] --> src/models/auth.rs:68:12 [INFO] [stdout] | [INFO] [stdout] 68 | pub fn session( [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `update` [INFO] [stdout] --> src/models/auth.rs:117:18 [INFO] [stdout] | [INFO] [stdout] 117 | pub async fn update( [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `is_complete` [INFO] [stdout] --> src/models/auth.rs:130:12 [INFO] [stdout] | [INFO] [stdout] 130 | pub fn is_complete(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `handle` [INFO] [stdout] --> src/models/auth.rs:173:18 [INFO] [stdout] | [INFO] [stdout] 173 | pub async fn handle(mut self, store: &T) -> Result<(), actix_web::Error> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 35 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 15.90s [INFO] running `Command { std: "docker" "inspect" "32a11eb5da6c869706db5183a4a37cb3a444f2fcd96c99b1762930d90d700a6a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "32a11eb5da6c869706db5183a4a37cb3a444f2fcd96c99b1762930d90d700a6a", kill_on_drop: false }` [INFO] [stdout] 32a11eb5da6c869706db5183a4a37cb3a444f2fcd96c99b1762930d90d700a6a [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-14/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-14/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env@sha256:a636fd89d022f18117e1dc8fb37a0a009933cdbbe082814857f0e2024962d47c" "/opt/rustwide/cargo-home/bin/cargo" "+1.45.2" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 0ccf6d0c646106142c52655513e8f4360db0790054c07c0d52f9674637f49865 [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" "0ccf6d0c646106142c52655513e8f4360db0790054c07c0d52f9674637f49865", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] warning: unused import: `actix_web::dev::Url` [INFO] [stderr] --> src/config/mod.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use actix_web::dev::Url; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `log::warn` [INFO] [stderr] --> src/config/mod.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | use log::warn; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Serialize` [INFO] [stderr] --> src/config/mod.rs:9:26 [INFO] [stderr] | [INFO] [stderr] 9 | use serde::{Deserialize, Serialize}; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::error::Error` [INFO] [stderr] --> src/config/mod.rs:11:5 [INFO] [stderr] | [INFO] [stderr] 11 | use std::error::Error; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `InteractiveLoginFlow`, `LoginFlow`, `LoginType` [INFO] [stderr] --> src/server/mod.rs:8:27 [INFO] [stderr] | [INFO] [stderr] 8 | use crate::models::auth::{InteractiveLoginFlow, LoginFlow, LoginType}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `serde_json::json` [INFO] [stderr] --> src/server/handlers/admin.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use serde_json::json; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `jsonwebtoken as jwt` [INFO] [stderr] --> src/server/handlers/auth.rs:8:5 [INFO] [stderr] | [INFO] [stderr] 8 | use jsonwebtoken as jwt; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DeviceId`, `UserId` [INFO] [stderr] --> src/server/handlers/auth.rs:9:24 [INFO] [stderr] | [INFO] [stderr] 9 | use ruma_identifiers::{DeviceId, UserId}; [INFO] [stderr] | ^^^^^^^^ ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `PostgresStore` [INFO] [stderr] --> src/server/middleware/auth_checker.rs:9:27 [INFO] [stderr] | [INFO] [stderr] 9 | db::{mock::MockStore, PostgresStore, Store}, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `ruma_identifiers::DeviceId` [INFO] [stderr] --> src/server/middleware/auth_checker.rs:13:5 [INFO] [stderr] | [INFO] [stderr] 13 | use ruma_identifiers::DeviceId; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `user_id` [INFO] [stderr] --> src/db/mock.rs:67:9 [INFO] [stderr] | [INFO] [stderr] 67 | user_id: &'a UserIdentifier, [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `user_id` [INFO] [stderr] --> src/db/mock.rs:82:9 [INFO] [stderr] | [INFO] [stderr] 82 | user_id: &UserId, [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `device_id` [INFO] [stderr] --> src/db/mock.rs:83:9 [INFO] [stderr] | [INFO] [stderr] 83 | device_id: &DeviceId, [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `device_id` [INFO] [stderr] --> src/db/mock.rs:90:38 [INFO] [stderr] | [INFO] [stderr] 90 | async fn remove_device_id(&self, device_id: &DeviceId, user_id: &UserId) -> Result<(), Error> { [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `user_id` [INFO] [stderr] --> src/db/mock.rs:90:60 [INFO] [stderr] | [INFO] [stderr] 90 | async fn remove_device_id(&self, device_id: &DeviceId, user_id: &UserId) -> Result<(), Error> { [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `user_id` [INFO] [stderr] --> src/db/mock.rs:96:43 [INFO] [stderr] | [INFO] [stderr] 96 | async fn remove_all_device_ids(&self, user_id: &UserId) -> Result<(), Error> { [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `user_id` [INFO] [stderr] --> src/db/postgres.rs:66:9 [INFO] [stderr] | [INFO] [stderr] 66 | user_id: &'a UserIdentifier, [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `user_id` [INFO] [stderr] --> src/db/postgres.rs:71:41 [INFO] [stderr] | [INFO] [stderr] 71 | async fn fetch_password_hash(&self, user_id: &UserId) -> Result { [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `user_id` [INFO] [stderr] --> src/db/postgres.rs:75:38 [INFO] [stderr] | [INFO] [stderr] 75 | async fn check_otp_exists(&self, user_id: &UserId, otp: &str) -> Result { [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `otp` [INFO] [stderr] --> src/db/postgres.rs:75:56 [INFO] [stderr] | [INFO] [stderr] 75 | async fn check_otp_exists(&self, user_id: &UserId, otp: &str) -> Result { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_otp` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `user_id` [INFO] [stderr] --> src/db/postgres.rs:116:9 [INFO] [stderr] | [INFO] [stderr] 116 | user_id: &UserId, [INFO] [stderr] | ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_user_id` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `device_id` [INFO] [stderr] --> src/db/postgres.rs:117:9 [INFO] [stderr] | [INFO] [stderr] 117 | device_id: &DeviceId, [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_device_id` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `display_name` [INFO] [stderr] --> src/db/postgres.rs:118:9 [INFO] [stderr] | [INFO] [stderr] 118 | display_name: Option<&str>, [INFO] [stderr] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_display_name` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `a` [INFO] [stderr] --> src/models/auth.rs:55:30 [INFO] [stderr] | [INFO] [stderr] 55 | .unwrap_or_else(|a| 0); [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `a` [INFO] [stderr] --> src/models/auth.rs:76:30 [INFO] [stderr] | [INFO] [stderr] 76 | .unwrap_or_else(|a| 0); [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `pw` [INFO] [stderr] --> src/models/auth.rs:359:27 [INFO] [stderr] | [INFO] [stderr] 359 | pub fn matches(&self, pw: &str) -> bool { [INFO] [stderr] | ^^ help: if this is intentional, prefix it with an underscore: `_pw` [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `with_username_exists_resp` [INFO] [stderr] --> src/db/mock.rs:24:12 [INFO] [stderr] | [INFO] [stderr] 24 | pub fn with_username_exists_resp(self, resp: Result) -> MockStore { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `AuthFailed` [INFO] [stderr] --> src/db/mod.rs:93:5 [INFO] [stderr] | [INFO] [stderr] 93 | AuthFailed, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `DuplicateViolation` [INFO] [stderr] --> src/db/mod.rs:97:5 [INFO] [stderr] | [INFO] [stderr] 97 | DuplicateViolation, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `NullViolation` [INFO] [stderr] --> src/db/mod.rs:99:5 [INFO] [stderr] | [INFO] [stderr] 99 | NullViolation, [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Session` [INFO] [stderr] --> src/models/auth.rs:33:5 [INFO] [stderr] | [INFO] [stderr] 33 | Session, [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `session` [INFO] [stderr] --> src/models/auth.rs:68:12 [INFO] [stderr] | [INFO] [stderr] 68 | pub fn session( [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `update` [INFO] [stderr] --> src/models/auth.rs:117:18 [INFO] [stderr] | [INFO] [stderr] 117 | pub async fn update( [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `is_complete` [INFO] [stderr] --> src/models/auth.rs:130:12 [INFO] [stderr] | [INFO] [stderr] 130 | pub fn is_complete(&self) -> bool { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `handle` [INFO] [stderr] --> src/models/auth.rs:173:18 [INFO] [stderr] | [INFO] [stderr] 173 | pub async fn handle(mut self, store: &T) -> Result<(), actix_web::Error> { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: 35 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.78s [INFO] [stderr] Running /opt/rustwide/target/debug/deps/maelstrom-8f3010ba41a10ffc [INFO] [stdout] [INFO] [stdout] running 19 tests [INFO] [stdout] test models::registration::tests::test_kind_from_str_user ... ok [INFO] [stdout] test models::registration::tests::test_kind_from_str_guest ... ok [INFO] [stdout] test models::registration::tests::test_kind_from_str_defaults_to_user ... ok [INFO] [stdout] test server::middleware::auth_checker::tests::test_no_auth_fails ... ok [INFO] [stdout] test server::handlers::admin::tests::test_get_wellknown_ok ... ok [INFO] [stdout] test server::handlers::admin::tests::test_versions_ok ... ok [INFO] [stdout] test models::registration::tests::test_check_username_valid_empty ... ok [INFO] [stdout] test models::registration::tests::test_check_username_valid_good ... ok [INFO] [stdout] test server::handlers::registration::tests::test_get_available_username_invalid ... ok [INFO] [stdout] test server::handlers::registration::tests::test_get_available_username_available ... ok [INFO] [stdout] test server::middleware::auth_checker::tests::test_query_string_auth_fails_empty_db ... ok [INFO] [stdout] test models::registration::tests::test_check_username_valid_bad ... ok [INFO] [stdout] test server::middleware::auth_checker::tests::test_incorrect_token_fails ... ok [INFO] [stdout] test server::handlers::auth::tests::test_logout_succeeds ... ok [INFO] [stdout] test server::handlers::auth::tests::test_logout_all_succeeds ... ok [INFO] [stdout] test server::handlers::registration::tests::test_get_available_username_taken ... ok [INFO] [stdout] test server::middleware::auth_checker::tests::test_header_auth_succeeds ... ok [INFO] [stdout] test server::handlers::account::tests::test_whoami_with_header_auth_succeeds ... ok [INFO] [stdout] test server::middleware::auth_checker::tests::test_query_string_auth_succeeds ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 19 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "0ccf6d0c646106142c52655513e8f4360db0790054c07c0d52f9674637f49865", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "0ccf6d0c646106142c52655513e8f4360db0790054c07c0d52f9674637f49865", kill_on_drop: false }` [INFO] [stdout] 0ccf6d0c646106142c52655513e8f4360db0790054c07c0d52f9674637f49865