[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#fa4dd1f19bfeb3fd235dc7f1406c42404436bef5 for pr-145108-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fthisisbintang%2FICP-Testing" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[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-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/thisisbintang/ICP-Testing on toolchain fa4dd1f19bfeb3fd235dc7f1406c42404436bef5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[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" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "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]   |
[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]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded ic-cdk-macros v0.8.1
[INFO] [stderr]   Downloaded thiserror v1.0.49
[INFO] [stderr]   Downloaded thiserror-impl v1.0.49
[INFO] [stderr]   Downloaded ic0 v0.21.1
[INFO] [stderr]   Downloaded stacker v0.1.17
[INFO] [stderr]   Downloaded candid_derive v0.6.4
[INFO] [stderr]   Downloaded termcolor v1.3.0
[INFO] [stderr]   Downloaded psm v0.1.24
[INFO] [stderr]   Downloaded binread_derive v2.1.0
[INFO] [stderr]   Downloaded serde_tokenstream v0.1.7
[INFO] [stderr]   Downloaded binread v2.2.0
[INFO] [stderr]   Downloaded indexmap v2.0.2
[INFO] [stderr]   Downloaded candid v0.9.11
[INFO] [stderr]   Downloaded pretty v0.12.3
[INFO] [stderr]   Downloaded hashbrown v0.14.1
[INFO] [stderr]   Downloaded ic-stable-structures v0.5.6
[INFO] [stderr]   Downloaded winnow v0.5.16
[INFO] [stderr]   Downloaded serde_json v1.0.109
[INFO] [stderr]   Downloaded ic-cdk v0.11.6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:61361fe0aef631f17e9d025a70c5a647956f8c671dd02950a60ad3f5cc5526d7" "/opt/rustwide/cargo-home/bin/cargo" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7bc20e96379a0fa6b1610829721f588ec40a6754faa9d64953c4899bd4ad55fd
[INFO] running `Command { std: "docker" "start" "-a" "7bc20e96379a0fa6b1610829721f588ec40a6754faa9d64953c4899bd4ad55fd", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7bc20e96379a0fa6b1610829721f588ec40a6754faa9d64953c4899bd4ad55fd", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7bc20e96379a0fa6b1610829721f588ec40a6754faa9d64953c4899bd4ad55fd", kill_on_drop: false }`
[INFO] [stdout] 7bc20e96379a0fa6b1610829721f588ec40a6754faa9d64953c4899bd4ad55fd
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:61361fe0aef631f17e9d025a70c5a647956f8c671dd02950a60ad3f5cc5526d7" "/opt/rustwide/cargo-home/bin/cargo" "+fa4dd1f19bfeb3fd235dc7f1406c42404436bef5" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2f0d044d83b31225effd7470322704c30f8dc9a06505df89336c024b2fac5346
[INFO] running `Command { std: "docker" "start" "-a" "2f0d044d83b31225effd7470322704c30f8dc9a06505df89336c024b2fac5346", 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]   |
[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 serde v1.0.188
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling hashbrown v0.14.1
[INFO] [stderr]    Compiling toml_datetime v0.6.3
[INFO] [stderr]    Compiling winnow v0.5.16
[INFO] [stderr]    Compiling once_cell v1.18.0
[INFO] [stderr]    Compiling num-traits v0.2.17
[INFO] [stderr]    Compiling num-bigint v0.4.4
[INFO] [stderr]    Compiling psm v0.1.24
[INFO] [stderr]    Compiling stacker v0.1.17
[INFO] [stderr]    Compiling either v1.9.0
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling thiserror v1.0.49
[INFO] [stderr]    Compiling paste v1.0.14
[INFO] [stderr]    Compiling unicode-width v0.1.11
[INFO] [stderr]    Compiling candid v0.9.11
[INFO] [stderr]    Compiling cpufeatures v0.2.9
[INFO] [stderr]    Compiling termcolor v1.3.0
[INFO] [stderr]    Compiling typed-arena v2.0.2
[INFO] [stderr]    Compiling arrayvec v0.5.2
[INFO] [stderr]    Compiling crc32fast v1.3.2
[INFO] [stderr]    Compiling leb128 v0.2.5
[INFO] [stderr]    Compiling data-encoding v2.4.0
[INFO] [stderr]    Compiling codespan-reporting v0.11.1
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling indexmap v2.0.2
[INFO] [stderr]     Checking pretty v0.12.3
[INFO] [stderr]    Compiling serde_json v1.0.109
[INFO] [stderr]     Checking ic0 v0.21.1
[INFO] [stderr]     Checking ic-stable-structures v0.5.6
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling sha2 v0.10.8
[INFO] [stderr]    Compiling quote v1.0.33
[INFO] [stderr]    Compiling syn v2.0.38
[INFO] [stderr]     Checking num-integer v0.1.45
[INFO] [stderr]    Compiling toml_edit v0.19.15
[INFO] [stderr]    Compiling proc-macro-crate v1.3.1
[INFO] [stderr]    Compiling serde_derive v1.0.188
[INFO] [stderr]    Compiling num_enum_derive v0.6.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.49
[INFO] [stderr]    Compiling candid_derive v0.6.4
[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<T: ArgumentEncoder, R: for<'a> 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[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<T: ArgumentEncoder, R: for<'a> 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[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<V> {
[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<V> {
[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<V> {
[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<V> {
[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) due to 4 previous errors
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[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] running `Command { std: "docker" "inspect" "2f0d044d83b31225effd7470322704c30f8dc9a06505df89336c024b2fac5346", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2f0d044d83b31225effd7470322704c30f8dc9a06505df89336c024b2fac5346", kill_on_drop: false }`
[INFO] [stdout] 2f0d044d83b31225effd7470322704c30f8dc9a06505df89336c024b2fac5346
