[INFO] cloning repository https://github.com/Zaki-1052/WebReg-Auto-Enroller [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Zaki-1052/WebReg-Auto-Enroller" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FZaki-1052%2FWebReg-Auto-Enroller", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FZaki-1052%2FWebReg-Auto-Enroller'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 478710f8e246157cbfc1945b08cc440887b40c30 [INFO] testing Zaki-1052/WebReg-Auto-Enroller against try#bd7d74411512a3dd3b35d2f699c51dd2557c7e7e+cargoflags=-Zbuild-dir-new-layout for pr-149852-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FZaki-1052%2FWebReg-Auto-Enroller" "/workspace/builds/worker-4-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/Zaki-1052/WebReg-Auto-Enroller [INFO] finished tweaking git repo https://github.com/Zaki-1052/WebReg-Auto-Enroller [INFO] tweaked toml for git repo https://github.com/Zaki-1052/WebReg-Auto-Enroller written to /workspace/builds/worker-4-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/Zaki-1052/WebReg-Auto-Enroller on toolchain bd7d74411512a3dd3b35d2f699c51dd2557c7e7e [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/Zaki-1052/WebReg-Auto-Enroller already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "fetch" "--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-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 760141c23d31496bd9c926fdafaad074c498bedd2c6373f5b623aab8b7899d97 [INFO] running `Command { std: "docker" "start" "-a" "760141c23d31496bd9c926fdafaad074c498bedd2c6373f5b623aab8b7899d97", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "760141c23d31496bd9c926fdafaad074c498bedd2c6373f5b623aab8b7899d97", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "760141c23d31496bd9c926fdafaad074c498bedd2c6373f5b623aab8b7899d97", kill_on_drop: false }` [INFO] [stdout] 760141c23d31496bd9c926fdafaad074c498bedd2c6373f5b623aab8b7899d97 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/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" "RUSTDOCFLAGS=--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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "build" "--frozen" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }` [INFO] [stdout] 5c36f227ea4db17da0008a8fb0d525f5794f78bddcb0de6b6819ff3798d2206e [INFO] running `Command { std: "docker" "start" "-a" "5c36f227ea4db17da0008a8fb0d525f5794f78bddcb0de6b6819ff3798d2206e", kill_on_drop: false }` [INFO] [stderr] Compiling typenum v1.19.0 [INFO] [stderr] Compiling smallvec v1.13.2 [INFO] [stderr] Compiling generic-array v0.14.9 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Compiling syn v2.0.96 [INFO] [stderr] Compiling getrandom v0.2.15 [INFO] [stderr] Compiling log v0.4.25 [INFO] [stderr] Compiling serde_json v1.0.135 [INFO] [stderr] Compiling byteorder v1.5.0 [INFO] [stderr] Compiling http v1.3.1 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling getrandom v0.3.4 [INFO] [stderr] Compiling nom v7.1.3 [INFO] [stderr] Compiling unicode-normalization v0.1.24 [INFO] [stderr] Compiling unicode_categories v0.1.1 [INFO] [stderr] Compiling rand_core v0.6.4 [INFO] [stderr] Compiling parking_lot_core v0.9.10 [INFO] [stderr] Compiling form_urlencoded v1.2.1 [INFO] [stderr] Compiling ahash v0.8.12 [INFO] [stderr] Compiling parking_lot v0.12.3 [INFO] [stderr] Compiling tokio v1.43.0 [INFO] [stderr] Compiling rustix v0.38.43 [INFO] [stderr] Compiling unicode-properties v0.1.4 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling futures-channel v0.3.31 [INFO] [stderr] Compiling hashbrown v0.14.5 [INFO] [stderr] Compiling dotenvy v0.15.7 [INFO] [stderr] Compiling futures-intrusive v0.5.0 [INFO] [stderr] Compiling uuid v1.18.1 [INFO] [stderr] Compiling stringprep v0.1.5 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling http-body v1.0.1 [INFO] [stderr] Compiling whoami v1.6.1 [INFO] [stderr] Compiling home v0.5.12 [INFO] [stderr] Compiling http-body-util v0.1.3 [INFO] [stderr] Compiling sync_wrapper v1.0.2 [INFO] [stderr] Compiling hashlink v0.8.4 [INFO] [stderr] Compiling base64 v0.21.7 [INFO] [stderr] Compiling thiserror v2.0.17 [INFO] [stderr] Compiling atoi v2.0.0 [INFO] [stderr] Compiling chrono v0.4.39 [INFO] [stderr] Compiling unicase v2.8.1 [INFO] [stderr] Compiling time-macros v0.2.24 [INFO] [stderr] Compiling heck v0.4.1 [INFO] [stderr] Compiling deranged v0.5.5 [INFO] [stderr] Compiling num-integer v0.1.46 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling mime_guess v2.0.5 [INFO] [stderr] Compiling multer v3.1.0 [INFO] [stderr] Compiling regex-automata v0.4.9 [INFO] [stderr] Compiling num-bigint v0.4.6 [INFO] [stderr] Compiling headers-core v0.3.0 [INFO] [stderr] Compiling match_cfg v0.1.0 [INFO] [stderr] Compiling winnow v0.5.40 [INFO] [stderr] Compiling block-buffer v0.10.4 [INFO] [stderr] Compiling crypto-common v0.1.6 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling sqlformat v0.2.6 [INFO] [stderr] Compiling sha2 v0.10.9 [INFO] [stderr] Compiling hmac v0.12.1 [INFO] [stderr] Compiling md-5 v0.10.6 [INFO] [stderr] Compiling inout v0.1.4 [INFO] [stderr] Compiling hkdf v0.12.4 [INFO] [stderr] Compiling tempfile v3.15.0 [INFO] [stderr] Compiling cipher v0.4.4 [INFO] [stderr] Compiling universal-hash v0.5.1 [INFO] [stderr] Compiling polyval v0.6.2 [INFO] [stderr] Compiling serde_path_to_error v0.1.20 [INFO] [stderr] Compiling sha1 v0.10.6 [INFO] [stderr] Compiling matchit v0.7.3 [INFO] [stderr] Compiling spin v0.9.8 [INFO] [stderr] Compiling headers v0.4.1 [INFO] [stderr] Compiling time v0.3.44 [INFO] [stderr] Compiling ghash v0.5.1 [INFO] [stderr] Compiling aes v0.8.4 [INFO] [stderr] Compiling ctr v0.9.2 [INFO] [stderr] Compiling aead v0.5.2 [INFO] [stderr] Compiling hostname v0.3.1 [INFO] [stderr] Compiling idna v0.3.0 [INFO] [stderr] Compiling email-encoding v0.2.1 [INFO] [stderr] Compiling pem v3.0.6 [INFO] [stderr] Compiling is-terminal v0.4.13 [INFO] [stderr] Compiling socket2 v0.4.10 [INFO] [stderr] Compiling email_address v0.2.9 [INFO] [stderr] Compiling humantime v2.1.0 [INFO] [stderr] Compiling http-range-header v0.4.2 [INFO] [stderr] Compiling quoted_printable v0.4.8 [INFO] [stderr] Compiling aes-gcm v0.10.3 [INFO] [stderr] Compiling dotenv v0.15.0 [INFO] [stderr] Compiling synstructure v0.13.1 [INFO] [stderr] Compiling regex v1.11.1 [INFO] [stderr] Compiling tokio-stream v0.1.17 [INFO] [stderr] Compiling zerofrom-derive v0.1.5 [INFO] [stderr] Compiling yoke-derive v0.7.5 [INFO] [stderr] Compiling zerovec-derive v0.10.3 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling tracing-attributes v0.1.30 [INFO] [stderr] Compiling icu_provider_macros v1.5.0 [INFO] [stderr] Compiling tokio-macros v2.5.0 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling zerocopy-derive v0.7.35 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling openssl v0.10.68 [INFO] [stderr] Compiling async-trait v0.1.85 [INFO] [stderr] Compiling thiserror-impl v2.0.17 [INFO] [stderr] Compiling pin-project-internal v1.1.8 [INFO] [stderr] Compiling env_logger v0.10.2 [INFO] [stderr] Compiling zerocopy v0.7.35 [INFO] [stderr] Compiling zerofrom v0.1.5 [INFO] [stderr] Compiling yoke v0.7.5 [INFO] [stderr] Compiling zerovec v0.10.4 [INFO] [stderr] Compiling tracing v0.1.41 [INFO] [stderr] Compiling ppv-lite86 v0.2.20 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Compiling tower v0.4.13 [INFO] [stderr] Compiling pin-project v1.1.8 [INFO] [stderr] Compiling simple_asn1 v0.6.3 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling rand v0.8.5 [INFO] [stderr] Compiling tinystr v0.7.6 [INFO] [stderr] Compiling icu_collections v1.5.0 [INFO] [stderr] Compiling icu_locid v1.5.0 [INFO] [stderr] Compiling either v1.15.0 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling serde_spanned v0.6.8 [INFO] [stderr] Compiling toml_datetime v0.6.8 [INFO] [stderr] Compiling toml_edit v0.19.15 [INFO] [stderr] Compiling icu_provider v1.5.0 [INFO] [stderr] Compiling axum-core v0.4.5 [INFO] [stderr] Compiling futures-executor v0.3.31 [INFO] [stderr] Compiling futures v0.3.31 [INFO] [stderr] Compiling icu_locid_transform v1.5.0 [INFO] [stderr] Compiling jsonwebtoken v9.3.1 [INFO] [stderr] Compiling native-tls v0.2.12 [INFO] [stderr] Compiling icu_properties v1.5.1 [INFO] [stderr] Compiling tokio-util v0.7.13 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling hyper v1.7.0 [INFO] [stderr] Compiling tower v0.5.2 [INFO] [stderr] Compiling tokio-retry v0.3.0 [INFO] [stderr] Compiling lettre v0.10.4 [INFO] [stderr] Compiling hyper-util v0.1.17 [INFO] [stderr] Compiling h2 v0.3.26 [INFO] [stderr] Compiling tower-http v0.5.2 [INFO] [stderr] Compiling toml v0.7.8 [INFO] [stderr] Compiling axum v0.7.9 [INFO] [stderr] Compiling icu_normalizer v1.5.0 [INFO] [stderr] Compiling idna_adapter v1.2.0 [INFO] [stderr] Compiling idna v1.0.3 [INFO] [stderr] Compiling url v2.5.4 [INFO] [stderr] Compiling sqlx-core v0.7.4 [INFO] [stderr] Compiling hyper v0.14.32 [INFO] [stderr] Compiling axum-extra v0.9.6 [INFO] [stderr] Compiling sqlx-postgres v0.7.4 [INFO] [stderr] Compiling hyper-tls v0.5.0 [INFO] [stderr] Compiling reqwest v0.11.27 [INFO] [stderr] Compiling webweg v0.9.2 [INFO] [stderr] Compiling sqlx-macros-core v0.7.4 [INFO] [stderr] Compiling sqlx-macros v0.7.4 [INFO] [stderr] Compiling sqlx v0.7.4 [INFO] [stderr] Compiling my_webreg_project v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/multi_user_state.rs:6:17 [INFO] [stdout] | [INFO] [stdout] 6 | use log::{info, error}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Deserialize` [INFO] [stdout] --> src/multi_user_api.rs:8:13 [INFO] [stdout] | [INFO] [stdout] 8 | use serde::{Deserialize, Serialize}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `log_file`, `stats_file`, `max_retries`, and `retry_delay` are never read [INFO] [stdout] --> src/config.rs:90:9 [INFO] [stdout] | [INFO] [stdout] 89 | pub struct MonitoringConfig { [INFO] [stdout] | ---------------- fields in this struct [INFO] [stdout] 90 | pub log_file: String, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 91 | pub stats_file: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 92 | pub cookie_refresh_interval: u64, [INFO] [stdout] 93 | pub max_retries: u32, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 94 | pub retry_delay: u64, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `MonitoringConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `update_stats` and `monitor_section_health` are never used [INFO] [stdout] --> src/state.rs:109:12 [INFO] [stdout] | [INFO] [stdout] 27 | impl AppState { [INFO] [stdout] | ------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 109 | pub fn update_stats(&mut self) { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 144 | pub async fn monitor_section_health( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `log_file`, `max_retries`, and `retry_delay` are never read [INFO] [stdout] --> src/config.rs:90:9 [INFO] [stdout] | [INFO] [stdout] 89 | pub struct MonitoringConfig { [INFO] [stdout] | ---------------- fields in this struct [INFO] [stdout] 90 | pub log_file: String, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 93 | pub max_retries: u32, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 94 | pub retry_delay: u64, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `MonitoringConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `monitor_section_health` is never used [INFO] [stdout] --> src/state.rs:144:18 [INFO] [stdout] | [INFO] [stdout] 27 | impl AppState { [INFO] [stdout] | ------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 144 | pub async fn monitor_section_health( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::::from_slice`: please upgrade to generic-array 1.x [INFO] [stdout] --> src/encryption.rs:43:28 [INFO] [stdout] | [INFO] [stdout] 43 | let nonce = Nonce::from_slice(&nonce_bytes); [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::::from_slice`: please upgrade to generic-array 1.x [INFO] [stdout] --> src/encryption.rs:68:28 [INFO] [stdout] | [INFO] [stdout] 68 | let nonce = Nonce::from_slice(&nonce_bytes); [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `CONFIG_PATH` is never used [INFO] [stdout] --> src/config.rs:6:11 [INFO] [stdout] | [INFO] [stdout] 6 | pub const CONFIG_PATH: &str = "config.toml"; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AppConfig` is never constructed [INFO] [stdout] --> src/config.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct AppConfig { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `WebRegConfig` is never constructed [INFO] [stdout] --> src/config.rs:17:12 [INFO] [stdout] | [INFO] [stdout] 17 | pub struct WebRegConfig { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `CourseConfig` is never constructed [INFO] [stdout] --> src/config.rs:32:12 [INFO] [stdout] | [INFO] [stdout] 32 | pub struct CourseConfig { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `CourseDetails` is never used [INFO] [stdout] --> src/config.rs:39:10 [INFO] [stdout] | [INFO] [stdout] 39 | pub enum CourseDetails { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `NewCourseDetails` is never constructed [INFO] [stdout] --> src/config.rs:45:12 [INFO] [stdout] | [INFO] [stdout] 45 | pub struct NewCourseDetails { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `LegacyCourseDetails` is never constructed [INFO] [stdout] --> src/config.rs:52:12 [INFO] [stdout] | [INFO] [stdout] 52 | pub struct LegacyCourseDetails { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `department` and `course_code` are never used [INFO] [stdout] --> src/config.rs:60:12 [INFO] [stdout] | [INFO] [stdout] 59 | impl CourseDetails { [INFO] [stdout] | ------------------ methods in this implementation [INFO] [stdout] 60 | pub fn department(&self) -> &str { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 67 | pub fn course_code(&self) -> &str { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `to_section_groups` is never used [INFO] [stdout] --> src/config.rs:75:8 [INFO] [stdout] | [INFO] [stdout] 75 | pub fn to_section_groups(course: &LegacyCourseDetails) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `SectionGroup` is never constructed [INFO] [stdout] --> src/config.rs:83:12 [INFO] [stdout] | [INFO] [stdout] 83 | pub struct SectionGroup { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MonitoringConfig` is never constructed [INFO] [stdout] --> src/config.rs:89:12 [INFO] [stdout] | [INFO] [stdout] 89 | pub struct MonitoringConfig { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `default_seat_threshold` is never used [INFO] [stdout] --> src/config.rs:99:4 [INFO] [stdout] | [INFO] [stdout] 99 | fn default_seat_threshold() -> i64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `HealthStatus` is never constructed [INFO] [stdout] --> src/stats.rs:62:12 [INFO] [stdout] | [INFO] [stdout] 62 | pub struct HealthStatus { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `format_duration` is never used [INFO] [stdout] --> src/utils.rs:32:8 [INFO] [stdout] | [INFO] [stdout] 32 | pub fn format_duration(duration: Duration) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `initialize_webreg` is never used [INFO] [stdout] --> src/webreg.rs:6:14 [INFO] [stdout] | [INFO] [stdout] 6 | pub async fn initialize_webreg(config: &WebRegConfig) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_connection_valid` is never used [INFO] [stdout] --> src/webreg.rs:29:14 [INFO] [stdout] | [INFO] [stdout] 29 | pub async fn is_connection_valid(wrapper: &WebRegWrapper, term: &str) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_user_by_id` is never used [INFO] [stdout] --> src/db.rs:59:14 [INFO] [stdout] | [INFO] [stdout] 59 | pub async fn get_user_by_id( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_all_active_jobs` is never used [INFO] [stdout] --> src/db.rs:191:14 [INFO] [stdout] | [INFO] [stdout] 191 | pub async fn get_all_active_jobs( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `generate` is never used [INFO] [stdout] --> src/encryption.rs:34:12 [INFO] [stdout] | [INFO] [stdout] 13 | impl EncryptionKey { [INFO] [stdout] | ------------------ associated function in this implementation [INFO] [stdout] ... [INFO] [stdout] 34 | pub fn generate() -> String { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `verify_clerk_session` is never used [INFO] [stdout] --> src/auth.rs:113:14 [INFO] [stdout] | [INFO] [stdout] 113 | pub async fn verify_clerk_session(session_token: &str) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `user_id` and `start_time` are never read [INFO] [stdout] --> src/multi_user_state.rs:22:9 [INFO] [stdout] | [INFO] [stdout] 20 | pub struct UserJob { [INFO] [stdout] | ------- fields in this struct [INFO] [stdout] 21 | pub job_id: Uuid, [INFO] [stdout] 22 | pub user_id: Uuid, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 33 | pub start_time: SystemTime, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `is_running`, `is_connected`, `last_check_time`, and `stats` are never read [INFO] [stdout] --> src/multi_user_state.rs:409:9 [INFO] [stdout] | [INFO] [stdout] 408 | pub struct JobStatusInfo { [INFO] [stdout] | ------------- fields in this struct [INFO] [stdout] 409 | pub is_running: bool, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 410 | pub is_connected: bool, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 411 | pub last_check_time: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] 412 | pub stats: EnrollmentStats, [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `JobStatusInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `error` is never used [INFO] [stdout] --> src/multi_user_api.rs:45:12 [INFO] [stdout] | [INFO] [stdout] 36 | impl ApiResponse { [INFO] [stdout] | ---------------------- associated function in this implementation [INFO] [stdout] ... [INFO] [stdout] 45 | pub fn error(error: String) -> Self { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 59s [INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: sqlx-postgres v0.7.4 [INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2` [INFO] running `Command { std: "docker" "inspect" "5c36f227ea4db17da0008a8fb0d525f5794f78bddcb0de6b6819ff3798d2206e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5c36f227ea4db17da0008a8fb0d525f5794f78bddcb0de6b6819ff3798d2206e", kill_on_drop: false }` [INFO] [stdout] 5c36f227ea4db17da0008a8fb0d525f5794f78bddcb0de6b6819ff3798d2206e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/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" "RUSTDOCFLAGS=--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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "--no-run" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }` [INFO] [stdout] cd8705bbebf533f8302136d2426a103ca8e225c0a466e62b071daddf2ef79495 [INFO] running `Command { std: "docker" "start" "-a" "cd8705bbebf533f8302136d2426a103ca8e225c0a466e62b071daddf2ef79495", kill_on_drop: false }` [INFO] [stderr] Compiling my_webreg_project v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `error` [INFO] [stdout] --> src/multi_user_state.rs:6:17 [INFO] [stdout] | [INFO] [stdout] 6 | use log::{info, error}; [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Deserialize` [INFO] [stdout] --> src/multi_user_api.rs:8:13 [INFO] [stdout] | [INFO] [stdout] 8 | use serde::{Deserialize, Serialize}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `log_file`, `max_retries`, and `retry_delay` are never read [INFO] [stdout] --> src/config.rs:90:9 [INFO] [stdout] | [INFO] [stdout] 89 | pub struct MonitoringConfig { [INFO] [stdout] | ---------------- fields in this struct [INFO] [stdout] 90 | pub log_file: String, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 93 | pub max_retries: u32, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 94 | pub retry_delay: u64, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `MonitoringConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `monitor_section_health` is never used [INFO] [stdout] --> src/state.rs:144:18 [INFO] [stdout] | [INFO] [stdout] 27 | impl AppState { [INFO] [stdout] | ------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 144 | pub async fn monitor_section_health( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `log_file`, `stats_file`, `max_retries`, and `retry_delay` are never read [INFO] [stdout] --> src/config.rs:90:9 [INFO] [stdout] | [INFO] [stdout] 89 | pub struct MonitoringConfig { [INFO] [stdout] | ---------------- fields in this struct [INFO] [stdout] 90 | pub log_file: String, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 91 | pub stats_file: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 92 | pub cookie_refresh_interval: u64, [INFO] [stdout] 93 | pub max_retries: u32, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 94 | pub retry_delay: u64, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `MonitoringConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `update_stats` and `monitor_section_health` are never used [INFO] [stdout] --> src/state.rs:109:12 [INFO] [stdout] | [INFO] [stdout] 27 | impl AppState { [INFO] [stdout] | ------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 109 | pub fn update_stats(&mut self) { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 144 | pub async fn monitor_section_health( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::::from_slice`: please upgrade to generic-array 1.x [INFO] [stdout] --> src/encryption.rs:43:28 [INFO] [stdout] | [INFO] [stdout] 43 | let nonce = Nonce::from_slice(&nonce_bytes); [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::::from_slice`: please upgrade to generic-array 1.x [INFO] [stdout] --> src/encryption.rs:68:28 [INFO] [stdout] | [INFO] [stdout] 68 | let nonce = Nonce::from_slice(&nonce_bytes); [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `CONFIG_PATH` is never used [INFO] [stdout] --> src/config.rs:6:11 [INFO] [stdout] | [INFO] [stdout] 6 | pub const CONFIG_PATH: &str = "config.toml"; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AppConfig` is never constructed [INFO] [stdout] --> src/config.rs:9:12 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct AppConfig { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `WebRegConfig` is never constructed [INFO] [stdout] --> src/config.rs:17:12 [INFO] [stdout] | [INFO] [stdout] 17 | pub struct WebRegConfig { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `CourseConfig` is never constructed [INFO] [stdout] --> src/config.rs:32:12 [INFO] [stdout] | [INFO] [stdout] 32 | pub struct CourseConfig { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `CourseDetails` is never used [INFO] [stdout] --> src/config.rs:39:10 [INFO] [stdout] | [INFO] [stdout] 39 | pub enum CourseDetails { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `NewCourseDetails` is never constructed [INFO] [stdout] --> src/config.rs:45:12 [INFO] [stdout] | [INFO] [stdout] 45 | pub struct NewCourseDetails { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `LegacyCourseDetails` is never constructed [INFO] [stdout] --> src/config.rs:52:12 [INFO] [stdout] | [INFO] [stdout] 52 | pub struct LegacyCourseDetails { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `department` and `course_code` are never used [INFO] [stdout] --> src/config.rs:60:12 [INFO] [stdout] | [INFO] [stdout] 59 | impl CourseDetails { [INFO] [stdout] | ------------------ methods in this implementation [INFO] [stdout] 60 | pub fn department(&self) -> &str { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 67 | pub fn course_code(&self) -> &str { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `to_section_groups` is never used [INFO] [stdout] --> src/config.rs:75:8 [INFO] [stdout] | [INFO] [stdout] 75 | pub fn to_section_groups(course: &LegacyCourseDetails) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `SectionGroup` is never constructed [INFO] [stdout] --> src/config.rs:83:12 [INFO] [stdout] | [INFO] [stdout] 83 | pub struct SectionGroup { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MonitoringConfig` is never constructed [INFO] [stdout] --> src/config.rs:89:12 [INFO] [stdout] | [INFO] [stdout] 89 | pub struct MonitoringConfig { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `default_seat_threshold` is never used [INFO] [stdout] --> src/config.rs:99:4 [INFO] [stdout] | [INFO] [stdout] 99 | fn default_seat_threshold() -> i64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `HealthStatus` is never constructed [INFO] [stdout] --> src/stats.rs:62:12 [INFO] [stdout] | [INFO] [stdout] 62 | pub struct HealthStatus { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `format_duration` is never used [INFO] [stdout] --> src/utils.rs:32:8 [INFO] [stdout] | [INFO] [stdout] 32 | pub fn format_duration(duration: Duration) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `initialize_webreg` is never used [INFO] [stdout] --> src/webreg.rs:6:14 [INFO] [stdout] | [INFO] [stdout] 6 | pub async fn initialize_webreg(config: &WebRegConfig) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_connection_valid` is never used [INFO] [stdout] --> src/webreg.rs:29:14 [INFO] [stdout] | [INFO] [stdout] 29 | pub async fn is_connection_valid(wrapper: &WebRegWrapper, term: &str) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_user_by_id` is never used [INFO] [stdout] --> src/db.rs:59:14 [INFO] [stdout] | [INFO] [stdout] 59 | pub async fn get_user_by_id( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_all_active_jobs` is never used [INFO] [stdout] --> src/db.rs:191:14 [INFO] [stdout] | [INFO] [stdout] 191 | pub async fn get_all_active_jobs( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `verify_clerk_session` is never used [INFO] [stdout] --> src/auth.rs:113:14 [INFO] [stdout] | [INFO] [stdout] 113 | pub async fn verify_clerk_session(session_token: &str) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `user_id` and `start_time` are never read [INFO] [stdout] --> src/multi_user_state.rs:22:9 [INFO] [stdout] | [INFO] [stdout] 20 | pub struct UserJob { [INFO] [stdout] | ------- fields in this struct [INFO] [stdout] 21 | pub job_id: Uuid, [INFO] [stdout] 22 | pub user_id: Uuid, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 33 | pub start_time: SystemTime, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `is_running`, `is_connected`, `last_check_time`, and `stats` are never read [INFO] [stdout] --> src/multi_user_state.rs:409:9 [INFO] [stdout] | [INFO] [stdout] 408 | pub struct JobStatusInfo { [INFO] [stdout] | ------------- fields in this struct [INFO] [stdout] 409 | pub is_running: bool, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 410 | pub is_connected: bool, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 411 | pub last_check_time: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] 412 | pub stats: EnrollmentStats, [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `JobStatusInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `error` is never used [INFO] [stdout] --> src/multi_user_api.rs:45:12 [INFO] [stdout] | [INFO] [stdout] 36 | impl ApiResponse { [INFO] [stdout] | ---------------------- associated function in this implementation [INFO] [stdout] ... [INFO] [stdout] 45 | pub fn error(error: String) -> Self { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 8.45s [INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: sqlx-postgres v0.7.4 [INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2` [INFO] running `Command { std: "docker" "inspect" "cd8705bbebf533f8302136d2426a103ca8e225c0a466e62b071daddf2ef79495", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "cd8705bbebf533f8302136d2426a103ca8e225c0a466e62b071daddf2ef79495", kill_on_drop: false }` [INFO] [stdout] cd8705bbebf533f8302136d2426a103ca8e225c0a466e62b071daddf2ef79495 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/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" "RUSTDOCFLAGS=--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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "-Zbuild-dir-new-layout", kill_on_drop: false }` [INFO] [stdout] 8381310384e3984e26443173fdd691a01c12eba141627eaf071576495c6fd89a [INFO] running `Command { std: "docker" "start" "-a" "8381310384e3984e26443173fdd691a01c12eba141627eaf071576495c6fd89a", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `error` [INFO] [stderr] --> src/multi_user_state.rs:6:17 [INFO] [stderr] | [INFO] [stderr] 6 | use log::{info, error}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `Deserialize` [INFO] [stderr] --> src/multi_user_api.rs:8:13 [INFO] [stderr] | [INFO] [stderr] 8 | use serde::{Deserialize, Serialize}; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::::from_slice`: please upgrade to generic-array 1.x [INFO] [stderr] --> src/encryption.rs:43:28 [INFO] [stderr] | [INFO] [stderr] 43 | let nonce = Nonce::from_slice(&nonce_bytes); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated associated function `aes_gcm::aead::generic_array::GenericArray::::from_slice`: please upgrade to generic-array 1.x [INFO] [stderr] --> src/encryption.rs:68:28 [INFO] [stderr] | [INFO] [stderr] 68 | let nonce = Nonce::from_slice(&nonce_bytes); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: constant `CONFIG_PATH` is never used [INFO] [stderr] --> src/config.rs:6:11 [INFO] [stderr] | [INFO] [stderr] 6 | pub const CONFIG_PATH: &str = "config.toml"; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: struct `AppConfig` is never constructed [INFO] [stderr] --> src/config.rs:9:12 [INFO] [stderr] | [INFO] [stderr] 9 | pub struct AppConfig { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `WebRegConfig` is never constructed [INFO] [stderr] --> src/config.rs:17:12 [INFO] [stderr] | [INFO] [stderr] 17 | pub struct WebRegConfig { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `CourseConfig` is never constructed [INFO] [stderr] --> src/config.rs:32:12 [INFO] [stderr] | [INFO] [stderr] 32 | pub struct CourseConfig { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum `CourseDetails` is never used [INFO] [stderr] --> src/config.rs:39:10 [INFO] [stderr] | [INFO] [stderr] 39 | pub enum CourseDetails { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `NewCourseDetails` is never constructed [INFO] [stderr] --> src/config.rs:45:12 [INFO] [stderr] | [INFO] [stderr] 45 | pub struct NewCourseDetails { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `LegacyCourseDetails` is never constructed [INFO] [stderr] --> src/config.rs:52:12 [INFO] [stderr] | [INFO] [stderr] 52 | pub struct LegacyCourseDetails { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: methods `department` and `course_code` are never used [INFO] [stderr] --> src/config.rs:60:12 [INFO] [stderr] | [INFO] [stderr] 59 | impl CourseDetails { [INFO] [stderr] | ------------------ methods in this implementation [INFO] [stderr] 60 | pub fn department(&self) -> &str { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 67 | pub fn course_code(&self) -> &str { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `to_section_groups` is never used [INFO] [stderr] --> src/config.rs:75:8 [INFO] [stderr] | [INFO] [stderr] 75 | pub fn to_section_groups(course: &LegacyCourseDetails) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `SectionGroup` is never constructed [INFO] [stderr] --> src/config.rs:83:12 [INFO] [stderr] | [INFO] [stderr] 83 | pub struct SectionGroup { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `MonitoringConfig` is never constructed [INFO] [stderr] --> src/config.rs:89:12 [INFO] [stderr] | [INFO] [stderr] 89 | pub struct MonitoringConfig { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `default_seat_threshold` is never used [INFO] [stderr] --> src/config.rs:99:4 [INFO] [stderr] | [INFO] [stderr] 99 | fn default_seat_threshold() -> i64 { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `HealthStatus` is never constructed [INFO] [stderr] --> src/stats.rs:62:12 [INFO] [stderr] | [INFO] [stderr] 62 | pub struct HealthStatus { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `format_duration` is never used [INFO] [stderr] --> src/utils.rs:32:8 [INFO] [stderr] | [INFO] [stderr] 32 | pub fn format_duration(duration: Duration) -> String { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `initialize_webreg` is never used [INFO] [stderr] --> src/webreg.rs:6:14 [INFO] [stderr] | [INFO] [stderr] 6 | pub async fn initialize_webreg(config: &WebRegConfig) -> Result> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `is_connection_valid` is never used [INFO] [stderr] --> src/webreg.rs:29:14 [INFO] [stderr] | [INFO] [stderr] 29 | pub async fn is_connection_valid(wrapper: &WebRegWrapper, term: &str) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `get_user_by_id` is never used [INFO] [stderr] --> src/db.rs:59:14 [INFO] [stderr] | [INFO] [stderr] 59 | pub async fn get_user_by_id( [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `get_all_active_jobs` is never used [INFO] [stderr] --> src/db.rs:191:14 [INFO] [stderr] | [INFO] [stderr] 191 | pub async fn get_all_active_jobs( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `verify_clerk_session` is never used [INFO] [stderr] --> src/auth.rs:113:14 [INFO] [stderr] | [INFO] [stderr] 113 | pub async fn verify_clerk_session(session_token: &str) -> Result> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `user_id` and `start_time` are never read [INFO] [stderr] --> src/multi_user_state.rs:22:9 [INFO] [stderr] | [INFO] [stderr] 20 | pub struct UserJob { [INFO] [stderr] | ------- fields in this struct [INFO] [stderr] 21 | pub job_id: Uuid, [INFO] [stderr] 22 | pub user_id: Uuid, [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 33 | pub start_time: SystemTime, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `is_running`, `is_connected`, `last_check_time`, and `stats` are never read [INFO] [stderr] --> src/multi_user_state.rs:409:9 [INFO] [stderr] | [INFO] [stderr] 408 | pub struct JobStatusInfo { [INFO] [stderr] | ------------- fields in this struct [INFO] [stderr] 409 | pub is_running: bool, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] 410 | pub is_connected: bool, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] 411 | pub last_check_time: String, [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] 412 | pub stats: EnrollmentStats, [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `JobStatusInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: associated function `error` is never used [INFO] [stderr] --> src/multi_user_api.rs:45:12 [INFO] [stderr] | [INFO] [stderr] 36 | impl ApiResponse { [INFO] [stderr] | ---------------------- associated function in this implementation [INFO] [stderr] ... [INFO] [stderr] 45 | pub fn error(error: String) -> Self { [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `log_file`, `stats_file`, `max_retries`, and `retry_delay` are never read [INFO] [stderr] --> src/config.rs:90:9 [INFO] [stderr] | [INFO] [stderr] 89 | pub struct MonitoringConfig { [INFO] [stderr] | ---------------- fields in this struct [INFO] [stderr] 90 | pub log_file: String, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] 91 | pub stats_file: String, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] 92 | pub cookie_refresh_interval: u64, [INFO] [stderr] 93 | pub max_retries: u32, [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] 94 | pub retry_delay: u64, [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `MonitoringConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: methods `update_stats` and `monitor_section_health` are never used [INFO] [stderr] --> src/state.rs:109:12 [INFO] [stderr] | [INFO] [stderr] 27 | impl AppState { [INFO] [stderr] | ------------- methods in this implementation [INFO] [stderr] ... [INFO] [stderr] 109 | pub fn update_stats(&mut self) { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 144 | pub async fn monitor_section_health( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `log_file`, `max_retries`, and `retry_delay` are never read [INFO] [stderr] --> src/config.rs:90:9 [INFO] [stderr] | [INFO] [stderr] 89 | pub struct MonitoringConfig { [INFO] [stderr] | ---------------- fields in this struct [INFO] [stderr] 90 | pub log_file: String, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 93 | pub max_retries: u32, [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] 94 | pub retry_delay: u64, [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `MonitoringConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: method `monitor_section_health` is never used [INFO] [stderr] --> src/state.rs:144:18 [INFO] [stderr] | [INFO] [stderr] 27 | impl AppState { [INFO] [stderr] | ------------- method in this implementation [INFO] [stderr] ... [INFO] [stderr] 144 | pub async fn monitor_section_health( [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `my_webreg_project` (bin "webreg-web-multiuser" test) generated 26 warnings (run `cargo fix --bin "webreg-web-multiuser" -p my_webreg_project --tests` to apply 2 suggestions) [INFO] [stderr] warning: `my_webreg_project` (bin "webreg-web" test) generated 2 warnings [INFO] [stderr] warning: `my_webreg_project` (bin "webreg-cli" test) generated 2 warnings [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.36s [INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: sqlx-postgres v0.7.4 [INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2` [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/build/my_webreg_project/b3b374f08a11c558/deps/webreg_cli-b3b374f08a11c558) [INFO] [stdout] [INFO] [stderr] Running unittests src/web_main.rs (/opt/rustwide/target/debug/build/my_webreg_project/484dd46fba195fde/deps/webreg_web-484dd46fba195fde) [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] [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] [stderr] Running unittests src/web_main_multiuser.rs (/opt/rustwide/target/debug/build/my_webreg_project/2ddb66f72d53e253/deps/webreg_web_multiuser-2ddb66f72d53e253) [INFO] [stdout] [INFO] [stdout] running 3 tests [INFO] [stdout] test auth::tests::test_clerk_validator_creation ... ok [INFO] [stdout] test encryption::tests::test_generate_key ... ok [INFO] [stdout] test encryption::tests::test_encryption_roundtrip ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "8381310384e3984e26443173fdd691a01c12eba141627eaf071576495c6fd89a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8381310384e3984e26443173fdd691a01c12eba141627eaf071576495c6fd89a", kill_on_drop: false }` [INFO] [stdout] 8381310384e3984e26443173fdd691a01c12eba141627eaf071576495c6fd89a