[INFO] fetching crate rate_my_professor_api_rs 0.1.5...
[INFO] testing rate_my_professor_api_rs-0.1.5 against master#733b47ea4b1b86216f14ef56e49440c33933f230+rustflags=-Copt-level=3 for pr-138759
[INFO] extracting crate rate_my_professor_api_rs 0.1.5 into /workspace/builds/worker-0-tc2/source
[INFO] started tweaking crates.io crate rate_my_professor_api_rs 0.1.5
[INFO] finished tweaking crates.io crate rate_my_professor_api_rs 0.1.5
[INFO] tweaked toml for crates.io crate rate_my_professor_api_rs 0.1.5 written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate rate_my_professor_api_rs 0.1.5 on toolchain 733b47ea4b1b86216f14ef56e49440c33933f230
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate rate_my_professor_api_rs 0.1.5 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" "+733b47ea4b1b86216f14ef56e49440c33933f230" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] c150304a1afc13311a843418034579f6a08a1815205ffe5d62ae5f280d888681
[INFO] running `Command { std: "docker" "start" "-a" "c150304a1afc13311a843418034579f6a08a1815205ffe5d62ae5f280d888681", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c150304a1afc13311a843418034579f6a08a1815205ffe5d62ae5f280d888681", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c150304a1afc13311a843418034579f6a08a1815205ffe5d62ae5f280d888681", kill_on_drop: false }`
[INFO] [stdout] c150304a1afc13311a843418034579f6a08a1815205ffe5d62ae5f280d888681
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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 -Copt-level=3" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6b5a201eb2d3ea2f87b85e6f6959701c20420e34a08509b7fed148b1a2483295
[INFO] running `Command { std: "docker" "start" "-a" "6b5a201eb2d3ea2f87b85e6f6959701c20420e34a08509b7fed148b1a2483295", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.92
[INFO] [stderr]    Compiling unicode-ident v1.0.14
[INFO] [stderr]    Compiling libc v0.2.169
[INFO] [stderr]    Compiling autocfg v1.4.0
[INFO] [stderr]    Compiling log v0.4.22
[INFO] [stderr]    Compiling bytes v1.9.0
[INFO] [stderr]    Compiling pkg-config v0.3.31
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling once_cell v1.20.2
[INFO] [stderr]    Compiling itoa v1.0.14
[INFO] [stderr]    Compiling futures-task v0.3.31
[INFO] [stderr]    Compiling bitflags v2.6.0
[INFO] [stderr]    Compiling tracing-core v0.1.33
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling memchr v2.7.4
[INFO] [stderr]    Compiling quote v1.0.38
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]    Compiling syn v2.0.95
[INFO] [stderr]    Compiling jobserver v0.1.32
[INFO] [stderr]    Compiling cc v1.2.7
[INFO] [stderr]    Compiling signal-hook-registry v1.4.2
[INFO] [stderr]    Compiling parking_lot v0.12.3
[INFO] [stderr]    Compiling socket2 v0.5.8
[INFO] [stderr]    Compiling mio v1.0.3
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling slab v0.4.9
[INFO] [stderr]    Compiling hashbrown v0.15.2
[INFO] [stderr]    Compiling typenum v1.17.0
[INFO] [stderr]    Compiling litemap v0.7.4
[INFO] [stderr]    Compiling http v1.2.0
[INFO] [stderr]    Compiling httparse v1.9.5
[INFO] [stderr]    Compiling openssl v0.10.68
[INFO] [stderr]    Compiling indexmap v2.7.0
[INFO] [stderr]    Compiling serde v1.0.217
[INFO] [stderr]    Compiling icu_locid_transform_data v1.5.0
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]    Compiling local-waker v0.1.4
[INFO] [stderr]    Compiling icu_properties_data v1.5.0
[INFO] [stderr]    Compiling http v0.2.12
[INFO] [stderr]    Compiling alloc-no-stdlib v2.0.4
[INFO] [stderr]    Compiling write16 v1.0.0
[INFO] [stderr]    Compiling utf16_iter v1.0.5
[INFO] [stderr]    Compiling icu_normalizer_data v1.5.0
[INFO] [stderr]    Compiling zstd-safe v7.2.1
[INFO] [stderr]    Compiling alloc-stdlib v0.2.2
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling actix-service v2.0.2
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling actix-utils v3.0.1
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]    Compiling time-core v0.1.2
[INFO] [stderr]    Compiling adler2 v2.0.0
[INFO] [stderr]    Compiling ryu v1.0.18
[INFO] [stderr]    Compiling serde_json v1.0.135
[INFO] [stderr]    Compiling native-tls v0.2.12
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling time-macros v0.2.19
[INFO] [stderr]    Compiling deranged v0.3.11
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling miniz_oxide v0.8.2
[INFO] [stderr]    Compiling brotli-decompressor v4.0.1
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling bytestring v1.4.0
[INFO] [stderr]    Compiling cookie v0.16.2
[INFO] [stderr]    Compiling futures-channel v0.3.31
[INFO] [stderr]    Compiling encoding_rs v0.8.35
[INFO] [stderr]    Compiling openssl-sys v0.9.104
[INFO] [stderr]    Compiling zstd-sys v2.0.13+zstd.1.5.6
[INFO] [stderr]    Compiling crc32fast v1.4.2
[INFO] [stderr]    Compiling tower-service v0.3.3
[INFO] [stderr]    Compiling tokio-openssl v0.6.5
[INFO] [stderr]    Compiling cpufeatures v0.2.16
[INFO] [stderr]    Compiling regex-lite v0.1.6
[INFO] [stderr]    Compiling convert_case v0.4.0
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling sha1 v0.10.6
[INFO] [stderr]    Compiling flate2 v1.0.35
[INFO] [stderr]    Compiling time v0.3.37
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling brotli v6.0.0
[INFO] [stderr]    Compiling local-channel v0.1.5
[INFO] [stderr]    Compiling httpdate v1.0.3
[INFO] [stderr]    Compiling language-tags v0.3.2
[INFO] [stderr]    Compiling impl-more v0.1.9
[INFO] [stderr]    Compiling actix-router v0.5.3
[INFO] [stderr]    Compiling http-body-util v0.1.2
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling tower-layer v0.3.3
[INFO] [stderr]    Compiling rustls-pki-types v1.10.1
[INFO] [stderr]    Compiling anyhow v1.0.95
[INFO] [stderr]    Compiling crossbeam-channel v0.5.14
[INFO] [stderr]    Compiling rustls-pemfile v2.2.0
[INFO] [stderr]    Compiling float-cmp v0.10.0
[INFO] [stderr]    Compiling anstyle v1.0.10
[INFO] [stderr]    Compiling predicates-core v1.0.9
[INFO] [stderr]    Compiling difflib v0.4.0
[INFO] [stderr]    Compiling ipnet v2.10.1
[INFO] [stderr]    Compiling normalize-line-endings v0.3.0
[INFO] [stderr]    Compiling predicates v3.1.3
[INFO] [stderr]    Compiling filepath v0.2.0
[INFO] [stderr]    Compiling zstd v0.13.2
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[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 icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling zerocopy-derive v0.7.35
[INFO] [stderr]    Compiling serde_derive v1.0.217
[INFO] [stderr]    Compiling actix-macros v0.2.4
[INFO] [stderr]    Compiling zerocopy v0.7.35
[INFO] [stderr]    Compiling derive_more v0.99.18
[INFO] [stderr]    Compiling tokio v1.43.0
[INFO] [stderr]    Compiling ppv-lite86 v0.2.20
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling actix-web-codegen v4.3.0
[INFO] [stderr]    Compiling actix_derive v0.6.2
[INFO] [stderr]    Compiling zerofrom v0.1.5
[INFO] [stderr]    Compiling yoke v0.7.5
[INFO] [stderr]    Compiling zerovec v0.10.4
[INFO] [stderr]    Compiling tokio-util v0.7.13
[INFO] [stderr]    Compiling tinystr v0.7.6
[INFO] [stderr]    Compiling icu_locid v1.5.0
[INFO] [stderr]    Compiling icu_collections v1.5.0
[INFO] [stderr]    Compiling actix-rt v2.10.0
[INFO] [stderr]    Compiling icu_provider v1.5.0
[INFO] [stderr]    Compiling icu_locid_transform v1.5.0
[INFO] [stderr]    Compiling h2 v0.4.7
[INFO] [stderr]    Compiling icu_properties v1.5.1
[INFO] [stderr]    Compiling h2 v0.3.26
[INFO] [stderr]    Compiling actix-codec v0.5.2
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling actix-tls v3.4.0
[INFO] [stderr]    Compiling icu_normalizer v1.5.0
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling idna_adapter v1.2.0
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling hyper v1.5.2
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling actix-http v3.9.0
[INFO] [stderr]    Compiling hyper-util v0.1.10
[INFO] [stderr]    Compiling actix-server v2.5.0
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling actix v0.13.5
[INFO] [stderr]    Compiling reqwest v0.12.12
[INFO] [stderr]    Compiling actix-web v4.9.0
[INFO] [stderr]    Compiling awc v3.5.1
[INFO] [stderr]    Compiling rate_my_professor_api_rs v0.1.5 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::any::type_name`
[INFO] [stdout]   --> src/features.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::any::type_name;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::cmp::Ord`
[INFO] [stdout]   --> src/features.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use core::cmp::Ord;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/features.rs:727:5
[INFO] [stdout]     |
[INFO] [stdout] 727 | /     /**
[INFO] [stdout] 728 | |      * for "variables", it would be the same as writting
[INFO] [stdout] 729 | |      * "variables" : "query" : { "text" : school_name }
[INFO] [stdout] 730 | |      */
[INFO] [stdout]     | |_______^
[INFO] [stdout] 731 | /     let body = serde_json::json!({
[INFO] [stdout] 732 | |         "query": SCHOOL_BODY_QUERY,
[INFO] [stdout] 733 | |         "variables": variables
[INFO] [stdout] 734 | |     });
[INFO] [stdout]     | |_______- rustdoc does not generate documentation for statements
[INFO] [stdout]     |
[INFO] [stdout]     = help: use `/* */` for a plain comment
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `predicates::prelude::*`
[INFO] [stdout]  --> src/methods.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use predicates::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `comments_data`
[INFO] [stdout]    --> src/features.rs:188:9
[INFO] [stdout]     |
[INFO] [stdout] 188 |     let comments_data : String = serde_json::from_str(&comments_subsection[index]["node"]["comment"].to_string())?;
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_comments_data`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `would_take_again`
[INFO] [stdout]    --> src/features.rs:190:9
[INFO] [stdout]     |
[INFO] [stdout] 190 |     let would_take_again : &serde_json::Value = &comments_subsection[index]["node"]["wouldTakeAgain"];
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_would_take_again`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:180:7
[INFO] [stdout]     |
[INFO] [stdout] 180 |   let mut comments_data : serde_json::Value = response.json().await.unwrap();
[INFO] [stdout]     |       ----^^^^^^^^^^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:181:7
[INFO] [stdout]     |
[INFO] [stdout] 181 |   let mut comments_subsection = comments_data["data"]["node"]["ratings"]["edges"].clone();
[INFO] [stdout]     |       ----^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `school_id`
[INFO] [stdout]    --> src/features.rs:758:9
[INFO] [stdout]     |
[INFO] [stdout] 758 |     let school_id : String = serde_json::from_str(&edges[0]["cursor"].clone().to_string()).unwrap();
[INFO] [stdout]     |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_school_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_path`
[INFO] [stdout]    --> src/features.rs:769:34
[INFO] [stdout]     |
[INFO] [stdout] 769 |     let (all_search_result_file, file_path) = create_file("all_search_result.json").await;
[INFO] [stdout]     |                                  ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_path`
[INFO] [stdout]    --> src/features.rs:770:28
[INFO] [stdout]     |
[INFO] [stdout] 770 |     let (school_name_file, file_path) = create_file(&(school_name.clone().to_owned() + ".json")).await;
[INFO] [stdout]     |                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> src/features.rs:773:10
[INFO] [stdout]     |
[INFO] [stdout] 773 |     for (index, data) in results.clone().into_iter().enumerate() {
[INFO] [stdout]     |          ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:811:7
[INFO] [stdout]     |
[INFO] [stdout] 811 |   let mut file = fs::File::create(fileName).unwrap();
[INFO] [stdout]     |       ----^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:874:7
[INFO] [stdout]     |
[INFO] [stdout] 874 |   let mut professor_list_raw : serde_json::Value = response.json().await?;
[INFO] [stdout]     |       ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_path`
[INFO] [stdout]    --> src/methods.rs:249:20
[INFO] [stdout]     |
[INFO] [stdout] 249 |         let (file, file_path) = create_file(file_name).await;
[INFO] [stdout]     |                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `professor_list_returned`
[INFO] [stdout]    --> src/features.rs:626:13
[INFO] [stdout]     |
[INFO] [stdout] 626 |         let professor_list_returned = get_professor_list_by_school(school_id).await?;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_professor_list_returned`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `main` is never used
[INFO] [stdout]    --> src/features.rs:610:10
[INFO] [stdout]     |
[INFO] [stdout] 610 | async fn main() -> Result<()> {
[INFO] [stdout]     |          ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_type_of` is never used
[INFO] [stdout]    --> src/features.rs:792:4
[INFO] [stdout]     |
[INFO] [stdout] 792 | fn print_type_of<T>(_ : &T) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: crate `rateMyProfessorApi_rs` should have a snake case name
[INFO] [stdout]   |
[INFO] [stdout]   = help: convert the identifier to snake case: `rate_my_professor_api_rs`
[INFO] [stdout]   = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `professorID` should have a snake case name
[INFO] [stdout]    --> src/features.rs:165:40
[INFO] [stdout]     |
[INFO] [stdout] 165 | pub async fn search_professor_comments(professorID : ProfessorId) -> Result<Vec<ProfessorComments>> {
[INFO] [stdout]     |                                        ^^^^^^^^^^^ help: convert the identifier to snake case: `professor_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ProfessorCommentsVector` should have a snake case name
[INFO] [stdout]    --> src/features.rs:183:11
[INFO] [stdout]     |
[INFO] [stdout] 183 |   let mut ProfessorCommentsVector : Vec<ProfessorComments> = Vec::with_capacity(length.clone());
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `professor_comments_vector`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `Id` should have a snake case name
[INFO] [stdout]    --> src/features.rs:235:7
[INFO] [stdout]     |
[INFO] [stdout] 235 |   pub Id : String
[INFO] [stdout]     |       ^^ help: convert the identifier to snake case (notice the capitalization): `id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/features.rs:770:66
[INFO] [stdout]     |
[INFO] [stdout] 770 |     let (school_name_file, file_path) = create_file(&(school_name.clone().to_owned() + ".json")).await;
[INFO] [stdout]     |                                                                  ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `fileName` should have a snake case name
[INFO] [stdout]    --> src/features.rs:810:26
[INFO] [stdout]     |
[INFO] [stdout] 810 | pub async fn create_file(fileName : &str) -> (fs::File, PathBuf) {
[INFO] [stdout]     |                          ^^^^^^^^ help: convert the identifier to snake case: `file_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `filePath` should have a snake case name
[INFO] [stdout]    --> src/features.rs:812:7
[INFO] [stdout]     |
[INFO] [stdout] 812 |   let filePath = file.path().unwrap();    // Ok("/path/to/file") -> "/path/to/file"
[INFO] [stdout]     |       ^^^^^^^^ help: convert the identifier to snake case: `file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `CollegeName` should have a snake case name
[INFO] [stdout]   --> src/methods.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub CollegeName : String,               
[INFO] [stdout]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `college_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `ProfessorName` should have a snake case name
[INFO] [stdout]   --> src/methods.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub ProfessorName : Option<String>      
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `professor_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Deserialize` and `Serialize`
[INFO] [stdout]  --> src/bin/execute_methods.rs:4:13
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |             ^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `predicates::prelude::*`
[INFO] [stdout]  --> src/bin/execute_methods.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use predicates::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Deserialize` and `Serialize`
[INFO] [stdout]  --> src/bin/execute_features.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |             ^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/bin/execute_methods.rs:100:9
[INFO] [stdout]     |
[INFO] [stdout] 100 |     let mut rate_my_professor_instance = RateMyProfessor::construct_college("Queens College");
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/bin/execute_methods.rs:111:9
[INFO] [stdout]     |
[INFO] [stdout] 111 |     let mut rate_my_professor_instance_version2 = RateMyProfessor::construct_college_and_professor("City College of New York", "Douglas T...
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `predicates::prelude`
[INFO] [stdout]  --> src/bin/execute_features.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use predicates::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `professor_list_returned`
[INFO] [stdout]   --> src/bin/execute_features.rs:25:13
[INFO] [stdout]    |
[INFO] [stdout] 25 |         let professor_list_returned = get_professor_list_by_school(school_id).await?;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_professor_list_returned`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_constructor_methods` is never used
[INFO] [stdout]   --> src/bin/execute_methods.rs:98:10
[INFO] [stdout]    |
[INFO] [stdout] 98 | async fn test_constructor_methods() -> Result<()> {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 10m 30s
[INFO] running `Command { std: "docker" "inspect" "6b5a201eb2d3ea2f87b85e6f6959701c20420e34a08509b7fed148b1a2483295", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6b5a201eb2d3ea2f87b85e6f6959701c20420e34a08509b7fed148b1a2483295", kill_on_drop: false }`
[INFO] [stdout] 6b5a201eb2d3ea2f87b85e6f6959701c20420e34a08509b7fed148b1a2483295
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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 -Copt-level=3" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] e8fee915d4e1efa107b26c83839e737d372d014cbe53cefcfb44b5bf4d85c0c9
[INFO] running `Command { std: "docker" "start" "-a" "e8fee915d4e1efa107b26c83839e737d372d014cbe53cefcfb44b5bf4d85c0c9", kill_on_drop: false }`
[INFO] [stdout] warning: unused import: `std::any::type_name`
[INFO] [stdout]   --> src/features.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::any::type_name;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::cmp::Ord`
[INFO] [stdout]   --> src/features.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use core::cmp::Ord;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/features.rs:727:5
[INFO] [stdout]     |
[INFO] [stdout] 727 | /     /**
[INFO] [stdout] 728 | |      * for "variables", it would be the same as writting
[INFO] [stdout] 729 | |      * "variables" : "query" : { "text" : school_name }
[INFO] [stdout] 730 | |      */
[INFO] [stdout]     | |_______^
[INFO] [stdout] 731 | /     let body = serde_json::json!({
[INFO] [stdout] 732 | |         "query": SCHOOL_BODY_QUERY,
[INFO] [stdout] 733 | |         "variables": variables
[INFO] [stdout] 734 | |     });
[INFO] [stdout]     | |_______- rustdoc does not generate documentation for statements
[INFO] [stdout]     |
[INFO] [stdout]     = help: use `/* */` for a plain comment
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `predicates::prelude::*`
[INFO] [stdout]  --> src/methods.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use predicates::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `comments_data`
[INFO] [stdout]    --> src/features.rs:188:9
[INFO] [stdout]     |
[INFO] [stdout] 188 |     let comments_data : String = serde_json::from_str(&comments_subsection[index]["node"]["comment"].to_string())?;
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_comments_data`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `would_take_again`
[INFO] [stdout]    --> src/features.rs:190:9
[INFO] [stdout]     |
[INFO] [stdout] 190 |     let would_take_again : &serde_json::Value = &comments_subsection[index]["node"]["wouldTakeAgain"];
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_would_take_again`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:180:7
[INFO] [stdout]     |
[INFO] [stdout] 180 |   let mut comments_data : serde_json::Value = response.json().await.unwrap();
[INFO] [stdout]     |       ----^^^^^^^^^^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:181:7
[INFO] [stdout]     |
[INFO] [stdout] 181 |   let mut comments_subsection = comments_data["data"]["node"]["ratings"]["edges"].clone();
[INFO] [stdout]     |       ----^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `school_id`
[INFO] [stdout]    --> src/features.rs:758:9
[INFO] [stdout]     |
[INFO] [stdout] 758 |     let school_id : String = serde_json::from_str(&edges[0]["cursor"].clone().to_string()).unwrap();
[INFO] [stdout]     |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_school_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_path`
[INFO] [stdout]    --> src/features.rs:769:34
[INFO] [stdout]     |
[INFO] [stdout] 769 |     let (all_search_result_file, file_path) = create_file("all_search_result.json").await;
[INFO] [stdout]     |                                  ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_path`
[INFO] [stdout]    --> src/features.rs:770:28
[INFO] [stdout]     |
[INFO] [stdout] 770 |     let (school_name_file, file_path) = create_file(&(school_name.clone().to_owned() + ".json")).await;
[INFO] [stdout]     |                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> src/features.rs:773:10
[INFO] [stdout]     |
[INFO] [stdout] 773 |     for (index, data) in results.clone().into_iter().enumerate() {
[INFO] [stdout]     |          ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:811:7
[INFO] [stdout]     |
[INFO] [stdout] 811 |   let mut file = fs::File::create(fileName).unwrap();
[INFO] [stdout]     |       ----^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:874:7
[INFO] [stdout]     |
[INFO] [stdout] 874 |   let mut professor_list_raw : serde_json::Value = response.json().await?;
[INFO] [stdout]     |       ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_path`
[INFO] [stdout]    --> src/methods.rs:249:20
[INFO] [stdout]     |
[INFO] [stdout] 249 |         let (file, file_path) = create_file(file_name).await;
[INFO] [stdout]     |                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `professor_list_returned`
[INFO] [stdout]    --> src/features.rs:626:13
[INFO] [stdout]     |
[INFO] [stdout] 626 |         let professor_list_returned = get_professor_list_by_school(school_id).await?;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_professor_list_returned`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `main` is never used
[INFO] [stdout]    --> src/features.rs:610:10
[INFO] [stdout]     |
[INFO] [stdout] 610 | async fn main() -> Result<()> {
[INFO] [stdout]     |          ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_type_of` is never used
[INFO] [stdout]    --> src/features.rs:792:4
[INFO] [stdout]     |
[INFO] [stdout] 792 | fn print_type_of<T>(_ : &T) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: crate `rateMyProfessorApi_rs` should have a snake case name
[INFO] [stdout]   |
[INFO] [stdout]   = help: convert the identifier to snake case: `rate_my_professor_api_rs`
[INFO] [stdout]   = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `professorID` should have a snake case name
[INFO] [stdout]    --> src/features.rs:165:40
[INFO] [stdout]     |
[INFO] [stdout] 165 | pub async fn search_professor_comments(professorID : ProfessorId) -> Result<Vec<ProfessorComments>> {
[INFO] [stdout]     |                                        ^^^^^^^^^^^ help: convert the identifier to snake case: `professor_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ProfessorCommentsVector` should have a snake case name
[INFO] [stdout]    --> src/features.rs:183:11
[INFO] [stdout]     |
[INFO] [stdout] 183 |   let mut ProfessorCommentsVector : Vec<ProfessorComments> = Vec::with_capacity(length.clone());
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `professor_comments_vector`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `Id` should have a snake case name
[INFO] [stdout]    --> src/features.rs:235:7
[INFO] [stdout]     |
[INFO] [stdout] 235 |   pub Id : String
[INFO] [stdout]     |       ^^ help: convert the identifier to snake case (notice the capitalization): `id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/features.rs:770:66
[INFO] [stdout]     |
[INFO] [stdout] 770 |     let (school_name_file, file_path) = create_file(&(school_name.clone().to_owned() + ".json")).await;
[INFO] [stdout]     |                                                                  ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `fileName` should have a snake case name
[INFO] [stdout]    --> src/features.rs:810:26
[INFO] [stdout]     |
[INFO] [stdout] 810 | pub async fn create_file(fileName : &str) -> (fs::File, PathBuf) {
[INFO] [stdout]     |                          ^^^^^^^^ help: convert the identifier to snake case: `file_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `filePath` should have a snake case name
[INFO] [stdout]    --> src/features.rs:812:7
[INFO] [stdout]     |
[INFO] [stdout] 812 |   let filePath = file.path().unwrap();    // Ok("/path/to/file") -> "/path/to/file"
[INFO] [stdout]     |       ^^^^^^^^ help: convert the identifier to snake case: `file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `CollegeName` should have a snake case name
[INFO] [stdout]   --> src/methods.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub CollegeName : String,               
[INFO] [stdout]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `college_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `ProfessorName` should have a snake case name
[INFO] [stdout]   --> src/methods.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub ProfessorName : Option<String>      
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `professor_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling rate_my_professor_api_rs v0.1.5 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `Deserialize` and `Serialize`
[INFO] [stdout]  --> src/bin/execute_features.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |             ^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `predicates::prelude`
[INFO] [stdout]  --> src/bin/execute_features.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use predicates::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `professor_list_returned`
[INFO] [stdout]   --> src/bin/execute_features.rs:25:13
[INFO] [stdout]    |
[INFO] [stdout] 25 |         let professor_list_returned = get_professor_list_by_school(school_id).await?;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_professor_list_returned`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Deserialize` and `Serialize`
[INFO] [stdout]  --> src/bin/execute_methods.rs:4:13
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |             ^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `predicates::prelude::*`
[INFO] [stdout]  --> src/bin/execute_methods.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use predicates::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/bin/execute_methods.rs:100:9
[INFO] [stdout]     |
[INFO] [stdout] 100 |     let mut rate_my_professor_instance = RateMyProfessor::construct_college("Queens College");
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/bin/execute_methods.rs:111:9
[INFO] [stdout]     |
[INFO] [stdout] 111 |     let mut rate_my_professor_instance_version2 = RateMyProfessor::construct_college_and_professor("City College of New York", "Douglas T...
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/bin/execute_methods.rs:119:5
[INFO] [stdout]     |
[INFO] [stdout] 119 |     test_constructor_methods().await;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 119 |     let _ = test_constructor_methods().await;
[INFO] [stdout]     |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::any::type_name`
[INFO] [stdout]   --> src/features.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::any::type_name;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `core::cmp::Ord`
[INFO] [stdout]   --> src/features.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use core::cmp::Ord;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/features.rs:727:5
[INFO] [stdout]     |
[INFO] [stdout] 727 | /     /**
[INFO] [stdout] 728 | |      * for "variables", it would be the same as writting
[INFO] [stdout] 729 | |      * "variables" : "query" : { "text" : school_name }
[INFO] [stdout] 730 | |      */
[INFO] [stdout]     | |_______^
[INFO] [stdout] 731 | /     let body = serde_json::json!({
[INFO] [stdout] 732 | |         "query": SCHOOL_BODY_QUERY,
[INFO] [stdout] 733 | |         "variables": variables
[INFO] [stdout] 734 | |     });
[INFO] [stdout]     | |_______- rustdoc does not generate documentation for statements
[INFO] [stdout]     |
[INFO] [stdout]     = help: use `/* */` for a plain comment
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `predicates::prelude::*`
[INFO] [stdout]  --> src/methods.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use predicates::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `comments_data`
[INFO] [stdout]    --> src/features.rs:188:9
[INFO] [stdout]     |
[INFO] [stdout] 188 |     let comments_data : String = serde_json::from_str(&comments_subsection[index]["node"]["comment"].to_string())?;
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_comments_data`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `would_take_again`
[INFO] [stdout]    --> src/features.rs:190:9
[INFO] [stdout]     |
[INFO] [stdout] 190 |     let would_take_again : &serde_json::Value = &comments_subsection[index]["node"]["wouldTakeAgain"];
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_would_take_again`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:180:7
[INFO] [stdout]     |
[INFO] [stdout] 180 |   let mut comments_data : serde_json::Value = response.json().await.unwrap();
[INFO] [stdout]     |       ----^^^^^^^^^^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:181:7
[INFO] [stdout]     |
[INFO] [stdout] 181 |   let mut comments_subsection = comments_data["data"]["node"]["ratings"]["edges"].clone();
[INFO] [stdout]     |       ----^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `school_id`
[INFO] [stdout]    --> src/features.rs:758:9
[INFO] [stdout]     |
[INFO] [stdout] 758 |     let school_id : String = serde_json::from_str(&edges[0]["cursor"].clone().to_string()).unwrap();
[INFO] [stdout]     |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_school_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_path`
[INFO] [stdout]    --> src/features.rs:769:34
[INFO] [stdout]     |
[INFO] [stdout] 769 |     let (all_search_result_file, file_path) = create_file("all_search_result.json").await;
[INFO] [stdout]     |                                  ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_path`
[INFO] [stdout]    --> src/features.rs:770:28
[INFO] [stdout]     |
[INFO] [stdout] 770 |     let (school_name_file, file_path) = create_file(&(school_name.clone().to_owned() + ".json")).await;
[INFO] [stdout]     |                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> src/features.rs:773:10
[INFO] [stdout]     |
[INFO] [stdout] 773 |     for (index, data) in results.clone().into_iter().enumerate() {
[INFO] [stdout]     |          ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:811:7
[INFO] [stdout]     |
[INFO] [stdout] 811 |   let mut file = fs::File::create(fileName).unwrap();
[INFO] [stdout]     |       ----^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/features.rs:874:7
[INFO] [stdout]     |
[INFO] [stdout] 874 |   let mut professor_list_raw : serde_json::Value = response.json().await?;
[INFO] [stdout]     |       ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_path`
[INFO] [stdout]    --> src/methods.rs:249:20
[INFO] [stdout]     |
[INFO] [stdout] 249 |         let (file, file_path) = create_file(file_name).await;
[INFO] [stdout]     |                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `professor_list_returned`
[INFO] [stdout]    --> src/features.rs:626:13
[INFO] [stdout]     |
[INFO] [stdout] 626 |         let professor_list_returned = get_professor_list_by_school(school_id).await?;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_professor_list_returned`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `main` is never used
[INFO] [stdout]    --> src/features.rs:610:10
[INFO] [stdout]     |
[INFO] [stdout] 610 | async fn main() -> Result<()> {
[INFO] [stdout]     |          ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_type_of` is never used
[INFO] [stdout]    --> src/features.rs:792:4
[INFO] [stdout]     |
[INFO] [stdout] 792 | fn print_type_of<T>(_ : &T) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `professorID` should have a snake case name
[INFO] [stdout]    --> src/features.rs:165:40
[INFO] [stdout]     |
[INFO] [stdout] 165 | pub async fn search_professor_comments(professorID : ProfessorId) -> Result<Vec<ProfessorComments>> {
[INFO] [stdout]     |                                        ^^^^^^^^^^^ help: convert the identifier to snake case: `professor_id`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ProfessorCommentsVector` should have a snake case name
[INFO] [stdout]    --> src/features.rs:183:11
[INFO] [stdout]     |
[INFO] [stdout] 183 |   let mut ProfessorCommentsVector : Vec<ProfessorComments> = Vec::with_capacity(length.clone());
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `professor_comments_vector`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `Id` should have a snake case name
[INFO] [stdout]    --> src/features.rs:235:7
[INFO] [stdout]     |
[INFO] [stdout] 235 |   pub Id : String
[INFO] [stdout]     |       ^^ help: convert the identifier to snake case (notice the capitalization): `id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/features.rs:770:66
[INFO] [stdout]     |
[INFO] [stdout] 770 |     let (school_name_file, file_path) = create_file(&(school_name.clone().to_owned() + ".json")).await;
[INFO] [stdout]     |                                                                  ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `fileName` should have a snake case name
[INFO] [stdout]    --> src/features.rs:810:26
[INFO] [stdout]     |
[INFO] [stdout] 810 | pub async fn create_file(fileName : &str) -> (fs::File, PathBuf) {
[INFO] [stdout]     |                          ^^^^^^^^ help: convert the identifier to snake case: `file_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `filePath` should have a snake case name
[INFO] [stdout]    --> src/features.rs:812:7
[INFO] [stdout]     |
[INFO] [stdout] 812 |   let filePath = file.path().unwrap();    // Ok("/path/to/file") -> "/path/to/file"
[INFO] [stdout]     |       ^^^^^^^^ help: convert the identifier to snake case: `file_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `CollegeName` should have a snake case name
[INFO] [stdout]   --> src/methods.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub CollegeName : String,               
[INFO] [stdout]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `college_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `ProfessorName` should have a snake case name
[INFO] [stdout]   --> src/methods.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub ProfessorName : Option<String>      
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `professor_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 2.71s
[INFO] running `Command { std: "docker" "inspect" "e8fee915d4e1efa107b26c83839e737d372d014cbe53cefcfb44b5bf4d85c0c9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e8fee915d4e1efa107b26c83839e737d372d014cbe53cefcfb44b5bf4d85c0c9", kill_on_drop: false }`
[INFO] [stdout] e8fee915d4e1efa107b26c83839e737d372d014cbe53cefcfb44b5bf4d85c0c9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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 -Copt-level=3" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 8876304cbb875c24e2d3cc7e234e18a0f0db3d4d843eac354c916af62fdb0934
[INFO] running `Command { std: "docker" "start" "-a" "8876304cbb875c24e2d3cc7e234e18a0f0db3d4d843eac354c916af62fdb0934", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `std::any::type_name`
[INFO] [stderr]   --> src/features.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 12 | use std::any::type_name;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `core::cmp::Ord`
[INFO] [stderr]   --> src/features.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 | use core::cmp::Ord;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused doc comment
[INFO] [stderr]    --> src/features.rs:727:5
[INFO] [stderr]     |
[INFO] [stderr] 727 | /     /**
[INFO] [stderr] 728 | |      * for "variables", it would be the same as writting
[INFO] [stderr] 729 | |      * "variables" : "query" : { "text" : school_name }
[INFO] [stderr] 730 | |      */
[INFO] [stderr]     | |_______^
[INFO] [stderr] 731 | /     let body = serde_json::json!({
[INFO] [stderr] 732 | |         "query": SCHOOL_BODY_QUERY,
[INFO] [stderr] 733 | |         "variables": variables
[INFO] [stderr] 734 | |     });
[INFO] [stderr]     | |_______- rustdoc does not generate documentation for statements
[INFO] [stderr]     |
[INFO] [stderr]     = help: use `/* */` for a plain comment
[INFO] [stderr]     = note: `#[warn(unused_doc_comments)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `predicates::prelude::*`
[INFO] [stderr]  --> src/methods.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use predicates::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `comments_data`
[INFO] [stderr]    --> src/features.rs:188:9
[INFO] [stderr]     |
[INFO] [stderr] 188 |     let comments_data : String = serde_json::from_str(&comments_subsection[index]["node"]["comment"].to_string())?;
[INFO] [stderr]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_comments_data`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `would_take_again`
[INFO] [stderr]    --> src/features.rs:190:9
[INFO] [stderr]     |
[INFO] [stderr] 190 |     let would_take_again : &serde_json::Value = &comments_subsection[index]["node"]["wouldTakeAgain"];
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_would_take_again`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/features.rs:180:7
[INFO] [stderr]     |
[INFO] [stderr] 180 |   let mut comments_data : serde_json::Value = response.json().await.unwrap();
[INFO] [stderr]     |       ----^^^^^^^^^^^^^
[INFO] [stderr]     |       |
[INFO] [stderr]     |       help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/features.rs:181:7
[INFO] [stderr]     |
[INFO] [stderr] 181 |   let mut comments_subsection = comments_data["data"]["node"]["ratings"]["edges"].clone();
[INFO] [stderr]     |       ----^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |       |
[INFO] [stderr]     |       help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `school_id`
[INFO] [stderr]    --> src/features.rs:758:9
[INFO] [stderr]     |
[INFO] [stderr] 758 |     let school_id : String = serde_json::from_str(&edges[0]["cursor"].clone().to_string()).unwrap();
[INFO] [stderr]     |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_school_id`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `file_path`
[INFO] [stderr]    --> src/features.rs:769:34
[INFO] [stderr]     |
[INFO] [stderr] 769 |     let (all_search_result_file, file_path) = create_file("all_search_result.json").await;
[INFO] [stderr]     |                                  ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `file_path`
[INFO] [stderr]    --> src/features.rs:770:28
[INFO] [stderr]     |
[INFO] [stderr] 770 |     let (school_name_file, file_path) = create_file(&(school_name.clone().to_owned() + ".json")).await;
[INFO] [stderr]     |                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `index`
[INFO] [stderr]    --> src/features.rs:773:10
[INFO] [stderr]     |
[INFO] [stderr] 773 |     for (index, data) in results.clone().into_iter().enumerate() {
[INFO] [stderr]     |          ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/features.rs:811:7
[INFO] [stderr]     |
[INFO] [stderr] 811 |   let mut file = fs::File::create(fileName).unwrap();
[INFO] [stderr]     |       ----^^^^
[INFO] [stderr]     |       |
[INFO] [stderr]     |       help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/features.rs:874:7
[INFO] [stderr]     |
[INFO] [stderr] 874 |   let mut professor_list_raw : serde_json::Value = response.json().await?;
[INFO] [stderr]     |       ----^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |       |
[INFO] [stderr]     |       help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `file_path`
[INFO] [stderr]    --> src/methods.rs:249:20
[INFO] [stderr]     |
[INFO] [stderr] 249 |         let (file, file_path) = create_file(file_name).await;
[INFO] [stderr]     |                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_path`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `professor_list_returned`
[INFO] [stderr]    --> src/features.rs:626:13
[INFO] [stderr]     |
[INFO] [stderr] 626 |         let professor_list_returned = get_professor_list_by_school(school_id).await?;
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_professor_list_returned`
[INFO] [stderr] 
[INFO] [stderr] warning: function `main` is never used
[INFO] [stderr]    --> src/features.rs:610:10
[INFO] [stderr]     |
[INFO] [stderr] 610 | async fn main() -> Result<()> {
[INFO] [stderr]     |          ^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `print_type_of` is never used
[INFO] [stderr]    --> src/features.rs:792:4
[INFO] [stderr]     |
[INFO] [stderr] 792 | fn print_type_of<T>(_ : &T) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: crate `rateMyProfessorApi_rs` should have a snake case name
[INFO] [stderr]   |
[INFO] [stderr]   = help: convert the identifier to snake case: `rate_my_professor_api_rs`
[INFO] [stderr]   = note: `#[warn(non_snake_case)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable `professorID` should have a snake case name
[INFO] [stderr]    --> src/features.rs:165:40
[INFO] [stderr]     |
[INFO] [stderr] 165 | pub async fn search_professor_comments(professorID : ProfessorId) -> Result<Vec<ProfessorComments>> {
[INFO] [stderr]     |                                        ^^^^^^^^^^^ help: convert the identifier to snake case: `professor_id`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `ProfessorCommentsVector` should have a snake case name
[INFO] [stderr]    --> src/features.rs:183:11
[INFO] [stderr]     |
[INFO] [stderr] 183 |   let mut ProfessorCommentsVector : Vec<ProfessorComments> = Vec::with_capacity(length.clone());
[INFO] [stderr]     |           ^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `professor_comments_vector`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `Id` should have a snake case name
[INFO] [stderr]    --> src/features.rs:235:7
[INFO] [stderr]     |
[INFO] [stderr] 235 |   pub Id : String
[INFO] [stderr]     |       ^^ help: convert the identifier to snake case (notice the capitalization): `id`
[INFO] [stderr] 
[INFO] [stderr] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stderr]    --> src/features.rs:770:66
[INFO] [stderr]     |
[INFO] [stderr] 770 |     let (school_name_file, file_path) = create_file(&(school_name.clone().to_owned() + ".json")).await;
[INFO] [stderr]     |                                                                  ^^^^^^^^ help: remove this redundant call
[INFO] [stderr]     |
[INFO] [stderr]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stderr]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable `fileName` should have a snake case name
[INFO] [stderr]    --> src/features.rs:810:26
[INFO] [stderr]     |
[INFO] [stderr] 810 | pub async fn create_file(fileName : &str) -> (fs::File, PathBuf) {
[INFO] [stderr]     |                          ^^^^^^^^ help: convert the identifier to snake case: `file_name`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `filePath` should have a snake case name
[INFO] [stderr]    --> src/features.rs:812:7
[INFO] [stderr]     |
[INFO] [stderr] 812 |   let filePath = file.path().unwrap();    // Ok("/path/to/file") -> "/path/to/file"
[INFO] [stderr]     |       ^^^^^^^^ help: convert the identifier to snake case: `file_path`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `CollegeName` should have a snake case name
[INFO] [stderr]   --> src/methods.rs:13:9
[INFO] [stderr]    |
[INFO] [stderr] 13 |     pub CollegeName : String,               
[INFO] [stderr]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `college_name`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `ProfessorName` should have a snake case name
[INFO] [stderr]   --> src/methods.rs:16:9
[INFO] [stderr]    |
[INFO] [stderr] 16 |     pub ProfessorName : Option<String>      
[INFO] [stderr]    |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `professor_name`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `professorID` should have a snake case name
[INFO] [stderr]    --> src/features.rs:165:40
[INFO] [stderr]     |
[INFO] [stderr] 165 | pub async fn search_professor_comments(professorID : ProfessorId) -> Result<Vec<ProfessorComments>> {
[INFO] [stderr]     |                                        ^^^^^^^^^^^ help: convert the identifier to snake case: `professor_id`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(non_snake_case)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `rate_my_professor_api_rs` (lib) generated 27 warnings (run `cargo fix --lib -p rate_my_professor_api_rs` to apply 8 suggestions)
[INFO] [stderr] warning: `rate_my_professor_api_rs` (lib test) generated 26 warnings (25 duplicates)
[INFO] [stderr] warning: unused imports: `Deserialize` and `Serialize`
[INFO] [stderr]  --> src/bin/execute_features.rs:3:13
[INFO] [stderr]   |
[INFO] [stderr] 3 | use serde::{Deserialize, Serialize};
[INFO] [stderr]   |             ^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `predicates::prelude`
[INFO] [stderr]  --> src/bin/execute_features.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use predicates::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `professor_list_returned`
[INFO] [stderr]   --> src/bin/execute_features.rs:25:13
[INFO] [stderr]    |
[INFO] [stderr] 25 |         let professor_list_returned = get_professor_list_by_school(school_id).await?;
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_professor_list_returned`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Deserialize` and `Serialize`
[INFO] [stderr]  --> src/bin/execute_methods.rs:4:13
[INFO] [stderr]   |
[INFO] [stderr] 4 | use serde::{Deserialize, Serialize};
[INFO] [stderr]   |             ^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `predicates::prelude::*`
[INFO] [stderr]  --> src/bin/execute_methods.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use predicates::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/bin/execute_methods.rs:100:9
[INFO] [stderr]     |
[INFO] [stderr] 100 |     let mut rate_my_professor_instance = RateMyProfessor::construct_college("Queens College");
[INFO] [stderr]     |         ----^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/bin/execute_methods.rs:111:9
[INFO] [stderr]     |
[INFO] [stderr] 111 |     let mut rate_my_professor_instance_version2 = RateMyProfessor::construct_college_and_professor("City College of New York", "Douglas T...
[INFO] [stderr]     |         ----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> src/bin/execute_methods.rs:119:5
[INFO] [stderr]     |
[INFO] [stderr] 119 |     test_constructor_methods().await;
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 119 |     let _ = test_constructor_methods().await;
[INFO] [stderr]     |     +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: `rate_my_professor_api_rs` (bin "test-bin-features" test) generated 3 warnings (run `cargo fix --bin "test-bin-features" --tests` to apply 1 suggestion)
[INFO] [stderr] warning: `rate_my_professor_api_rs` (bin "test-bin-methods" test) generated 5 warnings (run `cargo fix --bin "test-bin-methods" --tests` to apply 4 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.31s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/rateMyProfessorApi_rs-b23c897a4024b936)
[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/bin/execute_features.rs (/opt/rustwide/target/debug/deps/test_bin_features-a42add865d27aa91)
[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/bin/execute_methods.rs (/opt/rustwide/target/debug/deps/test_bin_methods-5ba839c1062630e9)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stderr]    Doc-tests rateMyProfessorApi_rs
[INFO] [stdout] test test_asynchronous_functions ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 7 tests
[INFO] [stdout] test src/methods.rs - methods::RateMyProfessor::get_professor_comments (line 290) ... FAILED
[INFO] [stdout] test src/methods.rs - methods::RateMyProfessor::construct_college (line 25) ... FAILED
[INFO] [stdout] test src/methods.rs - methods::RateMyProfessor::get_professor_list (line 355) ... FAILED
[INFO] [stdout] test src/methods.rs - methods::main (line 440) ... FAILED
[INFO] [stdout] test src/methods.rs - methods::RateMyProfessor::construct_college_and_professor (line 62) ... FAILED
[INFO] [stdout] test src/methods.rs - methods::RateMyProfessor::get_teacher_summary (line 110) ... FAILED
[INFO] [stdout] test src/methods.rs - methods::RateMyProfessor::get_teacher_summary_and_save (line 215) ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- src/methods.rs - methods::RateMyProfessor::get_professor_comments (line 290) stdout ----
[INFO] [stdout] error[E0425]: cannot find value `rate_my_professor_instance` in this scope
[INFO] [stdout]  --> src/methods.rs:292:30
[INFO] [stdout]   |
[INFO] [stdout] 4 | let mut professor_comments = rate_my_professor_instance.get_professor_comments().await?;
[INFO] [stdout]   |                              ^^^^^^^^^^^^^^^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] error[E0728]: `await` is only allowed inside `async` functions and blocks
[INFO] [stdout]  --> src/methods.rs:292:82
[INFO] [stdout]   |
[INFO] [stdout] 2 | fn main() { #[allow(non_snake_case)] fn _doctest_main_src_methods_rs_290_0() {
[INFO] [stdout]   |                                      --------------------------------------- this is not `async`
[INFO] [stdout] 3 | // add the following within the main function from above (or any asynchronous function)
[INFO] [stdout] 4 | let mut professor_comments = rate_my_professor_instance.get_professor_comments().await?;
[INFO] [stdout]   |                                                                                  ^^^^^ only allowed inside `async` functions and blocks
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 2 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0425, E0728.
[INFO] [stdout] For more information about an error, try `rustc --explain E0425`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/methods.rs - methods::RateMyProfessor::construct_college (line 25) stdout ----
[INFO] [stdout] error[E0428]: the name `main` is defined multiple times
[INFO] [stdout]   --> src/methods.rs:42:7
[INFO] [stdout]    |
[INFO] [stdout] 12 | fn main() {
[INFO] [stdout]    | --------- previous definition of the value `main` here
[INFO] [stdout] ...
[INFO] [stdout] 19 | async fn main() -> Result<()> {
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^^ `main` redefined here
[INFO] [stdout]    |
[INFO] [stdout]    = note: `main` must be defined only once in the value namespace of this module
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 1 previous error
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0428`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/methods.rs - methods::RateMyProfessor::get_professor_list (line 355) stdout ----
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `RateMyProfessor`
[INFO] [stdout]  --> src/methods.rs:356:38
[INFO] [stdout]   |
[INFO] [stdout] 3 | let mut rate_my_professor_instance = RateMyProfessor::construct_college("CUNY Queens College");
[INFO] [stdout]   |                                      ^^^^^^^^^^^^^^^ use of undeclared type `RateMyProfessor`
[INFO] [stdout]   |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]   |
[INFO] [stdout] 2 + use rateMyProfessorApi_rs::methods::RateMyProfessor;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] error[E0728]: `await` is only allowed inside `async` functions and blocks
[INFO] [stdout]  --> src/methods.rs:357:78
[INFO] [stdout]   |
[INFO] [stdout] 2 | fn main() { #[allow(non_snake_case)] fn _doctest_main_src_methods_rs_355_0() {
[INFO] [stdout]   |                                      --------------------------------------- this is not `async`
[INFO] [stdout] 3 | let mut rate_my_professor_instance = RateMyProfessor::construct_college("CUNY Queens College");
[INFO] [stdout] 4 | let mut list_of_professors = rate_my_professor_instance.get_professor_list().await?;
[INFO] [stdout]   |                                                                              ^^^^^ only allowed inside `async` functions and blocks
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 2 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0433, E0728.
[INFO] [stdout] For more information about an error, try `rustc --explain E0433`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/methods.rs - methods::main (line 440) stdout ----
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `RateMyProfessor`
[INFO] [stdout]  --> src/methods.rs:444:42
[INFO] [stdout]   |
[INFO] [stdout] 5 |     let mut rate_my_professor_instance = RateMyProfessor::construct_college_and_professor("City College of New York", "Douglas Troeger");
[INFO] [stdout]   |                                          ^^^^^^^^^^^^^^^ use of undeclared type `RateMyProfessor`
[INFO] [stdout]   |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]   |
[INFO] [stdout] 2 + use rateMyProfessorApi_rs::methods::RateMyProfessor;
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] error[E0107]: enum takes 2 generic arguments but 1 generic argument was supplied
[INFO] [stdout]  --> src/methods.rs:442:24
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub async fn main() -> Result<()> {
[INFO] [stdout]   |                        ^^^^^^ -- supplied 1 generic argument
[INFO] [stdout]   |                        |
[INFO] [stdout]   |                        expected 2 generic arguments
[INFO] [stdout]   |
[INFO] [stdout] help: add missing generic argument
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub async fn main() -> Result<(), E> {
[INFO] [stdout]   |                                 +++
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 2 previous errors
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0107, E0433.
[INFO] [stdout] For more information about an error, try `rustc --explain E0107`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] ---- src/methods.rs - methods::RateMyProfessor::construct_college_and_professor (line 62) stdout ----
[INFO] [stdout] Test executable failed (exit status: 101).
[INFO] [stdout] 
[INFO] [stdout] stdout:
[INFO] [stdout] newly instantiated object : RateMyProfessor {
[INFO] [stdout]     CollegeName: "City College of New York",
[INFO] [stdout]     ProfessorName: Some(
[INFO] [stdout]         "Douglas Troeger",
[INFO] [stdout]     ),
[INFO] [stdout] }
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Err(
[INFO] [stdout]     reqwest::Error {
[INFO] [stdout]         kind: Request,
[INFO] [stdout]         url: "https://www.ratemyprofessors.com/graphql",
[INFO] [stdout]         source: hyper_util::client::legacy::Error(
[INFO] [stdout]             Connect,
[INFO] [stdout]             ConnectError(
[INFO] [stdout]                 "dns error",
[INFO] [stdout]                 Custom {
[INFO] [stdout]                     kind: Uncategorized,
[INFO] [stdout]                     error: "failed to lookup address information: Temporary failure in name resolution",
[INFO] [stdout]                 },
[INFO] [stdout]             ),
[INFO] [stdout]         ),
[INFO] [stdout]     },
[INFO] [stdout] )
[INFO] [stdout] 
[INFO] [stdout] stderr:
[INFO] [stdout] 
[INFO] [stdout] thread 'main' panicked at /opt/rustwide/workdir/src/methods.rs:160:43:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: error sending request for url (https://www.ratemyprofessors.com/graphql)
[INFO] [stdout] 
[INFO] [stdout] Caused by:
[INFO] [stdout]     0: client error (Connect)
[INFO] [stdout]     1: dns error: failed to lookup address information: Temporary failure in name resolution
[INFO] [stdout]     2: failed to lookup address information: Temporary failure in name resolution
[INFO] [stdout] 
[INFO] [stdout] Stack backtrace:
[INFO] [stdout]    0: anyhow::error::<impl core::convert::From<E> for anyhow::Error>::from
[INFO] [stdout]    1: <core::result::Result<T,F> as core::ops::try_trait::FromResidual<core::result::Result<core::convert::Infallible,E>>>::from_residual
[INFO] [stdout]    2: rateMyProfessorApi_rs::features::search_school::{{closure}}
[INFO] [stdout]    3: rateMyProfessorApi_rs::methods::RateMyProfessor::get_teacher_summary::{{closure}}
[INFO] [stdout]    4: rust_out::main::{{closure}}
[INFO] [stdout]    5: tokio::runtime::park::CachedParkThread::block_on::{{closure}}
[INFO] [stdout]    6: tokio::runtime::park::CachedParkThread::block_on
[INFO] [stdout]    7: tokio::runtime::scheduler::multi_thread::MultiThread::block_on::{{closure}}
[INFO] [stdout]    8: tokio::runtime::context::runtime::enter_runtime
[INFO] [stdout]    9: tokio::runtime::runtime::Runtime::block_on_inner
[INFO] [stdout]   10: tokio::runtime::runtime::Runtime::block_on
[INFO] [stdout]   11: rust_out::main
[INFO] [stdout]   12: core::ops::function::FnOnce::call_once
[INFO] [stdout]   13: std::sys::backtrace::__rust_begin_short_backtrace
[INFO] [stdout]   14: std::rt::lang_start::{{closure}}
[INFO] [stdout]   15: core::ops::function::impls::<impl core::ops::function::FnOnce<A> for &F>::call_once
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/ops/function.rs:284:21
[INFO] [stdout]   16: std::panicking::catch_unwind::do_call
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   17: std::panicking::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   18: std::panic::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   19: std::rt::lang_start_internal::{{closure}}
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:175:24
[INFO] [stdout]   20: std::panicking::catch_unwind::do_call
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   21: std::panicking::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   22: std::panic::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   23: std::rt::lang_start_internal
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:171:5
[INFO] [stdout]   24: std::rt::lang_start
[INFO] [stdout]   25: main
[INFO] [stdout]   26: <unknown>
[INFO] [stdout]   27: __libc_start_main
[INFO] [stdout]   28: _start
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x65052a7366e2 - std::backtrace_rs::backtrace::libunwind::trace::h73a647620bf1c49d
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x65052a7366e2 - std::backtrace_rs::backtrace::trace_unsynchronized::hd4d513ed96cb3cb1
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x65052a7366e2 - std::sys::backtrace::_print_fmt::h61bb95f7476aafa5
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x65052a7366e2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::ha2e7e3a01df69042
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x65052a75bea3 - core::fmt::rt::Argument::fmt::hf14163372f0f9a76
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x65052a75bea3 - core::fmt::write::h7cb8f63788cd01d2
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/fmt/mod.rs:1465:25
[INFO] [stdout]    6:     0x65052a732f23 - std::io::default_write_fmt::h92ac9345fd53cc14
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x65052a732f23 - std::io::Write::write_fmt::h5ebaf381f8338068
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x65052a736532 - std::sys::backtrace::BacktraceLock::print::h3ec4d7883eb25e61
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x65052a7377d6 - std::panicking::default_hook::{{closure}}::h29548987efd832cb
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x65052a7375d9 - std::panicking::default_hook::ha25170a15c643514
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:327:9
[INFO] [stdout]   11:     0x65052a7381e2 - std::panicking::rust_panic_with_hook::h0d81afcd829aa24b
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:833:13
[INFO] [stdout]   12:     0x65052a737f7a - std::panicking::begin_panic_handler::{{closure}}::hc84a33f1202346cf
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:706:13
[INFO] [stdout]   13:     0x65052a736bd9 - std::sys::backtrace::__rust_end_short_backtrace::h373067a14f6c59aa
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:168:18
[INFO] [stdout]   14:     0x65052a737c0d - __rustc[beb0385846a06d21]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:697:5
[INFO] [stdout]   15:     0x65052a759be0 - core::panicking::panic_fmt::ha33fa2ae772efba9
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/panicking.rs:75:14
[INFO] [stdout]   16:     0x65052a759fe6 - core::result::unwrap_failed::hfbbd3c78a73fea3d
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/result.rs:1761:5
[INFO] [stdout]   17:     0x65052a553c12 - rateMyProfessorApi_rs::methods::RateMyProfessor::get_teacher_summary::{{closure}}::h92b2ea644d0a4469
[INFO] [stdout]   18:     0x65052a591028 - rust_out::main::{{closure}}::h95a65277ee6aa83e
[INFO] [stdout]   19:     0x65052a57ad09 - tokio::runtime::park::CachedParkThread::block_on::{{closure}}::hd73a67a1211c68d9
[INFO] [stdout]   20:     0x65052a57a836 - tokio::runtime::park::CachedParkThread::block_on::hb2956ea47457540f
[INFO] [stdout]   21:     0x65052a57b8fe - tokio::runtime::scheduler::multi_thread::MultiThread::block_on::{{closure}}::h1783660b45d9e12e
[INFO] [stdout]   22:     0x65052a57b167 - tokio::runtime::context::runtime::enter_runtime::hcfadd459d855cee3
[INFO] [stdout]   23:     0x65052a57b727 - tokio::runtime::runtime::Runtime::block_on_inner::h434d7cd34ee42af7
[INFO] [stdout]   24:     0x65052a57b862 - tokio::runtime::runtime::Runtime::block_on::h1ed1a05d1f02fe16
[INFO] [stdout]   25:     0x65052a590ba4 - rust_out::main::hef4b5a9d6c0a82f9
[INFO] [stdout]   26:     0x65052a55e123 - core::ops::function::FnOnce::call_once::h090d32f108fbcd74
[INFO] [stdout]   27:     0x65052a55cac6 - std::sys::backtrace::__rust_begin_short_backtrace::h68c860683ded10f3
[INFO] [stdout]   28:     0x65052a55c979 - std::rt::lang_start::{{closure}}::hcda31aff2ef52b23
[INFO] [stdout]   29:     0x65052a72c460 - core::ops::function::impls::<impl core::ops::function::FnOnce<A> for &F>::call_once::hc3929e8466919df6
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/ops/function.rs:284:21
[INFO] [stdout]   30:     0x65052a72c460 - std::panicking::catch_unwind::do_call::hed30a66745299fca
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   31:     0x65052a72c460 - std::panicking::catch_unwind::hdfb0bc9563518507
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   32:     0x65052a72c460 - std::panic::catch_unwind::hd0a1d748acfba573
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   33:     0x65052a72c460 - std::rt::lang_start_internal::{{closure}}::h0c1845f1b3064b93
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:175:24
[INFO] [stdout]   34:     0x65052a72c460 - std::panicking::catch_unwind::do_call::h1114c52e864472d2
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   35:     0x65052a72c460 - std::panicking::catch_unwind::h91938c6665615bc7
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   36:     0x65052a72c460 - std::panic::catch_unwind::h0c65d4211626564a
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   37:     0x65052a72c460 - std::rt::lang_start_internal::hc41e58da8618ff02
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:171:5
[INFO] [stdout]   38:     0x65052a55c961 - std::rt::lang_start::h45b27d135ca47eac
[INFO] [stdout]   39:     0x65052a591285 - main
[INFO] [stdout]   40:     0x770e2abcf1ca - <unknown>
[INFO] [stdout]   41:     0x770e2abcf28b - __libc_start_main
[INFO] [stdout]   42:     0x65052a536295 - _start
[INFO] [stdout]   43:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] ---- src/methods.rs - methods::RateMyProfessor::get_teacher_summary (line 110) stdout ----
[INFO] [stdout] Test executable failed (exit status: 101).
[INFO] [stdout] 
[INFO] [stdout] stdout:
[INFO] [stdout] Object instance before setter method update : RateMyProfessor {
[INFO] [stdout]     CollegeName: "Queens College",
[INFO] [stdout]     ProfessorName: Some(
[INFO] [stdout]         "",
[INFO] [stdout]     ),
[INFO] [stdout] }
[INFO] [stdout] Object instance after setter method update : RateMyProfessor {
[INFO] [stdout]     CollegeName: "Queens College",
[INFO] [stdout]     ProfessorName: Some(
[INFO] [stdout]         "Ross Greenberg",
[INFO] [stdout]     ),
[INFO] [stdout] }
[INFO] [stdout] 
[INFO] [stdout] stderr:
[INFO] [stdout] 
[INFO] [stdout] thread 'main' panicked at /opt/rustwide/workdir/src/methods.rs:160:43:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: error sending request for url (https://www.ratemyprofessors.com/graphql)
[INFO] [stdout] 
[INFO] [stdout] Caused by:
[INFO] [stdout]     0: client error (Connect)
[INFO] [stdout]     1: dns error: failed to lookup address information: Temporary failure in name resolution
[INFO] [stdout]     2: failed to lookup address information: Temporary failure in name resolution
[INFO] [stdout] 
[INFO] [stdout] Stack backtrace:
[INFO] [stdout]    0: anyhow::error::<impl core::convert::From<E> for anyhow::Error>::from
[INFO] [stdout]    1: <core::result::Result<T,F> as core::ops::try_trait::FromResidual<core::result::Result<core::convert::Infallible,E>>>::from_residual
[INFO] [stdout]    2: rateMyProfessorApi_rs::features::search_school::{{closure}}
[INFO] [stdout]    3: rateMyProfessorApi_rs::methods::RateMyProfessor::get_teacher_summary::{{closure}}
[INFO] [stdout]    4: rust_out::main::{{closure}}
[INFO] [stdout]    5: tokio::runtime::park::CachedParkThread::block_on::{{closure}}
[INFO] [stdout]    6: tokio::runtime::park::CachedParkThread::block_on
[INFO] [stdout]    7: tokio::runtime::scheduler::multi_thread::MultiThread::block_on::{{closure}}
[INFO] [stdout]    8: tokio::runtime::context::runtime::enter_runtime
[INFO] [stdout]    9: tokio::runtime::runtime::Runtime::block_on_inner
[INFO] [stdout]   10: tokio::runtime::runtime::Runtime::block_on
[INFO] [stdout]   11: rust_out::main
[INFO] [stdout]   12: core::ops::function::FnOnce::call_once
[INFO] [stdout]   13: std::sys::backtrace::__rust_begin_short_backtrace
[INFO] [stdout]   14: std::rt::lang_start::{{closure}}
[INFO] [stdout]   15: core::ops::function::impls::<impl core::ops::function::FnOnce<A> for &F>::call_once
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/ops/function.rs:284:21
[INFO] [stdout]   16: std::panicking::catch_unwind::do_call
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   17: std::panicking::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   18: std::panic::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   19: std::rt::lang_start_internal::{{closure}}
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:175:24
[INFO] [stdout]   20: std::panicking::catch_unwind::do_call
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   21: std::panicking::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   22: std::panic::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   23: std::rt::lang_start_internal
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:171:5
[INFO] [stdout]   24: std::rt::lang_start
[INFO] [stdout]   25: main
[INFO] [stdout]   26: <unknown>
[INFO] [stdout]   27: __libc_start_main
[INFO] [stdout]   28: _start
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x58ee9b772712 - std::backtrace_rs::backtrace::libunwind::trace::h73a647620bf1c49d
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x58ee9b772712 - std::backtrace_rs::backtrace::trace_unsynchronized::hd4d513ed96cb3cb1
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x58ee9b772712 - std::sys::backtrace::_print_fmt::h61bb95f7476aafa5
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x58ee9b772712 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::ha2e7e3a01df69042
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x58ee9b797ed3 - core::fmt::rt::Argument::fmt::hf14163372f0f9a76
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x58ee9b797ed3 - core::fmt::write::h7cb8f63788cd01d2
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/fmt/mod.rs:1465:25
[INFO] [stdout]    6:     0x58ee9b76ef53 - std::io::default_write_fmt::h92ac9345fd53cc14
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x58ee9b76ef53 - std::io::Write::write_fmt::h5ebaf381f8338068
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x58ee9b772562 - std::sys::backtrace::BacktraceLock::print::h3ec4d7883eb25e61
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x58ee9b773806 - std::panicking::default_hook::{{closure}}::h29548987efd832cb
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x58ee9b773609 - std::panicking::default_hook::ha25170a15c643514
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:327:9
[INFO] [stdout]   11:     0x58ee9b774212 - std::panicking::rust_panic_with_hook::h0d81afcd829aa24b
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:833:13
[INFO] [stdout]   12:     0x58ee9b773faa - std::panicking::begin_panic_handler::{{closure}}::hc84a33f1202346cf
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:706:13
[INFO] [stdout]   13:     0x58ee9b772c09 - std::sys::backtrace::__rust_end_short_backtrace::h373067a14f6c59aa
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:168:18
[INFO] [stdout]   14:     0x58ee9b773c3d - __rustc[beb0385846a06d21]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:697:5
[INFO] [stdout]   15:     0x58ee9b795c10 - core::panicking::panic_fmt::ha33fa2ae772efba9
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/panicking.rs:75:14
[INFO] [stdout]   16:     0x58ee9b796016 - core::result::unwrap_failed::hfbbd3c78a73fea3d
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/result.rs:1761:5
[INFO] [stdout]   17:     0x58ee9b5902d2 - rateMyProfessorApi_rs::methods::RateMyProfessor::get_teacher_summary::{{closure}}::h92b2ea644d0a4469
[INFO] [stdout]   18:     0x58ee9b5ccbb6 - rust_out::main::{{closure}}::h95a65277ee6aa83e
[INFO] [stdout]   19:     0x58ee9b5b6fe9 - tokio::runtime::park::CachedParkThread::block_on::{{closure}}::hd73a67a1211c68d9
[INFO] [stdout]   20:     0x58ee9b5b6b16 - tokio::runtime::park::CachedParkThread::block_on::hb2956ea47457540f
[INFO] [stdout]   21:     0x58ee9b5b7bde - tokio::runtime::scheduler::multi_thread::MultiThread::block_on::{{closure}}::h1783660b45d9e12e
[INFO] [stdout]   22:     0x58ee9b5b7447 - tokio::runtime::context::runtime::enter_runtime::hcfadd459d855cee3
[INFO] [stdout]   23:     0x58ee9b5b7a07 - tokio::runtime::runtime::Runtime::block_on_inner::h434d7cd34ee42af7
[INFO] [stdout]   24:     0x58ee9b5b7b42 - tokio::runtime::runtime::Runtime::block_on::h1ed1a05d1f02fe16
[INFO] [stdout]   25:     0x58ee9b5cc884 - rust_out::main::hef4b5a9d6c0a82f9
[INFO] [stdout]   26:     0x58ee9b59a443 - core::ops::function::FnOnce::call_once::h090d32f108fbcd74
[INFO] [stdout]   27:     0x58ee9b599186 - std::sys::backtrace::__rust_begin_short_backtrace::h68c860683ded10f3
[INFO] [stdout]   28:     0x58ee9b599039 - std::rt::lang_start::{{closure}}::hcda31aff2ef52b23
[INFO] [stdout]   29:     0x58ee9b768490 - core::ops::function::impls::<impl core::ops::function::FnOnce<A> for &F>::call_once::hc3929e8466919df6
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/ops/function.rs:284:21
[INFO] [stdout]   30:     0x58ee9b768490 - std::panicking::catch_unwind::do_call::hed30a66745299fca
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   31:     0x58ee9b768490 - std::panicking::catch_unwind::hdfb0bc9563518507
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   32:     0x58ee9b768490 - std::panic::catch_unwind::hd0a1d748acfba573
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   33:     0x58ee9b768490 - std::rt::lang_start_internal::{{closure}}::h0c1845f1b3064b93
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:175:24
[INFO] [stdout]   34:     0x58ee9b768490 - std::panicking::catch_unwind::do_call::h1114c52e864472d2
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   35:     0x58ee9b768490 - std::panicking::catch_unwind::h91938c6665615bc7
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   36:     0x58ee9b768490 - std::panic::catch_unwind::h0c65d4211626564a
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   37:     0x58ee9b768490 - std::rt::lang_start_internal::hc41e58da8618ff02
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:171:5
[INFO] [stdout]   38:     0x58ee9b599021 - std::rt::lang_start::h45b27d135ca47eac
[INFO] [stdout]   39:     0x58ee9b5cd175 - main
[INFO] [stdout]   40:     0x72b2fb7001ca - <unknown>
[INFO] [stdout]   41:     0x72b2fb70028b - __libc_start_main
[INFO] [stdout]   42:     0x58ee9b572bc5 - _start
[INFO] [stdout]   43:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] ---- src/methods.rs - methods::RateMyProfessor::get_teacher_summary_and_save (line 215) stdout ----
[INFO] [stdout] Test executable failed (exit status: 101).
[INFO] [stdout] 
[INFO] [stdout] stdout:
[INFO] [stdout] RateMyProfessor {
[INFO] [stdout]     CollegeName: "City College of New York",
[INFO] [stdout]     ProfessorName: Some(
[INFO] [stdout]         "Jie Wei",
[INFO] [stdout]     ),
[INFO] [stdout] }
[INFO] [stdout] 
[INFO] [stdout] stderr:
[INFO] [stdout] 
[INFO] [stdout] thread 'main' panicked at /opt/rustwide/workdir/src/methods.rs:160:43:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: error sending request for url (https://www.ratemyprofessors.com/graphql)
[INFO] [stdout] 
[INFO] [stdout] Caused by:
[INFO] [stdout]     0: client error (Connect)
[INFO] [stdout]     1: dns error: failed to lookup address information: Temporary failure in name resolution
[INFO] [stdout]     2: failed to lookup address information: Temporary failure in name resolution
[INFO] [stdout] 
[INFO] [stdout] Stack backtrace:
[INFO] [stdout]    0: anyhow::error::<impl core::convert::From<E> for anyhow::Error>::from
[INFO] [stdout]    1: <core::result::Result<T,F> as core::ops::try_trait::FromResidual<core::result::Result<core::convert::Infallible,E>>>::from_residual
[INFO] [stdout]    2: rateMyProfessorApi_rs::features::search_school::{{closure}}
[INFO] [stdout]    3: rateMyProfessorApi_rs::methods::RateMyProfessor::get_teacher_summary::{{closure}}
[INFO] [stdout]    4: rateMyProfessorApi_rs::methods::RateMyProfessor::get_teacher_summary_and_save::{{closure}}
[INFO] [stdout]    5: rust_out::main::{{closure}}
[INFO] [stdout]    6: tokio::runtime::park::CachedParkThread::block_on::{{closure}}
[INFO] [stdout]    7: tokio::runtime::park::CachedParkThread::block_on
[INFO] [stdout]    8: tokio::runtime::scheduler::multi_thread::MultiThread::block_on::{{closure}}
[INFO] [stdout]    9: tokio::runtime::context::runtime::enter_runtime
[INFO] [stdout]   10: tokio::runtime::runtime::Runtime::block_on_inner
[INFO] [stdout]   11: tokio::runtime::runtime::Runtime::block_on
[INFO] [stdout]   12: rust_out::main
[INFO] [stdout]   13: core::ops::function::FnOnce::call_once
[INFO] [stdout]   14: std::sys::backtrace::__rust_begin_short_backtrace
[INFO] [stdout]   15: std::rt::lang_start::{{closure}}
[INFO] [stdout]   16: core::ops::function::impls::<impl core::ops::function::FnOnce<A> for &F>::call_once
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/ops/function.rs:284:21
[INFO] [stdout]   17: std::panicking::catch_unwind::do_call
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   18: std::panicking::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   19: std::panic::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   20: std::rt::lang_start_internal::{{closure}}
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:175:24
[INFO] [stdout]   21: std::panicking::catch_unwind::do_call
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   22: std::panicking::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   23: std::panic::catch_unwind
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   24: std::rt::lang_start_internal
[INFO] [stdout]              at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:171:5
[INFO] [stdout]   25: std::rt::lang_start
[INFO] [stdout]   26: main
[INFO] [stdout]   27: <unknown>
[INFO] [stdout]   28: __libc_start_main
[INFO] [stdout]   29: _start
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5f2c5b36aaf2 - std::backtrace_rs::backtrace::libunwind::trace::h73a647620bf1c49d
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5f2c5b36aaf2 - std::backtrace_rs::backtrace::trace_unsynchronized::hd4d513ed96cb3cb1
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5f2c5b36aaf2 - std::sys::backtrace::_print_fmt::h61bb95f7476aafa5
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5f2c5b36aaf2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::ha2e7e3a01df69042
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5f2c5b3902b3 - core::fmt::rt::Argument::fmt::hf14163372f0f9a76
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5f2c5b3902b3 - core::fmt::write::h7cb8f63788cd01d2
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/fmt/mod.rs:1465:25
[INFO] [stdout]    6:     0x5f2c5b367333 - std::io::default_write_fmt::h92ac9345fd53cc14
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5f2c5b367333 - std::io::Write::write_fmt::h5ebaf381f8338068
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5f2c5b36a942 - std::sys::backtrace::BacktraceLock::print::h3ec4d7883eb25e61
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5f2c5b36bbe6 - std::panicking::default_hook::{{closure}}::h29548987efd832cb
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x5f2c5b36b9e9 - std::panicking::default_hook::ha25170a15c643514
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:327:9
[INFO] [stdout]   11:     0x5f2c5b36c5f2 - std::panicking::rust_panic_with_hook::h0d81afcd829aa24b
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:833:13
[INFO] [stdout]   12:     0x5f2c5b36c38a - std::panicking::begin_panic_handler::{{closure}}::hc84a33f1202346cf
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:706:13
[INFO] [stdout]   13:     0x5f2c5b36afe9 - std::sys::backtrace::__rust_end_short_backtrace::h373067a14f6c59aa
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/sys/backtrace.rs:168:18
[INFO] [stdout]   14:     0x5f2c5b36c01d - __rustc[beb0385846a06d21]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:697:5
[INFO] [stdout]   15:     0x5f2c5b38dff0 - core::panicking::panic_fmt::ha33fa2ae772efba9
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/panicking.rs:75:14
[INFO] [stdout]   16:     0x5f2c5b38e3f6 - core::result::unwrap_failed::hfbbd3c78a73fea3d
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/result.rs:1761:5
[INFO] [stdout]   17:     0x5f2c5b187752 - rateMyProfessorApi_rs::methods::RateMyProfessor::get_teacher_summary::{{closure}}::h92b2ea644d0a4469
[INFO] [stdout]   18:     0x5f2c5b188d37 - rateMyProfessorApi_rs::methods::RateMyProfessor::get_teacher_summary_and_save::{{closure}}::h04bbb34f186b89ea
[INFO] [stdout]   19:     0x5f2c5b1c544f - rust_out::main::{{closure}}::h95a65277ee6aa83e
[INFO] [stdout]   20:     0x5f2c5b1af7a9 - tokio::runtime::park::CachedParkThread::block_on::{{closure}}::hd73a67a1211c68d9
[INFO] [stdout]   21:     0x5f2c5b1af2d6 - tokio::runtime::park::CachedParkThread::block_on::hb2956ea47457540f
[INFO] [stdout]   22:     0x5f2c5b1b039e - tokio::runtime::scheduler::multi_thread::MultiThread::block_on::{{closure}}::h1783660b45d9e12e
[INFO] [stdout]   23:     0x5f2c5b1afc07 - tokio::runtime::context::runtime::enter_runtime::hcfadd459d855cee3
[INFO] [stdout]   24:     0x5f2c5b1b01c7 - tokio::runtime::runtime::Runtime::block_on_inner::h434d7cd34ee42af7
[INFO] [stdout]   25:     0x5f2c5b1b0302 - tokio::runtime::runtime::Runtime::block_on::h1ed1a05d1f02fe16
[INFO] [stdout]   26:     0x5f2c5b1c51b7 - rust_out::main::hef4b5a9d6c0a82f9
[INFO] [stdout]   27:     0x5f2c5b1926b3 - core::ops::function::FnOnce::call_once::h090d32f108fbcd74
[INFO] [stdout]   28:     0x5f2c5b1913f6 - std::sys::backtrace::__rust_begin_short_backtrace::h68c860683ded10f3
[INFO] [stdout]   29:     0x5f2c5b1912a9 - std::rt::lang_start::{{closure}}::hcda31aff2ef52b23
[INFO] [stdout]   30:     0x5f2c5b360870 - core::ops::function::impls::<impl core::ops::function::FnOnce<A> for &F>::call_once::hc3929e8466919df6
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/core/src/ops/function.rs:284:21
[INFO] [stdout]   31:     0x5f2c5b360870 - std::panicking::catch_unwind::do_call::hed30a66745299fca
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   32:     0x5f2c5b360870 - std::panicking::catch_unwind::hdfb0bc9563518507
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   33:     0x5f2c5b360870 - std::panic::catch_unwind::hd0a1d748acfba573
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   34:     0x5f2c5b360870 - std::rt::lang_start_internal::{{closure}}::h0c1845f1b3064b93
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:175:24
[INFO] [stdout]   35:     0x5f2c5b360870 - std::panicking::catch_unwind::do_call::h1114c52e864472d2
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:589:40
[INFO] [stdout]   36:     0x5f2c5b360870 - std::panicking::catch_unwind::h91938c6665615bc7
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panicking.rs:552:19
[INFO] [stdout]   37:     0x5f2c5b360870 - std::panic::catch_unwind::h0c65d4211626564a
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/panic.rs:359:14
[INFO] [stdout]   38:     0x5f2c5b360870 - std::rt::lang_start_internal::hc41e58da8618ff02
[INFO] [stdout]                                at /rustc/733b47ea4b1b86216f14ef56e49440c33933f230/library/std/src/rt.rs:171:5
[INFO] [stdout]   39:     0x5f2c5b191291 - std::rt::lang_start::h45b27d135ca47eac
[INFO] [stdout]   40:     0x5f2c5b1c5695 - main
[INFO] [stdout]   41:     0x75f6c81191ca - <unknown>
[INFO] [stdout]   42:     0x75f6c811928b - __libc_start_main
[INFO] [stdout]   43:     0x5f2c5b169e15 - _start
[INFO] [stdout]   44:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     src/methods.rs - methods::RateMyProfessor::construct_college (line 25)
[INFO] [stdout]     src/methods.rs - methods::RateMyProfessor::construct_college_and_professor (line 62)
[INFO] [stdout]     src/methods.rs - methods::RateMyProfessor::get_professor_comments (line 290)
[INFO] [stdout]     src/methods.rs - methods::RateMyProfessor::get_professor_list (line 355)
[INFO] [stdout]     src/methods.rs - methods::RateMyProfessor::get_teacher_summary (line 110)
[INFO] [stdout]     src/methods.rs - methods::RateMyProfessor::get_teacher_summary_and_save (line 215)
[INFO] [stdout]     src/methods.rs - methods::main (line 440)
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 7 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.62s
[INFO] [stdout] 
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] running `Command { std: "docker" "inspect" "8876304cbb875c24e2d3cc7e234e18a0f0db3d4d843eac354c916af62fdb0934", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8876304cbb875c24e2d3cc7e234e18a0f0db3d4d843eac354c916af62fdb0934", kill_on_drop: false }`
[INFO] [stdout] 8876304cbb875c24e2d3cc7e234e18a0f0db3d4d843eac354c916af62fdb0934
