[INFO] cloning repository https://github.com/thisisbintang/ICP-Testing [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/thisisbintang/ICP-Testing" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fthisisbintang%2FICP-Testing", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fthisisbintang%2FICP-Testing'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] ee96552be504c88caf9a71cea7c244cd51b2a568 [INFO] checking thisisbintang/ICP-Testing against try#d8a5ee01b913730aca7ab44c72c8f2722c0533ff for pr-139022 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fthisisbintang%2FICP-Testing" "/workspace/builds/worker-4-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc2/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/thisisbintang/ICP-Testing on toolchain d8a5ee01b913730aca7ab44c72c8f2722c0533ff [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d8a5ee01b913730aca7ab44c72c8f2722c0533ff" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/thisisbintang/ICP-Testing [INFO] finished tweaking git repo https://github.com/thisisbintang/ICP-Testing [INFO] tweaked toml for git repo https://github.com/thisisbintang/ICP-Testing written to /workspace/builds/worker-4-tc2/source/Cargo.toml [INFO] crate git repo https://github.com/thisisbintang/ICP-Testing 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" "+d8a5ee01b913730aca7ab44c72c8f2722c0533ff" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] warning: virtual workspace defaulting to `resolver = "1"` despite one or more workspace members being on edition 2021 which implies `resolver = "2"` [INFO] [stderr] note: to keep the current resolver, specify `workspace.resolver = "1"` in the workspace root's manifest [INFO] [stderr] note: to use the edition 2021 resolver, specify `workspace.resolver = "2"` in the workspace root's manifest [INFO] [stderr] note: for more details see https://doc.rust-lang.org/cargo/reference/resolver.html#resolver-versions [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4b26683ee3c49f365255c425c23003cbf4366de097804722c29c5bbbee3624d2" "/opt/rustwide/cargo-home/bin/cargo" "+d8a5ee01b913730aca7ab44c72c8f2722c0533ff" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 5581d6023ac4f660ce00fe8a020fb8b50197aaeccbf06604aebd3ae47e94808d [INFO] running `Command { std: "docker" "start" "-a" "5581d6023ac4f660ce00fe8a020fb8b50197aaeccbf06604aebd3ae47e94808d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "5581d6023ac4f660ce00fe8a020fb8b50197aaeccbf06604aebd3ae47e94808d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5581d6023ac4f660ce00fe8a020fb8b50197aaeccbf06604aebd3ae47e94808d", kill_on_drop: false }` [INFO] [stdout] 5581d6023ac4f660ce00fe8a020fb8b50197aaeccbf06604aebd3ae47e94808d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4b26683ee3c49f365255c425c23003cbf4366de097804722c29c5bbbee3624d2" "/opt/rustwide/cargo-home/bin/cargo" "+d8a5ee01b913730aca7ab44c72c8f2722c0533ff" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 6948049ef9c63eb3101334d0a46337f227d328e4d9f2de0cc58b97457c006ac6 [INFO] running `Command { std: "docker" "start" "-a" "6948049ef9c63eb3101334d0a46337f227d328e4d9f2de0cc58b97457c006ac6", kill_on_drop: false }` [INFO] [stderr] warning: virtual workspace defaulting to `resolver = "1"` despite one or more workspace members being on edition 2021 which implies `resolver = "2"` [INFO] [stderr] note: to keep the current resolver, specify `workspace.resolver = "1"` in the workspace root's manifest [INFO] [stderr] note: to use the edition 2021 resolver, specify `workspace.resolver = "2"` in the workspace root's manifest [INFO] [stderr] note: for more details see https://doc.rust-lang.org/cargo/reference/resolver.html#resolver-versions [INFO] [stderr] Compiling proc-macro2 v1.0.69 [INFO] [stderr] Compiling unicode-ident v1.0.12 [INFO] [stderr] Compiling autocfg v1.1.0 [INFO] [stderr] Compiling version_check v0.9.4 [INFO] [stderr] Compiling serde v1.0.188 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling cc v1.2.5 [INFO] [stderr] Compiling hashbrown v0.14.1 [INFO] [stderr] Compiling winnow v0.5.16 [INFO] [stderr] Compiling toml_datetime v0.6.3 [INFO] [stderr] Compiling libc v0.2.169 [INFO] [stderr] Compiling generic-array v0.14.7 [INFO] [stderr] Compiling once_cell v1.18.0 [INFO] [stderr] Compiling num-traits v0.2.17 [INFO] [stderr] Compiling num-integer v0.1.45 [INFO] [stderr] Compiling rustversion v1.0.14 [INFO] [stderr] Compiling num-bigint v0.4.4 [INFO] [stderr] Compiling either v1.9.0 [INFO] [stderr] Compiling indexmap v2.0.2 [INFO] [stderr] Compiling quote v1.0.33 [INFO] [stderr] Compiling anyhow v1.0.75 [INFO] [stderr] Compiling thiserror v1.0.49 [INFO] [stderr] Compiling crc32fast v1.3.2 [INFO] [stderr] Compiling syn v2.0.38 [INFO] [stderr] Compiling lazy_static v1.4.0 [INFO] [stderr] Compiling paste v1.0.14 [INFO] [stderr] Compiling crypto-common v0.1.6 [INFO] [stderr] Compiling block-buffer v0.10.4 [INFO] [stderr] Compiling unicode-width v0.1.11 [INFO] [stderr] Compiling candid v0.9.11 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling psm v0.1.24 [INFO] [stderr] Compiling stacker v0.1.17 [INFO] [stderr] Compiling toml_edit v0.19.15 [INFO] [stderr] Compiling typed-arena v2.0.2 [INFO] [stderr] Compiling termcolor v1.3.0 [INFO] [stderr] Compiling cpufeatures v0.2.9 [INFO] [stderr] Compiling arrayvec v0.5.2 [INFO] [stderr] Compiling codespan-reporting v0.11.1 [INFO] [stderr] Compiling pretty v0.12.3 [INFO] [stderr] Compiling sha2 v0.10.8 [INFO] [stderr] Compiling leb128 v0.2.5 [INFO] [stderr] Compiling byteorder v1.5.0 [INFO] [stderr] Compiling data-encoding v2.4.0 [INFO] [stderr] Compiling serde_json v1.0.109 [INFO] [stderr] Compiling proc-macro-crate v1.3.1 [INFO] [stderr] Checking itoa v1.0.14 [INFO] [stderr] Checking ic0 v0.21.1 [INFO] [stderr] Checking ic-stable-structures v0.5.6 [INFO] [stderr] Compiling serde_derive v1.0.188 [INFO] [stderr] Compiling thiserror-impl v1.0.49 [INFO] [stderr] Compiling candid_derive v0.6.4 [INFO] [stderr] Compiling num_enum_derive v0.6.1 [INFO] [stderr] Compiling num_enum v0.6.1 [INFO] [stderr] Compiling binread_derive v2.1.0 [INFO] [stderr] Compiling binread v2.2.0 [INFO] [stderr] Checking serde_bytes v0.11.12 [INFO] [stderr] Compiling serde_tokenstream v0.1.7 [INFO] [stderr] Compiling ic-cdk-macros v0.8.1 [INFO] [stderr] Checking ic-cdk v0.11.6 [INFO] [stderr] Checking icp_rust_boilerplate_backend v0.1.0 (/opt/rustwide/workdir/src/icp_rust_boilerplate_backend) [INFO] [stdout] error[E0283]: type annotations needed [INFO] [stdout] --> src/icp_rust_boilerplate_backend/src/lib.rs:297:11 [INFO] [stdout] | [INFO] [stdout] 297 | match call::call(token_interface.token_canister, "transfer", (transfer_args,)).await { [INFO] [stdout] | ^^^^^^^^^^ cannot infer type of the type parameter `R` declared on the function `call` [INFO] [stdout] | [INFO] [stdout] = note: cannot satisfy `for<'a> _: ArgumentDecoder<'a>` [INFO] [stdout] = help: the following types implement trait `ArgumentDecoder<'a>`: [INFO] [stdout] () [INFO] [stdout] (A, B) [INFO] [stdout] (A, B, C) [INFO] [stdout] (A, B, C, D) [INFO] [stdout] (A, B, C, D, E) [INFO] [stdout] (A, B, C, D, E, F) [INFO] [stdout] (A, B, C, D, E, F, G) [INFO] [stdout] (A, B, C, D, E, F, G, H) [INFO] [stdout] and 9 others [INFO] [stdout] note: required by a bound in `ic_cdk::call` [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/ic-cdk-0.11.6/src/api/call.rs:339:36 [INFO] [stdout] | [INFO] [stdout] 339 | pub fn call ArgumentDecoder<'a>>( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ required by this bound in `call` [INFO] [stdout] help: consider specifying the generic arguments [INFO] [stdout] | [INFO] [stdout] 297 | match call::call::<(TokenTransferArgs,), R>(token_interface.token_canister, "transfer", (transfer_args,)).await { [INFO] [stdout] | +++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0283]: type annotations needed [INFO] [stdout] --> src/icp_rust_boilerplate_backend/src/lib.rs:297:11 [INFO] [stdout] | [INFO] [stdout] 297 | match call::call(token_interface.token_canister, "transfer", (transfer_args,)).await { [INFO] [stdout] | ^^^^^^^^^^ cannot infer type of the type parameter `R` declared on the function `call` [INFO] [stdout] | [INFO] [stdout] = note: cannot satisfy `for<'a> _: ArgumentDecoder<'a>` [INFO] [stdout] = help: the following types implement trait `ArgumentDecoder<'a>`: [INFO] [stdout] () [INFO] [stdout] (A, B) [INFO] [stdout] (A, B, C) [INFO] [stdout] (A, B, C, D) [INFO] [stdout] (A, B, C, D, E) [INFO] [stdout] (A, B, C, D, E, F) [INFO] [stdout] (A, B, C, D, E, F, G) [INFO] [stdout] (A, B, C, D, E, F, G, H) [INFO] [stdout] and 9 others [INFO] [stdout] note: required by a bound in `ic_cdk::call` [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/ic-cdk-0.11.6/src/api/call.rs:339:36 [INFO] [stdout] | [INFO] [stdout] 339 | pub fn call ArgumentDecoder<'a>>( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ required by this bound in `call` [INFO] [stdout] help: consider specifying the generic arguments [INFO] [stdout] | [INFO] [stdout] 297 | match call::call::<(TokenTransferArgs,), R>(token_interface.token_canister, "transfer", (transfer_args,)).await { [INFO] [stdout] | +++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0382]: borrow of moved value: `token_amount` [INFO] [stdout] --> src/icp_rust_boilerplate_backend/src/lib.rs:401:59 [INFO] [stdout] | [INFO] [stdout] 397 | let token_amount = convert_wage_to_token_amount(approval_result.wage_amount); [INFO] [stdout] | ------------ move occurs because `token_amount` has type `candid::Nat`, which does not implement the `Copy` trait [INFO] [stdout] 398 | [INFO] [stdout] 399 | match transfer_usdt(manager_principal, employee_principal, token_amount).await { [INFO] [stdout] | ------------ value moved here [INFO] [stdout] 400 | Ok(_) => { [INFO] [stdout] 401 | update_wallet_balance(employee_principal, token_amount.clone())?; [INFO] [stdout] | ^^^^^^^^^^^^ value borrowed here after move [INFO] [stdout] | [INFO] [stdout] note: consider changing this parameter type in function `transfer_usdt` to borrow instead if owning the value isn't necessary [INFO] [stdout] --> src/icp_rust_boilerplate_backend/src/lib.rs:292:64 [INFO] [stdout] | [INFO] [stdout] 292 | async fn transfer_usdt(from: Principal, to: Principal, amount: Nat) -> Result<(), String> { [INFO] [stdout] | ------------- in this function ^^^ this parameter takes ownership of the value [INFO] [stdout] help: consider cloning the value if the performance cost is acceptable [INFO] [stdout] | [INFO] [stdout] 399 | match transfer_usdt(manager_principal, employee_principal, token_amount.clone()).await { [INFO] [stdout] | ++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0382]: borrow of moved value: `token_amount` [INFO] [stdout] --> src/icp_rust_boilerplate_backend/src/lib.rs:401:59 [INFO] [stdout] | [INFO] [stdout] 397 | let token_amount = convert_wage_to_token_amount(approval_result.wage_amount); [INFO] [stdout] | ------------ move occurs because `token_amount` has type `candid::Nat`, which does not implement the `Copy` trait [INFO] [stdout] 398 | [INFO] [stdout] 399 | match transfer_usdt(manager_principal, employee_principal, token_amount).await { [INFO] [stdout] | ------------ value moved here [INFO] [stdout] 400 | Ok(_) => { [INFO] [stdout] 401 | update_wallet_balance(employee_principal, token_amount.clone())?; [INFO] [stdout] | ^^^^^^^^^^^^ value borrowed here after move [INFO] [stdout] | [INFO] [stdout] note: consider changing this parameter type in function `transfer_usdt` to borrow instead if owning the value isn't necessary [INFO] [stdout] --> src/icp_rust_boilerplate_backend/src/lib.rs:292:64 [INFO] [stdout] | [INFO] [stdout] 292 | async fn transfer_usdt(from: Principal, to: Principal, amount: Nat) -> Result<(), String> { [INFO] [stdout] | ------------- in this function ^^^ this parameter takes ownership of the value [INFO] [stdout] help: consider cloning the value if the performance cost is acceptable [INFO] [stdout] | [INFO] [stdout] 399 | match transfer_usdt(manager_principal, employee_principal, token_amount.clone()).await { [INFO] [stdout] | ++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0308]: mismatched types [INFO] [stdout] --> src/icp_rust_boilerplate_backend/src/lib.rs:416:38 [INFO] [stdout] | [INFO] [stdout] 416 | let mut wallet = storage.get(&principal).unwrap_or(Wallet { [INFO] [stdout] | --- ^^^^^^^^^^ expected `&MyPrincipal`, found `&Principal` [INFO] [stdout] | | [INFO] [stdout] | arguments to this method are incorrect [INFO] [stdout] | [INFO] [stdout] = note: expected reference `&MyPrincipal` [INFO] [stdout] found reference `&candid::Principal` [INFO] [stdout] note: method defined here [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/ic-stable-structures-0.5.6/src/btreemap.rs:377:12 [INFO] [stdout] | [INFO] [stdout] 377 | pub fn get(&self, key: &K) -> Option { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0308]: mismatched types [INFO] [stdout] --> src/icp_rust_boilerplate_backend/src/lib.rs:416:38 [INFO] [stdout] | [INFO] [stdout] 416 | let mut wallet = storage.get(&principal).unwrap_or(Wallet { [INFO] [stdout] | --- ^^^^^^^^^^ expected `&MyPrincipal`, found `&Principal` [INFO] [stdout] | | [INFO] [stdout] | arguments to this method are incorrect [INFO] [stdout] | [INFO] [stdout] = note: expected reference `&MyPrincipal` [INFO] [stdout] found reference `&candid::Principal` [INFO] [stdout] note: method defined here [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/ic-stable-structures-0.5.6/src/btreemap.rs:377:12 [INFO] [stdout] | [INFO] [stdout] 377 | pub fn get(&self, key: &K) -> Option { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0308]: mismatched types [INFO] [stdout] --> src/icp_rust_boilerplate_backend/src/lib.rs:422:24 [INFO] [stdout] | [INFO] [stdout] 422 | storage.insert(principal, wallet); [INFO] [stdout] | ------ ^^^^^^^^^ expected `MyPrincipal`, found `Principal` [INFO] [stdout] | | [INFO] [stdout] | arguments to this method are incorrect [INFO] [stdout] | [INFO] [stdout] note: method defined here [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/ic-stable-structures-0.5.6/src/btreemap.rs:202:12 [INFO] [stdout] | [INFO] [stdout] 202 | pub fn insert(&mut self, key: K, value: V) -> Option { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] help: try wrapping the expression in `MyPrincipal` [INFO] [stdout] | [INFO] [stdout] 422 | storage.insert(MyPrincipal(principal), wallet); [INFO] [stdout] | ++++++++++++ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0308]: mismatched types [INFO] [stdout] --> src/icp_rust_boilerplate_backend/src/lib.rs:422:24 [INFO] [stdout] | [INFO] [stdout] 422 | storage.insert(principal, wallet); [INFO] [stdout] | ------ ^^^^^^^^^ expected `MyPrincipal`, found `Principal` [INFO] [stdout] | | [INFO] [stdout] | arguments to this method are incorrect [INFO] [stdout] | [INFO] [stdout] note: method defined here [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/ic-stable-structures-0.5.6/src/btreemap.rs:202:12 [INFO] [stdout] | [INFO] [stdout] 202 | pub fn insert(&mut self, key: K, value: V) -> Option { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] help: try wrapping the expression in `MyPrincipal` [INFO] [stdout] | [INFO] [stdout] 422 | storage.insert(MyPrincipal(principal), wallet); [INFO] [stdout] | ++++++++++++ + [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] Some errors have detailed explanations: E0283, E0308, E0382. [INFO] [stdout] [INFO] [stdout] For more information about an error, try `rustc --explain E0283`. [INFO] [stdout] [INFO] [stderr] error: could not compile `icp_rust_boilerplate_backend` (lib test) due to 4 previous errors [INFO] [stdout] Some errors have detailed explanations: E0283, E0308, E0382. [INFO] [stdout] [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stdout] For more information about an error, try `rustc --explain E0283`. [INFO] [stdout] [INFO] [stderr] error: could not compile `icp_rust_boilerplate_backend` (lib) due to 4 previous errors [INFO] running `Command { std: "docker" "inspect" "6948049ef9c63eb3101334d0a46337f227d328e4d9f2de0cc58b97457c006ac6", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6948049ef9c63eb3101334d0a46337f227d328e4d9f2de0cc58b97457c006ac6", kill_on_drop: false }` [INFO] [stdout] 6948049ef9c63eb3101334d0a46337f227d328e4d9f2de0cc58b97457c006ac6