[INFO] cloning repository https://github.com/deepm1nd/gsheets_mcp
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/deepm1nd/gsheets_mcp" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdeepm1nd%2Fgsheets_mcp", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdeepm1nd%2Fgsheets_mcp'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] ce1c4503ce5c283fa9d51460c1a5c3dc97ed05ed
[INFO] checking deepm1nd/gsheets_mcp against try#9b8307bcb9d1de8ffc7e1c81c48efffdb24ee840 for pr-149518
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdeepm1nd%2Fgsheets_mcp" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/deepm1nd/gsheets_mcp
[INFO] finished tweaking git repo https://github.com/deepm1nd/gsheets_mcp
[INFO] tweaked toml for git repo https://github.com/deepm1nd/gsheets_mcp written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/deepm1nd/gsheets_mcp on toolchain 9b8307bcb9d1de8ffc7e1c81c48efffdb24ee840
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+9b8307bcb9d1de8ffc7e1c81c48efffdb24ee840" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/deepm1nd/gsheets_mcp 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" "+9b8307bcb9d1de8ffc7e1c81c48efffdb24ee840" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded hyper-rustls v0.25.0
[INFO] [stderr]   Downloaded google-calendar3 v5.0.5+20240328
[INFO] [stderr]   Downloaded yup-oauth2 v9.0.0
[INFO] [stderr]   Downloaded google-apis-common v6.0.4
[INFO] [stderr]   Downloaded google-sheets4 v5.0.4+20240229
[INFO] [stderr]   Downloaded google-drive3 v5.0.4+20240227
[INFO] [stderr]   Downloaded google-docs1 v5.0.5+20240613
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:94a0c148923f5b2b52a63ef0eeb1882ad339ab61bce784c8077cbe41c61feb6c" "/opt/rustwide/cargo-home/bin/cargo" "+9b8307bcb9d1de8ffc7e1c81c48efffdb24ee840" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] c61cd2da52fa765d098f0d6d49e0863092d2dd3a017e060b3bdeaa8c8b6b0d64
[INFO] running `Command { std: "docker" "start" "-a" "c61cd2da52fa765d098f0d6d49e0863092d2dd3a017e060b3bdeaa8c8b6b0d64", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c61cd2da52fa765d098f0d6d49e0863092d2dd3a017e060b3bdeaa8c8b6b0d64", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c61cd2da52fa765d098f0d6d49e0863092d2dd3a017e060b3bdeaa8c8b6b0d64", kill_on_drop: false }`
[INFO] [stdout] c61cd2da52fa765d098f0d6d49e0863092d2dd3a017e060b3bdeaa8c8b6b0d64
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:94a0c148923f5b2b52a63ef0eeb1882ad339ab61bce784c8077cbe41c61feb6c" "/opt/rustwide/cargo-home/bin/cargo" "+9b8307bcb9d1de8ffc7e1c81c48efffdb24ee840" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 8c8a9228f5db044db97d8a96f1debf672bb80f5e90a1fb7daa881839b09db0db
[INFO] running `Command { std: "docker" "start" "-a" "8c8a9228f5db044db97d8a96f1debf672bb80f5e90a1fb7daa881839b09db0db", kill_on_drop: false }`
[INFO] [stderr]    Compiling cc v1.2.27
[INFO] [stderr]     Checking hashbrown v0.15.4
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking serde v1.0.219
[INFO] [stderr]     Checking tokio v1.46.0
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling rustls v0.22.4
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]     Checking rustls-native-certs v0.7.3
[INFO] [stderr]     Checking icu_normalizer v2.0.0
[INFO] [stderr]    Compiling ahash v0.7.8
[INFO] [stderr]    Compiling rustls v0.21.12
[INFO] [stderr]    Compiling ucd-trie v0.1.7
[INFO] [stderr]     Checking seahash v4.1.0
[INFO] [stderr]     Checking idna v0.1.5
[INFO] [stderr]     Checking itertools v0.10.5
[INFO] [stderr]     Checking rustls-native-certs v0.6.3
[INFO] [stderr]     Checking dlv-list v0.3.0
[INFO] [stderr]    Compiling pest v2.8.1
[INFO] [stderr]     Checking regex-syntax v0.8.5
[INFO] [stderr]     Checking linked-hash-map v0.5.6
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking thread_local v1.1.9
[INFO] [stderr]     Checking yaml-rust v0.4.5
[INFO] [stderr]     Checking pathdiff v0.2.3
[INFO] [stderr]     Checking hashbrown v0.12.3
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking indexmap v2.10.0
[INFO] [stderr]     Checking url v1.7.2
[INFO] [stderr]     Checking idna v1.0.3
[INFO] [stderr]     Checking url v2.5.4
[INFO] [stderr]     Checking ordered-multimap v0.4.3
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling openssl-sys v0.9.109
[INFO] [stderr]     Checking regex-automata v0.4.9
[INFO] [stderr]     Checking rust-ini v0.18.0
[INFO] [stderr]    Compiling openssl v0.10.73
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling pest_meta v2.8.1
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling serde_with_macros v3.14.0
[INFO] [stderr]    Compiling pest_generator v2.8.1
[INFO] [stderr]     Checking regex v1.11.1
[INFO] [stderr]     Checking deranged v0.4.0
[INFO] [stderr]     Checking chrono v0.4.41
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking toml v0.5.11
[INFO] [stderr]     Checking tracing-serde v0.2.0
[INFO] [stderr]     Checking ron v0.7.1
[INFO] [stderr]     Checking serde_path_to_error v0.1.17
[INFO] [stderr]     Checking serde_with v3.14.0
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking axum-core v0.4.5
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]    Compiling pest_derive v2.8.1
[INFO] [stderr]     Checking json5 v0.4.1
[INFO] [stderr]     Checking time v0.3.41
[INFO] [stderr]     Checking tracing-subscriber v0.3.19
[INFO] [stderr]     Checking config v0.13.4
[INFO] [stderr]     Checking tokio-util v0.7.15
[INFO] [stderr]     Checking hyper v1.6.0
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking rustls-webpki v0.102.8
[INFO] [stderr]     Checking sct v0.7.1
[INFO] [stderr]     Checking rustls-webpki v0.101.7
[INFO] [stderr]     Checking hyper-util v0.1.14
[INFO] [stderr]     Checking h2 v0.3.26
[INFO] [stderr]     Checking axum v0.7.9
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking tokio-rustls v0.24.1
[INFO] [stderr]     Checking tokio-rustls v0.25.0
[INFO] [stderr]     Checking hyper v0.14.32
[INFO] [stderr]     Checking hyper-rustls v0.25.0
[INFO] [stderr]     Checking hyper-rustls v0.24.2
[INFO] [stderr]     Checking hyper-tls v0.5.0
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking yup-oauth2 v9.0.0
[INFO] [stderr]     Checking google-apis-common v6.0.4
[INFO] [stderr]     Checking google-docs1 v5.0.5+20240613
[INFO] [stderr]     Checking google-drive3 v5.0.4+20240227
[INFO] [stderr]     Checking google-calendar3 v5.0.5+20240328
[INFO] [stderr]     Checking google-sheets4 v5.0.4+20240229
[INFO] [stderr]     Checking gsheets_mcp v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::str::FromStr`
[INFO] [stdout]  --> src/auth_manager.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::str::FromStr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `google_docs1::api::Scope`
[INFO] [stdout]    --> src/models.rs:393:13
[INFO] [stdout]     |
[INFO] [stdout] 393 |         use google_docs1::api::Scope;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Permission`
[INFO] [stdout]  --> src/google_api_client.rs:1:36
[INFO] [stdout]   |
[INFO] [stdout] 1 | use google_drive3::api::{DriveHub, Permission};
[INFO] [stdout]   |                                    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ServiceAccountKey`
[INFO] [stdout]  --> src/google_api_client.rs:5:47
[INFO] [stdout]   |
[INFO] [stdout] 5 | use yup_oauth2::{ServiceAccountAuthenticator, ServiceAccountKey, read_service_account_key};
[INFO] [stdout]   |                                               ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `google_drive3::api::Scope`
[INFO] [stdout]   --> src/google_api_client.rs:90:13
[INFO] [stdout]    |
[INFO] [stdout] 90 |         use google_drive3::api::Scope;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::str::FromStr`
[INFO] [stdout]  --> src/auth_manager.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::str::FromStr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `google_docs1::api::Scope`
[INFO] [stdout]    --> src/models.rs:393:13
[INFO] [stdout]     |
[INFO] [stdout] 393 |         use google_docs1::api::Scope;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Permission`
[INFO] [stdout]  --> src/google_api_client.rs:1:36
[INFO] [stdout]   |
[INFO] [stdout] 1 | use google_drive3::api::{DriveHub, Permission};
[INFO] [stdout]   |                                    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ServiceAccountKey`
[INFO] [stdout]  --> src/google_api_client.rs:5:47
[INFO] [stdout]   |
[INFO] [stdout] 5 | use yup_oauth2::{ServiceAccountAuthenticator, ServiceAccountKey, read_service_account_key};
[INFO] [stdout]   |                                               ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `google_drive3::api::Scope`
[INFO] [stdout]   --> src/google_api_client.rs:90:13
[INFO] [stdout]    |
[INFO] [stdout] 90 |         use google_drive3::api::Scope;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/google_api_client.rs:91:13
[INFO] [stdout]    |
[INFO] [stdout] 91 |         let mut drive = self.drive.lock().await;
[INFO] [stdout]    |             ----^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/google_api_client.rs:109:13
[INFO] [stdout]     |
[INFO] [stdout] 109 |         let mut drive = self.drive.lock().await;
[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/google_api_client.rs:122:13
[INFO] [stdout]     |
[INFO] [stdout] 122 |         let mut drive = self.drive.lock().await;
[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/google_api_client.rs:91:13
[INFO] [stdout]    |
[INFO] [stdout] 91 |         let mut drive = self.drive.lock().await;
[INFO] [stdout]    |             ----^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/google_api_client.rs:109:13
[INFO] [stdout]     |
[INFO] [stdout] 109 |         let mut drive = self.drive.lock().await;
[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/google_api_client.rs:122:13
[INFO] [stdout]     |
[INFO] [stdout] 122 |         let mut drive = self.drive.lock().await;
[INFO] [stdout]     |             ----^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `key_path`
[INFO] [stdout]   --> src/auth_manager.rs:26:21
[INFO] [stdout]    |
[INFO] [stdout] 26 |         if let Some(ref key_path) = _config.auth.service_account_key_path {
[INFO] [stdout]    |                     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_key_path`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `key_path`
[INFO] [stdout]   --> src/auth_manager.rs:26:21
[INFO] [stdout]    |
[INFO] [stdout] 26 |         if let Some(ref key_path) = _config.auth.service_account_key_path {
[INFO] [stdout]    |                     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_key_path`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `spreadsheet_id`
[INFO] [stdout]   --> src/google_api_client.rs:59:40
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub async fn get_sheet_data(&self, spreadsheet_id: &str, range: &str) -> Result<Vec<Vec<String>>, String> {
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_spreadsheet_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `range`
[INFO] [stdout]   --> src/google_api_client.rs:59:62
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub async fn get_sheet_data(&self, spreadsheet_id: &str, range: &str) -> Result<Vec<Vec<String>>, String> {
[INFO] [stdout]    |                                                              ^^^^^ help: if this is intentional, prefix it with an underscore: `_range`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `spreadsheet_id`
[INFO] [stdout]   --> src/google_api_client.rs:64:40
[INFO] [stdout]    |
[INFO] [stdout] 64 |     pub async fn set_sheet_data(&self, spreadsheet_id: &str, range: &str, values: Vec<Vec<String>>) -> Result<usize, String> {
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_spreadsheet_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `range`
[INFO] [stdout]   --> src/google_api_client.rs:64:62
[INFO] [stdout]    |
[INFO] [stdout] 64 |     pub async fn set_sheet_data(&self, spreadsheet_id: &str, range: &str, values: Vec<Vec<String>>) -> Result<usize, String> {
[INFO] [stdout]    |                                                              ^^^^^ help: if this is intentional, prefix it with an underscore: `_range`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `spreadsheet_id`
[INFO] [stdout]   --> src/google_api_client.rs:69:46
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub async fn batch_get_sheet_data(&self, spreadsheet_id: &str, ranges: &Vec<String>) -> Result<Vec<Vec<Vec<String>>>, String> {
[INFO] [stdout]    |                                              ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_spreadsheet_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `spreadsheet_id`
[INFO] [stdout]   --> src/google_api_client.rs:59:40
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub async fn get_sheet_data(&self, spreadsheet_id: &str, range: &str) -> Result<Vec<Vec<String>>, String> {
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_spreadsheet_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `range`
[INFO] [stdout]   --> src/google_api_client.rs:59:62
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub async fn get_sheet_data(&self, spreadsheet_id: &str, range: &str) -> Result<Vec<Vec<String>>, String> {
[INFO] [stdout]    |                                                              ^^^^^ help: if this is intentional, prefix it with an underscore: `_range`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `spreadsheet_id`
[INFO] [stdout]   --> src/google_api_client.rs:74:46
[INFO] [stdout]    |
[INFO] [stdout] 74 | ...sheet_data(&self, spreadsheet_id: &str, updates: &Vec<(String, Vec<Vec<String>>)>) -> Result<usize, String> {
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_spreadsheet_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `spreadsheet_id`
[INFO] [stdout]   --> src/google_api_client.rs:64:40
[INFO] [stdout]    |
[INFO] [stdout] 64 |     pub async fn set_sheet_data(&self, spreadsheet_id: &str, range: &str, values: Vec<Vec<String>>) -> Result<usize, String> {
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_spreadsheet_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `range`
[INFO] [stdout]   --> src/google_api_client.rs:64:62
[INFO] [stdout]    |
[INFO] [stdout] 64 |     pub async fn set_sheet_data(&self, spreadsheet_id: &str, range: &str, values: Vec<Vec<String>>) -> Result<usize, String> {
[INFO] [stdout]    |                                                              ^^^^^ help: if this is intentional, prefix it with an underscore: `_range`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `spreadsheet_id`
[INFO] [stdout]   --> src/google_api_client.rs:69:46
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub async fn batch_get_sheet_data(&self, spreadsheet_id: &str, ranges: &Vec<String>) -> Result<Vec<Vec<Vec<String>>>, String> {
[INFO] [stdout]    |                                              ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_spreadsheet_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `spreadsheet_id`
[INFO] [stdout]   --> src/google_api_client.rs:74:46
[INFO] [stdout]    |
[INFO] [stdout] 74 | ...sheet_data(&self, spreadsheet_id: &str, updates: &Vec<(String, Vec<Vec<String>>)>) -> Result<usize, String> {
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_spreadsheet_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> tests/unit.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CreateSpreadsheetResponse` and `ListSpreadsheetsResponse`
[INFO] [stdout]  --> tests/e2e.rs:5:55
[INFO] [stdout]   |
[INFO] [stdout] 5 |     ListSpreadsheetsHandler, ListSpreadsheetsRequest, ListSpreadsheetsResponse,
[INFO] [stdout]   |                                                       ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 6 |     CreateSpreadsheetHandler, CreateSpreadsheetRequest, CreateSpreadsheetResponse,
[INFO] [stdout]   |                                                         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 37.33s
[INFO] running `Command { std: "docker" "inspect" "8c8a9228f5db044db97d8a96f1debf672bb80f5e90a1fb7daa881839b09db0db", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8c8a9228f5db044db97d8a96f1debf672bb80f5e90a1fb7daa881839b09db0db", kill_on_drop: false }`
[INFO] [stdout] 8c8a9228f5db044db97d8a96f1debf672bb80f5e90a1fb7daa881839b09db0db
