[INFO] fetching crate keyflux 0.1.15...
[INFO] checking keyflux-0.1.15 against master#39cb3386ddc6c71657418be28dbb3987eea4aa4b for pr-133536
[INFO] extracting crate keyflux 0.1.15 into /workspace/builds/worker-6-tc1/source
[INFO] validating manifest of crates.io crate keyflux 0.1.15 on toolchain 39cb3386ddc6c71657418be28dbb3987eea4aa4b
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+39cb3386ddc6c71657418be28dbb3987eea4aa4b" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate keyflux 0.1.15
[INFO] finished tweaking crates.io crate keyflux 0.1.15
[INFO] tweaked toml for crates.io crate keyflux 0.1.15 written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] crate crates.io crate keyflux 0.1.15 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" "+39cb3386ddc6c71657418be28dbb3987eea4aa4b" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded whoami v1.5.1
[INFO] [stderr]   Downloaded rust-i18n-support v1.1.0
[INFO] [stderr]   Downloaded rust-i18n-macro v1.3.0
[INFO] [stderr]   Downloaded rust-i18n-extract v1.1.1
[INFO] [stderr]   Downloaded rust-i18n v1.2.2
[INFO] [stderr]   Downloaded line-numbers v0.3.0
[INFO] [stderr]   Downloaded mimalloc v0.1.28
[INFO] [stderr]   Downloaded postgres v0.17.5
[INFO] [stderr]   Downloaded const_format_proc_macros v0.2.32
[INFO] [stderr]   Downloaded clap_complete v4.5.5
[INFO] [stderr]   Downloaded wu-diff v0.1.2
[INFO] [stderr]   Downloaded prettytable v0.10.0
[INFO] [stderr]   Downloaded const_format v0.2.32
[INFO] [stderr]   Downloaded tokio-postgres v0.5.5
[INFO] [stderr]   Downloaded postgres-types v0.1.3
[INFO] [stderr]   Downloaded httparse v1.9.3
[INFO] [stderr]   Downloaded memchr v2.7.3
[INFO] [stderr]   Downloaded radix-heap v0.4.2
[INFO] [stderr]   Downloaded crypto-mac v0.9.1
[INFO] [stderr]   Downloaded hmac v0.9.0
[INFO] [stderr]   Downloaded postgres-protocol v0.5.3
[INFO] [stderr]   Downloaded libmimalloc-sys v0.1.24
[INFO] [stderr]   Downloaded sodiumoxide v0.2.7
[INFO] [stderr]   Downloaded libsodium-sys v0.2.7
[INFO] [stderr]   Downloaded difftastic v0.58.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/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:4a844ea9eb2546a2d2c7022eacef16ef2e8229c7fbb2c7d4d55a9ceca922f72d" "/opt/rustwide/cargo-home/bin/cargo" "+39cb3386ddc6c71657418be28dbb3987eea4aa4b" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 02f6a1664cdc8725f444a08e2d22c50926479fd05f3204aecb716be66da2fd03
[INFO] running `Command { std: "docker" "start" "-a" "02f6a1664cdc8725f444a08e2d22c50926479fd05f3204aecb716be66da2fd03", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "02f6a1664cdc8725f444a08e2d22c50926479fd05f3204aecb716be66da2fd03", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "02f6a1664cdc8725f444a08e2d22c50926479fd05f3204aecb716be66da2fd03", kill_on_drop: false }`
[INFO] [stdout] 02f6a1664cdc8725f444a08e2d22c50926479fd05f3204aecb716be66da2fd03
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/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:4a844ea9eb2546a2d2c7022eacef16ef2e8229c7fbb2c7d4d55a9ceca922f72d" "/opt/rustwide/cargo-home/bin/cargo" "+39cb3386ddc6c71657418be28dbb3987eea4aa4b" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 366c809d4da9fe98b5bb371462b2e84dd48e8c0b0cc26b31e76a034d8aabd25b
[INFO] running `Command { std: "docker" "start" "-a" "366c809d4da9fe98b5bb371462b2e84dd48e8c0b0cc26b31e76a034d8aabd25b", kill_on_drop: false }`
[INFO] [stderr] warning: keyflux v0.1.15 (/opt/rustwide/workdir) ignoring invalid dependency `difftastic` which is missing a lib target
[INFO] [stderr]    Compiling proc-macro2 v1.0.85
[INFO] [stderr]    Compiling libc v0.2.155
[INFO] [stderr]    Compiling autocfg v1.3.0
[INFO] [stderr]     Checking memchr v2.7.3
[INFO] [stderr]     Checking log v0.4.21
[INFO] [stderr]    Compiling serde v1.0.203
[INFO] [stderr]     Checking once_cell v1.19.0
[INFO] [stderr]     Checking smallvec v1.13.2
[INFO] [stderr]     Checking pin-project-lite v0.2.14
[INFO] [stderr]     Checking futures-core v0.3.30
[INFO] [stderr]     Checking futures-sink v0.3.30
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]     Checking itoa v1.0.11
[INFO] [stderr]     Checking bytes v1.6.0
[INFO] [stderr]    Compiling cc v1.0.99
[INFO] [stderr]    Compiling pkg-config v0.3.30
[INFO] [stderr]     Checking subtle v2.5.0
[INFO] [stderr]     Checking futures-io v0.3.30
[INFO] [stderr]     Checking futures-channel v0.3.30
[INFO] [stderr]     Checking futures-task v0.3.30
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]     Checking ppv-lite86 v0.2.17
[INFO] [stderr]     Checking zerocopy v0.7.34
[INFO] [stderr]    Compiling vcpkg v0.2.15
[INFO] [stderr]     Checking tinyvec_macros v0.1.1
[INFO] [stderr]     Checking tinyvec v1.6.0
[INFO] [stderr]    Compiling serde_json v1.0.117
[INFO] [stderr]     Checking cpufeatures v0.2.12
[INFO] [stderr]    Compiling getrandom v0.1.16
[INFO] [stderr]     Checking allocator-api2 v0.2.18
[INFO] [stderr]     Checking unicode-properties v0.1.1
[INFO] [stderr]    Compiling slab v0.4.9
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]     Checking litemap v0.7.3
[INFO] [stderr]     Checking regex-syntax v0.7.5
[INFO] [stderr]     Checking unicode-bidi v0.3.15
[INFO] [stderr]     Checking bitflags v2.5.0
[INFO] [stderr]     Checking http v1.1.0
[INFO] [stderr]     Checking siphasher v0.3.11
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking fallible-iterator v0.2.0
[INFO] [stderr]    Compiling quote v1.0.36
[INFO] [stderr]     Checking crypto-common v0.1.6
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]     Checking unicode-width v0.1.13
[INFO] [stderr]     Checking digest v0.9.0
[INFO] [stderr]     Checking tracing-core v0.1.32
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking unicode-ident v1.0.12
[INFO] [stderr]    Compiling syn v2.0.66
[INFO] [stderr]     Checking unicode-normalization v0.1.23
[INFO] [stderr]    Compiling openssl v0.10.64
[INFO] [stderr]    Compiling httparse v1.9.3
[INFO] [stderr]     Checking utf8parse v0.2.2
[INFO] [stderr]     Checking anstyle-parse v0.2.4
[INFO] [stderr]     Checking block-buffer v0.9.0
[INFO] [stderr]     Checking crypto-mac v0.9.1
[INFO] [stderr]    Compiling hashbrown v0.12.3
[INFO] [stderr]     Checking anstyle v1.0.7
[INFO] [stderr]    Compiling linked-hash-map v0.5.6
[INFO] [stderr]     Checking regex-syntax v0.8.4
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]    Compiling native-tls v0.2.12
[INFO] [stderr]     Checking http-body v1.0.0
[INFO] [stderr]    Compiling parking_lot_core v0.8.6
[INFO] [stderr]     Checking anstyle-query v1.1.0
[INFO] [stderr]     Checking stringprep v0.1.5
[INFO] [stderr]     Checking opaque-debug v0.3.1
[INFO] [stderr]    Compiling openssl-sys v0.9.102
[INFO] [stderr]     Checking colorchoice v1.0.1
[INFO] [stderr]     Checking is_terminal_polyfill v1.70.0
[INFO] [stderr]     Checking sha2 v0.9.9
[INFO] [stderr]     Checking yaml-rust v0.4.5
[INFO] [stderr]     Checking anstream v0.6.14
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking mio v0.8.11
[INFO] [stderr]     Checking socket2 v0.5.7
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking signal-hook-registry v1.4.2
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]     Checking iovec v0.1.4
[INFO] [stderr]     Checking net2 v0.2.39
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking hmac v0.9.0
[INFO] [stderr]     Checking rand_core v0.5.1
[INFO] [stderr]     Checking bstr v1.9.1
[INFO] [stderr]     Checking instant v0.1.13
[INFO] [stderr]     Checking pin-project-lite v0.1.12
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking mio v0.6.23
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]     Checking openssl-probe v0.1.5
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling rustix v0.38.34
[INFO] [stderr]     Checking regex-automata v0.4.7
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking regex-automata v0.3.9
[INFO] [stderr]     Checking tower-layer v0.3.2
[INFO] [stderr]     Checking base64 v0.13.1
[INFO] [stderr]    Compiling anyhow v1.0.86
[INFO] [stderr]     Checking tower-service v0.3.2
[INFO] [stderr]     Checking md5 v0.7.0
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking dirs-sys-next v0.1.2
[INFO] [stderr]    Compiling libsodium-sys v0.2.7
[INFO] [stderr]     Checking hmac v0.12.1
[INFO] [stderr]     Checking sha2 v0.10.8
[INFO] [stderr]     Checking md-5 v0.10.6
[INFO] [stderr]     Checking phf_shared v0.8.0
[INFO] [stderr]     Checking mio-uds v0.6.8
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking thread_local v1.1.8
[INFO] [stderr]     Checking glob v0.3.1
[INFO] [stderr]     Checking tokio v0.2.25
[INFO] [stderr]    Compiling heck v0.5.0
[INFO] [stderr]     Checking linux-raw-sys v0.4.14
[INFO] [stderr]    Compiling thiserror v1.0.61
[INFO] [stderr]     Checking clap_lex v0.7.1
[INFO] [stderr]     Checking strsim v0.11.1
[INFO] [stderr]    Compiling portable-atomic v1.6.0
[INFO] [stderr]     Checking phf v0.8.0
[INFO] [stderr]     Checking postgres-protocol v0.5.3
[INFO] [stderr]     Checking clap_builder v4.5.7
[INFO] [stderr]     Checking parking_lot v0.11.2
[INFO] [stderr]     Checking postgres-protocol v0.6.6
[INFO] [stderr]     Checking dirs-next v2.0.0
[INFO] [stderr]     Checking postgres-types v0.1.3
[INFO] [stderr]     Checking atty v0.2.14
[INFO] [stderr]     Checking is-terminal v0.4.12
[INFO] [stderr]     Checking console v0.15.8
[INFO] [stderr]     Checking inotify-sys v0.1.5
[INFO] [stderr]     Checking textwrap v0.11.0
[INFO] [stderr]     Checking phf_shared v0.11.2
[INFO] [stderr]     Checking csv-core v0.1.11
[INFO] [stderr]     Checking bitmaps v2.1.0
[INFO] [stderr]    Compiling im v15.1.0
[INFO] [stderr]     Checking fastrand v2.1.0
[INFO] [stderr]     Checking rustls-pki-types v1.7.0
[INFO] [stderr]     Checking signature v1.6.4
[INFO] [stderr]     Checking either v1.12.0
[INFO] [stderr]     Checking winnow v0.6.13
[INFO] [stderr]     Checking base64 v0.22.1
[INFO] [stderr]    Compiling serde_yaml v0.8.26
[INFO] [stderr]     Checking globset v0.4.14
[INFO] [stderr]     Checking regex v1.9.6
[INFO] [stderr]     Checking ansi_term v0.12.1
[INFO] [stderr]     Checking vec_map v0.8.2
[INFO] [stderr]     Checking sized-chunks v0.6.5
[INFO] [stderr]     Checking dirs-sys v0.4.1
[INFO] [stderr]     Checking rustls-pemfile v2.1.2
[INFO] [stderr]     Checking itertools v0.10.5
[INFO] [stderr]     Checking clap v2.34.0
[INFO] [stderr]     Checking ignore v0.4.18
[INFO] [stderr]     Checking ed25519 v1.5.3
[INFO] [stderr]     Checking phf v0.11.2
[INFO] [stderr]     Checking inotify v0.9.6
[INFO] [stderr]     Checking postgres-types v0.2.6
[INFO] [stderr]     Checking term v0.7.0
[INFO] [stderr]     Checking tokio-util v0.3.1
[INFO] [stderr]     Checking tempfile v3.10.1
[INFO] [stderr]     Checking rand_xoshiro v0.6.0
[INFO] [stderr]     Checking filetime v0.2.23
[INFO] [stderr]    Compiling rust-i18n-support v1.1.0
[INFO] [stderr]     Checking rand v0.4.6
[INFO] [stderr]     Checking crossbeam-channel v0.5.13
[INFO] [stderr]     Checking encoding_rs v0.8.34
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]     Checking shell-words v1.1.0
[INFO] [stderr]     Checking remove_dir_all v0.5.3
[INFO] [stderr]    Compiling keyflux v0.1.15 (/opt/rustwide/workdir)
[INFO] [stderr]     Checking ipnet v2.9.0
[INFO] [stderr]     Checking encode_unicode v1.0.0
[INFO] [stderr]     Checking whoami v1.5.1
[INFO] [stderr]     Checking number_prefix v0.4.0
[INFO] [stderr]     Checking notify v6.1.1
[INFO] [stderr]     Checking chrono v0.4.38
[INFO] [stderr]    Compiling test-case-core v3.3.1
[INFO] [stderr]     Checking env_logger v0.10.2
[INFO] [stderr]     Checking indicatif v0.17.8
[INFO] [stderr]     Checking tempdir v0.3.7
[INFO] [stderr]     Checking dirs v5.0.1
[INFO] [stderr]     Checking uuid v1.8.0
[INFO] [stderr]     Checking colored v2.1.0
[INFO] [stderr]     Checking dotenv v0.15.0
[INFO] [stderr]     Checking env_filter v0.1.0
[INFO] [stderr]     Checking env_logger v0.11.3
[INFO] [stderr]    Compiling rust-i18n-macro v1.3.0
[INFO] [stderr]    Compiling serde_derive v1.0.203
[INFO] [stderr]    Compiling zerofrom-derive v0.1.4
[INFO] [stderr]    Compiling yoke-derive v0.7.4
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]    Compiling zerovec-derive v0.10.2
[INFO] [stderr]    Compiling displaydoc v0.2.4
[INFO] [stderr]    Compiling tokio-macros v2.3.0
[INFO] [stderr]    Compiling icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling pin-project-internal v1.1.5
[INFO] [stderr]    Compiling async-trait v0.1.80
[INFO] [stderr]    Compiling rust-i18n v1.2.2
[INFO] [stderr]    Compiling thiserror-impl v1.0.61
[INFO] [stderr]    Compiling clap_derive v4.5.5
[INFO] [stderr]    Compiling test-case-macros v3.3.1
[INFO] [stderr]     Checking tokio v1.38.0
[INFO] [stderr]     Checking futures-util v0.3.30
[INFO] [stderr]     Checking test-case v3.3.1
[INFO] [stderr]     Checking pin-project v1.1.5
[INFO] [stderr]     Checking zerofrom v0.1.4
[INFO] [stderr]     Checking dialoguer v0.11.0
[INFO] [stderr]     Checking yoke v0.7.4
[INFO] [stderr]     Checking zerovec v0.10.2
[INFO] [stderr]     Checking clap v4.5.7
[INFO] [stderr]     Checking clap_complete v4.5.5
[INFO] [stderr]     Checking tinystr v0.7.6
[INFO] [stderr]     Checking icu_collections v1.5.0
[INFO] [stderr]     Checking icu_locid v1.5.0
[INFO] [stderr]     Checking icu_provider v1.5.0
[INFO] [stderr]     Checking icu_locid_transform v1.5.0
[INFO] [stderr]     Checking futures-executor v0.3.30
[INFO] [stderr]     Checking http-body-util v0.1.2
[INFO] [stderr]     Checking futures v0.3.30
[INFO] [stderr]     Checking tokio-postgres v0.5.5
[INFO] [stderr]     Checking icu_properties v1.5.0
[INFO] [stderr]     Checking tokio-util v0.7.11
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking indexmap v2.2.6
[INFO] [stderr]     Checking toml_datetime v0.6.6
[INFO] [stderr]     Checking serde_spanned v0.6.6
[INFO] [stderr]     Checking toml v0.5.11
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking csv v1.3.0
[INFO] [stderr]     Checking postgres v0.17.5
[INFO] [stderr]     Checking tokio-postgres v0.7.10
[INFO] [stderr]     Checking prettytable v0.10.0
[INFO] [stderr]     Checking h2 v0.4.5
[INFO] [stderr]     Checking toml_edit v0.22.14
[INFO] [stderr]     Checking icu_normalizer v1.5.0
[INFO] [stderr]     Checking rust-i18n-extract v1.1.1
[INFO] [stderr]     Checking idna v1.0.0
[INFO] [stderr]     Checking url v2.5.1
[INFO] [stderr]     Checking toml v0.8.14
[INFO] [stderr]     Checking hyper v1.3.1
[INFO] [stderr]     Checking hyper-util v0.1.5
[INFO] [stderr]     Checking hyper-tls v0.6.0
[INFO] [stderr]     Checking reqwest v0.12.4
[INFO] [stderr]     Checking sodiumoxide v0.2.7
[INFO] [stdout] warning: unused imports: `Deserialize` and `Serialize`
[INFO] [stdout]  --> src/traits.rs:5:13
[INFO] [stdout]   |
[INFO] [stdout] 5 | 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 imports: `PathBuf` and `Path`
[INFO] [stdout]  --> src/key_manager.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::path::{Path, PathBuf};
[INFO] [stdout]   |                 ^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::mpsc::channel`
[INFO] [stdout]  --> src/key_manager.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::mpsc::channel;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/key_manager.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyEnum`
[INFO] [stdout]  --> src/key_manager.rs:6:21
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::config::{KeyEnum, KeyFluxConfig};
[INFO] [stdout]   |                     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyValue`
[INFO] [stdout]  --> src/key_manager.rs:9:48
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::key::{Key, KeyDetail, KeyTransform, KeyValue};
[INFO] [stdout]   |                                                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error`, `info`, and `warn`
[INFO] [stdout]   --> src/key_manager.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | use log::{error, info, trace, warn};
[INFO] [stdout]    |           ^^^^^  ^^^^         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `colored::*`
[INFO] [stdout]   --> src/key_manager.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use colored::*;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Config`, `EventKind`, `Event`, `RecommendedWatcher`, and `RecursiveMode`
[INFO] [stdout]   --> src/key_manager.rs:12:14
[INFO] [stdout]    |
[INFO] [stdout] 12 | use notify::{Config, Event, EventKind, RecommendedWatcher, RecursiveMode, Watcher};
[INFO] [stdout]    |              ^^^^^^  ^^^^^  ^^^^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Generator` and `generate`
[INFO] [stdout]  --> src/cli.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | use clap_complete::{generate, Generator, Shell};
[INFO] [stdout]   |                     ^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Display`, `Formatter`, and `self`
[INFO] [stdout]  --> src/utils/interpolation.rs:2:16
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fmt::{self, Display, Formatter};
[INFO] [stdout]   |                ^^^^  ^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/flux/vercel.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug` and `trace`
[INFO] [stdout]    --> src/flux/vercel.rs:581:11
[INFO] [stdout]     |
[INFO] [stdout] 581 | use log::{debug, info, trace};
[INFO] [stdout]     |           ^^^^^        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::file::key_collection::KeyCollection`
[INFO] [stdout]    --> src/flux/vercel.rs:588:5
[INFO] [stdout]     |
[INFO] [stdout] 588 | use crate::file::key_collection::KeyCollection;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `de::Error as DeError`
[INFO] [stdout]  --> src/flux/impl.rs:2:40
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde::{Deserialize, Deserializer, de::Error as DeError, Serialize, Serializer};
[INFO] [stdout]   |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `merge`
[INFO] [stdout]   --> src/flux/github.rs:16:19
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::flux::{merge, merge_and_return_json, replace_vars_in_json};
[INFO] [stdout]    |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json`
[INFO] [stdout]  --> src/flux/file.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde_json;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_yaml`
[INFO] [stdout]  --> src/flux/file.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_yaml;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `toml`
[INFO] [stdout]  --> src/flux/file.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use toml;
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `OpenOptions`
[INFO] [stdout]  --> src/flux/file.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::fs::{OpenOptions};
[INFO] [stdout]   |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Write`
[INFO] [stdout]  --> src/flux/file.rs:7:21
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::io::{Read, Write};
[INFO] [stdout]   |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Path`
[INFO] [stdout]  --> src/flux/file.rs:8:17
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::path::{Path, PathBuf};
[INFO] [stdout]   |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/flux/file.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::Utc`
[INFO] [stdout]   --> src/flux/file.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use chrono::Utc;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error` and `info`
[INFO] [stdout]   --> src/flux/file.rs:11:11
[INFO] [stdout]    |
[INFO] [stdout] 11 | use log::{error, info};
[INFO] [stdout]    |           ^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::env`
[INFO] [stdout]   --> src/flux/mod.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 93 | use std::env;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde::de::DeserializeOwned`
[INFO] [stdout]   --> src/flux/mod.rs:95:5
[INFO] [stdout]    |
[INFO] [stdout] 95 | use serde::de::DeserializeOwned;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::key::Key`
[INFO] [stdout]   --> src/flux/mod.rs:98:5
[INFO] [stdout]    |
[INFO] [stdout] 98 | use crate::key::Key;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `reqwest::header::HeaderMap`
[INFO] [stdout]  --> src/api/mod.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use reqwest::header::HeaderMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `thiserror::Error`
[INFO] [stdout]  --> src/config/utils.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use thiserror::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/config/v1.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::PathBuf`
[INFO] [stdout]  --> src/config/v1.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EnvConfig`
[INFO] [stdout]  --> src/config/v1.rs:4:26
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::config::env::{EnvConfig, EnvConfigList};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/config/group.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::config::KeyEnum`
[INFO] [stdout]  --> src/config/group.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::config::KeyEnum;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fmt`
[INFO] [stdout]   --> src/config/mod.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::{fmt, fs};
[INFO] [stdout]    |           ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> src/config/mod.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::traits::Flux`
[INFO] [stdout]   --> src/config/mod.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::traits::Flux;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `thiserror::Error`
[INFO] [stdout]   --> src/config/mod.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use thiserror::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Select` and `theme::ColorfulTheme`
[INFO] [stdout]   --> src/config/mod.rs:20:17
[INFO] [stdout]    |
[INFO] [stdout] 20 | use dialoguer::{theme::ColorfulTheme, Select};
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EnvConfig`
[INFO] [stdout]   --> src/config/mod.rs:21:26
[INFO] [stdout]    |
[INFO] [stdout] 21 | use crate::config::env::{EnvConfig, EnvConfigList};
[INFO] [stdout]    |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> src/file/mod.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/file/env.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs`
[INFO] [stdout]  --> src/file/env.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fs;
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::os::unix::fs::PermissionsExt`
[INFO] [stdout]  --> src/file/env.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::os::unix::fs::PermissionsExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration` and `UNIX_EPOCH`
[INFO] [stdout]  --> src/file/env.rs:5:17
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::time::{Duration, SystemTime, UNIX_EPOCH};
[INFO] [stdout]   |                 ^^^^^^^^              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Value` and `json`
[INFO] [stdout]   --> src/file/env.rs:11:18
[INFO] [stdout]    |
[INFO] [stdout] 11 | use serde_json::{json, Value};
[INFO] [stdout]    |                  ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyCollectionMap`
[INFO] [stdout]   --> src/file/env.rs:15:50
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::file::key_collection::{KeyCollection, KeyCollectionMap};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::file::metadata::extract_file_metadata`
[INFO] [stdout]   --> src/file/env.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::file::metadata::extract_file_metadata;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> src/file/format_manager.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::vec`
[INFO] [stdout]  --> src/file/format_manager.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::vec;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyCollectionTransform`
[INFO] [stdout]   --> src/file/format_manager.rs:12:50
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::file::key_collection::{KeyCollection, KeyCollectionTransform};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/file/json.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::file::metadata::extract_file_metadata`
[INFO] [stdout]  --> src/file/json.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::file::metadata::extract_file_metadata;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyCollectionMap`
[INFO] [stdout]   --> src/file/postman.rs:12:50
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::file::key_collection::{KeyCollection, KeyCollectionMap, KeyCollectionTransform};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::Index`
[INFO] [stdout]  --> src/file/key_collection.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::ops::Index;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/file/parser/env.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]    --> src/command/diff.rs:170:5
[INFO] [stdout]     |
[INFO] [stdout] 170 | use log::info;
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `glob::glob`
[INFO] [stdout]  --> src/command/sub.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use glob::glob;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Deserialize` and `Serialize`
[INFO] [stdout]  --> src/traits.rs:5:13
[INFO] [stdout]   |
[INFO] [stdout] 5 | 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 imports: `PathBuf` and `Path`
[INFO] [stdout]  --> src/key_manager.rs:1:17
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::path::{Path, PathBuf};
[INFO] [stdout]   |                 ^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::mpsc::channel`
[INFO] [stdout]  --> src/key_manager.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::mpsc::channel;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/key_manager.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyEnum`
[INFO] [stdout]  --> src/key_manager.rs:6:21
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::config::{KeyEnum, KeyFluxConfig};
[INFO] [stdout]   |                     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyValue`
[INFO] [stdout]  --> src/key_manager.rs:9:48
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::key::{Key, KeyDetail, KeyTransform, KeyValue};
[INFO] [stdout]   |                                                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error`, `info`, and `warn`
[INFO] [stdout]   --> src/key_manager.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | use log::{error, info, trace, warn};
[INFO] [stdout]    |           ^^^^^  ^^^^         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `colored::*`
[INFO] [stdout]   --> src/key_manager.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use colored::*;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Config`, `EventKind`, `Event`, `RecommendedWatcher`, and `RecursiveMode`
[INFO] [stdout]   --> src/key_manager.rs:12:14
[INFO] [stdout]    |
[INFO] [stdout] 12 | use notify::{Config, Event, EventKind, RecommendedWatcher, RecursiveMode, Watcher};
[INFO] [stdout]    |              ^^^^^^  ^^^^^  ^^^^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Generator` and `generate`
[INFO] [stdout]  --> src/cli.rs:8:21
[INFO] [stdout]   |
[INFO] [stdout] 8 | use clap_complete::{generate, Generator, Shell};
[INFO] [stdout]   |                     ^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Display`, `Formatter`, and `self`
[INFO] [stdout]  --> src/utils/interpolation.rs:2:16
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fmt::{self, Display, Formatter};
[INFO] [stdout]   |                ^^^^  ^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/flux/vercel.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug` and `trace`
[INFO] [stdout]    --> src/flux/vercel.rs:581:11
[INFO] [stdout]     |
[INFO] [stdout] 581 | use log::{debug, info, trace};
[INFO] [stdout]     |           ^^^^^        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::file::key_collection::KeyCollection`
[INFO] [stdout]    --> src/flux/vercel.rs:588:5
[INFO] [stdout]     |
[INFO] [stdout] 588 | use crate::file::key_collection::KeyCollection;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `de::Error as DeError`
[INFO] [stdout]  --> src/flux/impl.rs:2:40
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde::{Deserialize, Deserializer, de::Error as DeError, Serialize, Serializer};
[INFO] [stdout]   |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `merge`
[INFO] [stdout]   --> src/flux/github.rs:16:19
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::flux::{merge, merge_and_return_json, replace_vars_in_json};
[INFO] [stdout]    |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json`
[INFO] [stdout]  --> src/flux/file.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde_json;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_yaml`
[INFO] [stdout]  --> src/flux/file.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_yaml;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `toml`
[INFO] [stdout]  --> src/flux/file.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use toml;
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `OpenOptions`
[INFO] [stdout]  --> src/flux/file.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::fs::{OpenOptions};
[INFO] [stdout]   |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Write`
[INFO] [stdout]  --> src/flux/file.rs:7:21
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::io::{Read, Write};
[INFO] [stdout]   |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Path`
[INFO] [stdout]  --> src/flux/file.rs:8:17
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::path::{Path, PathBuf};
[INFO] [stdout]   |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/flux/file.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::Utc`
[INFO] [stdout]   --> src/flux/file.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use chrono::Utc;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `error` and `info`
[INFO] [stdout]   --> src/flux/file.rs:11:11
[INFO] [stdout]    |
[INFO] [stdout] 11 | use log::{error, info};
[INFO] [stdout]    |           ^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::env`
[INFO] [stdout]   --> src/flux/mod.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 93 | use std::env;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde::de::DeserializeOwned`
[INFO] [stdout]   --> src/flux/mod.rs:95:5
[INFO] [stdout]    |
[INFO] [stdout] 95 | use serde::de::DeserializeOwned;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::key::Key`
[INFO] [stdout]   --> src/flux/mod.rs:98:5
[INFO] [stdout]    |
[INFO] [stdout] 98 | use crate::key::Key;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `reqwest::header::HeaderMap`
[INFO] [stdout]  --> src/api/mod.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use reqwest::header::HeaderMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `thiserror::Error`
[INFO] [stdout]  --> src/config/utils.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use thiserror::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/config/v1.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::PathBuf`
[INFO] [stdout]  --> src/config/v1.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EnvConfig`
[INFO] [stdout]  --> src/config/v1.rs:4:26
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::config::env::{EnvConfig, EnvConfigList};
[INFO] [stdout]   |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/config/group.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::config::KeyEnum`
[INFO] [stdout]  --> src/config/group.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::config::KeyEnum;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fmt`
[INFO] [stdout]   --> src/config/mod.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::{fmt, fs};
[INFO] [stdout]    |           ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> src/config/mod.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::traits::Flux`
[INFO] [stdout]   --> src/config/mod.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::traits::Flux;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `thiserror::Error`
[INFO] [stdout]   --> src/config/mod.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use thiserror::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Select` and `theme::ColorfulTheme`
[INFO] [stdout]   --> src/config/mod.rs:20:17
[INFO] [stdout]    |
[INFO] [stdout] 20 | use dialoguer::{theme::ColorfulTheme, Select};
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EnvConfig`
[INFO] [stdout]   --> src/config/mod.rs:21:26
[INFO] [stdout]    |
[INFO] [stdout] 21 | use crate::config::env::{EnvConfig, EnvConfigList};
[INFO] [stdout]    |                          ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> src/file/mod.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/file/env.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs`
[INFO] [stdout]  --> src/file/env.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fs;
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::os::unix::fs::PermissionsExt`
[INFO] [stdout]  --> src/file/env.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::os::unix::fs::PermissionsExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration` and `UNIX_EPOCH`
[INFO] [stdout]  --> src/file/env.rs:5:17
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::time::{Duration, SystemTime, UNIX_EPOCH};
[INFO] [stdout]   |                 ^^^^^^^^              ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Value` and `json`
[INFO] [stdout]   --> src/file/env.rs:11:18
[INFO] [stdout]    |
[INFO] [stdout] 11 | use serde_json::{json, Value};
[INFO] [stdout]    |                  ^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyCollectionMap`
[INFO] [stdout]   --> src/file/env.rs:15:50
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::file::key_collection::{KeyCollection, KeyCollectionMap};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::file::metadata::extract_file_metadata`
[INFO] [stdout]   --> src/file/env.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::file::metadata::extract_file_metadata;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> src/file/format_manager.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::vec`
[INFO] [stdout]  --> src/file/format_manager.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::vec;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyCollectionTransform`
[INFO] [stdout]   --> src/file/format_manager.rs:12:50
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::file::key_collection::{KeyCollection, KeyCollectionTransform};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/file/json.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::file::metadata::extract_file_metadata`
[INFO] [stdout]  --> src/file/json.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::file::metadata::extract_file_metadata;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyCollectionMap`
[INFO] [stdout]   --> src/file/postman.rs:12:50
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::file::key_collection::{KeyCollection, KeyCollectionMap, KeyCollectionTransform};
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::Index`
[INFO] [stdout]  --> src/file/key_collection.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::ops::Index;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/file/parser/env.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]    --> src/command/diff.rs:170:5
[INFO] [stdout]     |
[INFO] [stdout] 170 | use log::info;
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `glob::glob`
[INFO] [stdout]  --> src/command/sub.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use glob::glob;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/key_manager.rs:42:21
[INFO] [stdout]    |
[INFO] [stdout] 42 |                 let mut keys = group.keys.to_key_detail_collection();
[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/key_manager.rs:42:21
[INFO] [stdout]    |
[INFO] [stdout] 42 |                 let mut keys = group.keys.to_key_detail_collection();
[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: unused import: `Watcher`
[INFO] [stdout]   --> src/key_manager.rs:12:75
[INFO] [stdout]    |
[INFO] [stdout] 12 | use notify::{Config, Event, EventKind, RecommendedWatcher, RecursiveMode, Watcher};
[INFO] [stdout]    |                                                                           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> src/flux/file.rs:7:15
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `keys`
[INFO] [stdout]    --> src/traits.rs:115:33
[INFO] [stdout]     |
[INFO] [stdout] 115 |     async fn check_batch(&self, keys: &KeyCollection) -> Result<Vec<(String, Option<String>)>, FluxError> {
[INFO] [stdout]     |                                 ^^^^ help: if this is intentional, prefix it with an underscore: `_keys`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `keys`
[INFO] [stdout]    --> src/traits.rs:149:34
[INFO] [stdout]     |
[INFO] [stdout] 149 |     async fn revert_batch(&self, keys: &KeyCollection) -> Result<(), FluxError> {
[INFO] [stdout]     |                                  ^^^^ help: if this is intentional, prefix it with an underscore: `_keys`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `keys`
[INFO] [stdout]    --> src/traits.rs:178:32
[INFO] [stdout]     |
[INFO] [stdout] 178 |     async fn diff_batch(&self, keys: &KeyCollection) -> Result<HashMap<String, String>, FluxError> {
[INFO] [stdout]     |                                ^^^^ help: if this is intentional, prefix it with an underscore: `_keys`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Watcher`
[INFO] [stdout]   --> src/key_manager.rs:12:75
[INFO] [stdout]    |
[INFO] [stdout] 12 | use notify::{Config, Event, EventKind, RecommendedWatcher, RecursiveMode, Watcher};
[INFO] [stdout]    |                                                                           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> src/flux/file.rs:7:15
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `keys`
[INFO] [stdout]    --> src/traits.rs:115:33
[INFO] [stdout]     |
[INFO] [stdout] 115 |     async fn check_batch(&self, keys: &KeyCollection) -> Result<Vec<(String, Option<String>)>, FluxError> {
[INFO] [stdout]     |                                 ^^^^ help: if this is intentional, prefix it with an underscore: `_keys`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `keys`
[INFO] [stdout]    --> src/traits.rs:149:34
[INFO] [stdout]     |
[INFO] [stdout] 149 |     async fn revert_batch(&self, keys: &KeyCollection) -> Result<(), FluxError> {
[INFO] [stdout]     |                                  ^^^^ help: if this is intentional, prefix it with an underscore: `_keys`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `keys`
[INFO] [stdout]    --> src/traits.rs:178:32
[INFO] [stdout]     |
[INFO] [stdout] 178 |     async fn diff_batch(&self, keys: &KeyCollection) -> Result<HashMap<String, String>, FluxError> {
[INFO] [stdout]     |                                ^^^^ help: if this is intentional, prefix it with an underscore: `_keys`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `key`
[INFO] [stdout]    --> src/flux/impl.rs:142:18
[INFO] [stdout]     |
[INFO] [stdout] 142 |             for (key, value) in map {
[INFO] [stdout]     |                  ^^^ help: if this is intentional, prefix it with an underscore: `_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `key`
[INFO] [stdout]    --> src/flux/impl.rs:142:18
[INFO] [stdout]     |
[INFO] [stdout] 142 |             for (key, value) in map {
[INFO] [stdout]     |                  ^^^ help: if this is intentional, prefix it with an underscore: `_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/flux/github.rs:212:17
[INFO] [stdout]     |
[INFO] [stdout] 212 |             let mut raw_input = self.input.clone();
[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/flux/github.rs:212:17
[INFO] [stdout]     |
[INFO] [stdout] 212 |             let mut raw_input = self.input.clone();
[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/flux/file.rs:159:13
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let mut existing_keys = manager.load_keys(&self.path, Some(&self.format))?;
[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/flux/file.rs:159:13
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let mut existing_keys = manager.load_keys(&self.path, Some(&self.format))?;
[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/key.rs:164:13
[INFO] [stdout]     |
[INFO] [stdout] 164 |         let mut replace_fn = |caps: &regex::Captures| {
[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/key.rs:169:13
[INFO] [stdout]     |
[INFO] [stdout] 169 |         let mut replace_recursively = |value: &mut String| {
[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/key.rs:164:13
[INFO] [stdout]     |
[INFO] [stdout] 164 |         let mut replace_fn = |caps: &regex::Captures| {
[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/key.rs:169:13
[INFO] [stdout]     |
[INFO] [stdout] 169 |         let mut replace_recursively = |value: &mut String| {
[INFO] [stdout]     |             ----^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `placeholders`
[INFO] [stdout]    --> src/file/format_manager.rs:127:13
[INFO] [stdout]     |
[INFO] [stdout] 127 |         let placeholders = Placeholder::extract_placeholders(pattern);
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_placeholders`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fmt`
[INFO] [stdout]    --> src/file/format_manager.rs:143:45
[INFO] [stdout]     |
[INFO] [stdout] 143 |     pub fn load_keys(&self, path: &PathBuf, fmt: Option<&str>) -> Result<KeyCollection, FluxError> {
[INFO] [stdout]     |                                             ^^^ help: if this is intentional, prefix it with an underscore: `_fmt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `placeholders`
[INFO] [stdout]    --> src/file/format_manager.rs:127:13
[INFO] [stdout]     |
[INFO] [stdout] 127 |         let placeholders = Placeholder::extract_placeholders(pattern);
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_placeholders`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fmt`
[INFO] [stdout]    --> src/file/format_manager.rs:143:45
[INFO] [stdout]     |
[INFO] [stdout] 143 |     pub fn load_keys(&self, path: &PathBuf, fmt: Option<&str>) -> Result<KeyCollection, FluxError> {
[INFO] [stdout]     |                                             ^^^ help: if this is intentional, prefix it with an underscore: `_fmt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `ARGS` is never used
[INFO] [stdout]  --> src/flux/impl.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | static ARGS: &str = "args";
[INFO] [stdout]   |        ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `MalformedLine` is never constructed
[INFO] [stdout]   --> src/file/env.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | enum EnvParseError {
[INFO] [stdout]    |      ------------- variant in this enum
[INFO] [stdout] 24 |     IoError(std::io::Error),
[INFO] [stdout] 25 |     MalformedLine(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `EnvParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_system_time` is never used
[INFO] [stdout]   --> src/file/env.rs:55:4
[INFO] [stdout]    |
[INFO] [stdout] 55 | fn format_system_time(time: SystemTime) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `errors` is never read
[INFO] [stdout]   --> src/file/parser/env.rs:21:16
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub(crate) struct EnvParser {
[INFO] [stdout]    |                   --------- field in this struct
[INFO] [stdout] 20 |     pub(crate) entries: Vec<LineContent>,
[INFO] [stdout] 21 |     pub(crate) errors: Vec<ParseError>,
[INFO] [stdout]    |                ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_string` is never used
[INFO] [stdout]   --> src/file/parser/env.rs:52:19
[INFO] [stdout]    |
[INFO] [stdout] 26 | impl EnvParser {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub(crate) fn to_string(&self) -> String {
[INFO] [stdout]    |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `VAR_REGEX_V1` is never used
[INFO] [stdout]  --> src/re.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub static VAR_REGEX_V1: &str = r#"\$\{([^}]+)\}"#;
[INFO] [stdout]   |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `VAR_REGEX_V2` is never used
[INFO] [stdout]  --> src/re.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub static VAR_REGEX_V2: &str = r#"\$\{([^{}]*(?:\{[^{}]*\}[^{}]*)*)\}"#; // fixes nested
[INFO] [stdout]   |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `ARGS` is never used
[INFO] [stdout]  --> src/flux/impl.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | static ARGS: &str = "args";
[INFO] [stdout]   |        ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `MalformedLine` is never constructed
[INFO] [stdout]   --> src/file/env.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | enum EnvParseError {
[INFO] [stdout]    |      ------------- variant in this enum
[INFO] [stdout] 24 |     IoError(std::io::Error),
[INFO] [stdout] 25 |     MalformedLine(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `EnvParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_system_time` is never used
[INFO] [stdout]   --> src/file/env.rs:55:4
[INFO] [stdout]    |
[INFO] [stdout] 55 | fn format_system_time(time: SystemTime) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `errors` is never read
[INFO] [stdout]   --> src/file/parser/env.rs:21:16
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub(crate) struct EnvParser {
[INFO] [stdout]    |                   --------- field in this struct
[INFO] [stdout] 20 |     pub(crate) entries: Vec<LineContent>,
[INFO] [stdout] 21 |     pub(crate) errors: Vec<ParseError>,
[INFO] [stdout]    |                ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_string` is never used
[INFO] [stdout]   --> src/file/parser/env.rs:52:19
[INFO] [stdout]    |
[INFO] [stdout] 26 | impl EnvParser {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub(crate) fn to_string(&self) -> String {
[INFO] [stdout]    |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0464]: multiple candidates for `rmeta` dependency `env_logger` found
[INFO] [stdout]   --> tests/test_tags.rs:14:13
[INFO] [stdout]    |
[INFO] [stdout] 14 |             env_logger::init();
[INFO] [stdout]    |             ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: candidate #1: /opt/rustwide/target/debug/deps/libenv_logger-596d8ba2788811e9.rmeta
[INFO] [stdout]    = note: candidate #2: /opt/rustwide/target/debug/deps/libenv_logger-babd26fca780281d.rmeta
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0464]: multiple candidates for `rmeta` dependency `env_logger` found
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use env_logger::WriteStyle;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: candidate #1: /opt/rustwide/target/debug/deps/libenv_logger-596d8ba2788811e9.rmeta
[INFO] [stdout]    = note: candidate #2: /opt/rustwide/target/debug/deps/libenv_logger-babd26fca780281d.rmeta
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyFluxConfig`
[INFO] [stdout]  --> src/main.rs:2:37
[INFO] [stdout]   |
[INFO] [stdout] 2 | use keyflux::config::{ConfigHolder, KeyFluxConfig};
[INFO] [stdout]   |                                     ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/main.rs:3:24
[INFO] [stdout]   |
[INFO] [stdout] 3 | use log::{error, info, warn, trace};
[INFO] [stdout]   |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Path`
[INFO] [stdout]  --> src/main.rs:5:17
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::path::{Path, PathBuf};
[INFO] [stdout]   |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/main.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `env`
[INFO] [stdout]  --> src/main.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::{env, io};
[INFO] [stdout]   |           ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs`
[INFO] [stdout]  --> src/main.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::fs;
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Args`, `Subcommand`, and `ValueHint`
[INFO] [stdout]   --> src/main.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | use clap::{Args, Command, CommandFactory, Parser, Subcommand, ValueHint};
[INFO] [stdout]    |            ^^^^                                   ^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Shell`
[INFO] [stdout]   --> src/main.rs:21:42
[INFO] [stdout]    |
[INFO] [stdout] 21 | use clap_complete::{generate, Generator, Shell};
[INFO] [stdout]    |                                          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `keyflux::key::Key`
[INFO] [stdout]   --> src/main.rs:97:5
[INFO] [stdout]    |
[INFO] [stdout] 97 | use keyflux::key::Key;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `keyflux::key::KeyDetail`
[INFO] [stdout]    --> src/main.rs:135:5
[INFO] [stdout]     |
[INFO] [stdout] 135 | use keyflux::key::KeyDetail;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0464]: multiple candidates for `rmeta` dependency `env_logger` found
[INFO] [stdout]    --> src/main.rs:186:5
[INFO] [stdout]     |
[INFO] [stdout] 186 |     env_logger::Builder::new()
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: candidate #1: /opt/rustwide/target/debug/deps/libenv_logger-596d8ba2788811e9.rmeta
[INFO] [stdout]     = note: candidate #2: /opt/rustwide/target/debug/deps/libenv_logger-babd26fca780281d.rmeta
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `KeyFluxConfig`
[INFO] [stdout]  --> src/main.rs:2:37
[INFO] [stdout]   |
[INFO] [stdout] 2 | use keyflux::config::{ConfigHolder, KeyFluxConfig};
[INFO] [stdout]   |                                     ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/main.rs:3:24
[INFO] [stdout]   |
[INFO] [stdout] 3 | use log::{error, info, warn, trace};
[INFO] [stdout]   |                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Path`
[INFO] [stdout]  --> src/main.rs:5:17
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::path::{Path, PathBuf};
[INFO] [stdout]   |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/main.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `env`
[INFO] [stdout]  --> src/main.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::{env, io};
[INFO] [stdout]   |           ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs`
[INFO] [stdout]  --> src/main.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::fs;
[INFO] [stdout]   |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Args`, `Subcommand`, and `ValueHint`
[INFO] [stdout]   --> src/main.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | use clap::{Args, Command, CommandFactory, Parser, Subcommand, ValueHint};
[INFO] [stdout]    |            ^^^^                                   ^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Shell`
[INFO] [stdout]   --> src/main.rs:21:42
[INFO] [stdout]    |
[INFO] [stdout] 21 | use clap_complete::{generate, Generator, Shell};
[INFO] [stdout]    |                                          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `keyflux::key::Key`
[INFO] [stdout]   --> src/main.rs:97:5
[INFO] [stdout]    |
[INFO] [stdout] 97 | use keyflux::key::Key;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `keyflux::key::KeyDetail`
[INFO] [stdout]    --> src/main.rs:135:5
[INFO] [stdout]     |
[INFO] [stdout] 135 | use keyflux::key::KeyDetail;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `keyflux::file::key::Key`
[INFO] [stdout]  --> tests/file/common.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use keyflux::file::key::Key;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^ no `Key` in `file::key`
[INFO] [stdout]   |
[INFO] [stdout] help: consider importing one of these items instead
[INFO] [stdout]   |
[INFO] [stdout] 1 | use keyflux::config::KeyEnum::Key;
[INFO] [stdout]   |     ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 1 | use keyflux::key::Key;
[INFO] [stdout]   |     ~~~~~~~~~~~~~~~~~
[INFO] [stdout] 1 | use sodiumoxide::crypto::aead::Key;
[INFO] [stdout]   |     ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 1 | use sodiumoxide::crypto::aead::aes256gcm::Key;
[INFO] [stdout]   |     ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout]     and 15 other candidates
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `keyflux::key::AttributeValue`
[INFO] [stdout]  --> tests/test_key.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use keyflux::key::AttributeValue;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ no `AttributeValue` in `key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved imports `keyflux::key::Attributes`, `keyflux::key::AttributeValue`
[INFO] [stdout]  --> tests/test_key.rs:5:24
[INFO] [stdout]   |
[INFO] [stdout] 5 |     use keyflux::key::{Attributes, AttributeValue, Key};
[INFO] [stdout]   |                        ^^^^^^^^^^  ^^^^^^^^^^^^^^ no `AttributeValue` in `key`
[INFO] [stdout]   |                        |
[INFO] [stdout]   |                        no `Attributes` in `key`
[INFO] [stdout]   |
[INFO] [stdout]   = help: consider importing this unresolved item through its public re-export instead:
[INFO] [stdout]           crate::AttributeValue
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0464`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `keyflux` (test "test_tags") due to 1 previous error
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] For more information about this error, try `rustc --explain E0464`.
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:159:9
[INFO] [stdout]     |
[INFO] [stdout] 159 |     let mut cli = Cli::parse();
[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: function `print_completions` is never used
[INFO] [stdout]    --> src/main.rs:149:4
[INFO] [stdout]     |
[INFO] [stdout] 149 | fn print_completions<G: Generator>(gen: G, cmd: &mut Command) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `keyflux` (bin "keyflux" test) due to 2 previous errors; 10 warnings emitted
[INFO] [stdout] error[E0599]: no variant or associated item named `new` found for enum `keyflux::key::Key` in the current scope
[INFO] [stdout]    --> tests/test_key.rs:96:24
[INFO] [stdout]     |
[INFO] [stdout] 96  |         let key = Key::new("name", "value", attributes);
[INFO] [stdout]     |                        ^^^ variant or associated item not found in `Key`
[INFO] [stdout]     |
[INFO] [stdout] note: if you're trying to build a new `keyflux::key::Key` consider using one of the following associated functions:
[INFO] [stdout]       keyflux::key::Key::from_key_detail
[INFO] [stdout]       keyflux::key::Key::from_key_value
[INFO] [stdout]    --> /opt/rustwide/workdir/src/key.rs:136:5
[INFO] [stdout]     |
[INFO] [stdout] 136 |     pub fn from_key_detail(detail: KeyDetail) -> Key {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 140 |     pub fn from_key_value(kv: KeyValue) -> Key {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: there is a method `ne` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/39cb3386ddc6c71657418be28dbb3987eea4aa4b/library/core/src/cmp.rs:261:5
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no variant or associated item named `new` found for enum `keyflux::key::Key` in the current scope
[INFO] [stdout]    --> tests/test_key.rs:104:24
[INFO] [stdout]     |
[INFO] [stdout] 104 |         let key = Key::new("name", "value", attributes);
[INFO] [stdout]     |                        ^^^ variant or associated item not found in `Key`
[INFO] [stdout]     |
[INFO] [stdout] note: if you're trying to build a new `keyflux::key::Key` consider using one of the following associated functions:
[INFO] [stdout]       keyflux::key::Key::from_key_detail
[INFO] [stdout]       keyflux::key::Key::from_key_value
[INFO] [stdout]    --> /opt/rustwide/workdir/src/key.rs:136:5
[INFO] [stdout]     |
[INFO] [stdout] 136 |     pub fn from_key_detail(detail: KeyDetail) -> Key {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 140 |     pub fn from_key_value(kv: KeyValue) -> Key {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: there is a method `ne` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/39cb3386ddc6c71657418be28dbb3987eea4aa4b/library/core/src/cmp.rs:261:5
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no variant or associated item named `new` found for enum `keyflux::key::Key` in the current scope
[INFO] [stdout]    --> tests/test_key.rs:114:24
[INFO] [stdout]     |
[INFO] [stdout] 114 |         let key = Key::new("name", "value", attributes.clone());
[INFO] [stdout]     |                        ^^^ variant or associated item not found in `Key`
[INFO] [stdout]     |
[INFO] [stdout] note: if you're trying to build a new `keyflux::key::Key` consider using one of the following associated functions:
[INFO] [stdout]       keyflux::key::Key::from_key_detail
[INFO] [stdout]       keyflux::key::Key::from_key_value
[INFO] [stdout]    --> /opt/rustwide/workdir/src/key.rs:136:5
[INFO] [stdout]     |
[INFO] [stdout] 136 |     pub fn from_key_detail(detail: KeyDetail) -> Key {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 140 |     pub fn from_key_value(kv: KeyValue) -> Key {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: there is a method `ne` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/39cb3386ddc6c71657418be28dbb3987eea4aa4b/library/core/src/cmp.rs:261:5
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no variant or associated item named `new` found for enum `keyflux::key::Key` in the current scope
[INFO] [stdout]    --> tests/test_key.rs:123:24
[INFO] [stdout]     |
[INFO] [stdout] 123 |         let key = Key::new("name", "value", attributes);
[INFO] [stdout]     |                        ^^^ variant or associated item not found in `Key`
[INFO] [stdout]     |
[INFO] [stdout] note: if you're trying to build a new `keyflux::key::Key` consider using one of the following associated functions:
[INFO] [stdout]       keyflux::key::Key::from_key_detail
[INFO] [stdout]       keyflux::key::Key::from_key_value
[INFO] [stdout]    --> /opt/rustwide/workdir/src/key.rs:136:5
[INFO] [stdout]     |
[INFO] [stdout] 136 |     pub fn from_key_detail(detail: KeyDetail) -> Key {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 140 |     pub fn from_key_value(kv: KeyValue) -> Key {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] help: there is a method `ne` with a similar name, but with different arguments
[INFO] [stdout]    --> /rustc/39cb3386ddc6c71657418be28dbb3987eea4aa4b/library/core/src/cmp.rs:261:5
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0432, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0432`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `keyflux` (test "test_key") due to 6 previous errors
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]   --> tests/file/test_json_adapter.rs:34:34
[INFO] [stdout]    |
[INFO] [stdout] 34 |     let keys = adapter.load_keys(contents).unwrap();
[INFO] [stdout]    |                        --------- ^^^^^^^^ expected `&PathBuf`, found `&str`
[INFO] [stdout]    |                        |
[INFO] [stdout]    |                        arguments to this method are incorrect
[INFO] [stdout]    |
[INFO] [stdout]    = note: expected reference `&PathBuf`
[INFO] [stdout]               found reference `&str`
[INFO] [stdout] note: method defined here
[INFO] [stdout]   --> /opt/rustwide/workdir/src/file/format_manager.rs:77:8
[INFO] [stdout]    |
[INFO] [stdout] 77 |     fn load_keys(&self, path: &PathBuf) -> Result<KeyCollection, FluxError>;
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `len` found for enum `KeyCollection` in the current scope
[INFO] [stdout]   --> tests/file/test_json_adapter.rs:36:21
[INFO] [stdout]    |
[INFO] [stdout] 36 |     assert_eq!(keys.len(), 2);
[INFO] [stdout]    |                     ^^^ method not found in `KeyCollection`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0608]: cannot index into a value of type `KeyCollection`
[INFO] [stdout]   --> tests/file/test_json_adapter.rs:37:20
[INFO] [stdout]    |
[INFO] [stdout] 37 |     assert_eq!(keys["KEY1"].value, "VALUE1");
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0608]: cannot index into a value of type `KeyCollection`
[INFO] [stdout]   --> tests/file/test_json_adapter.rs:38:20
[INFO] [stdout]    |
[INFO] [stdout] 38 |     assert_eq!(keys["KEY2"].value, "VALUE2");
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this method takes 2 arguments but 1 argument was supplied
[INFO] [stdout]   --> tests/file/test_json_adapter.rs:45:26
[INFO] [stdout]    |
[INFO] [stdout] 45 |     let result = adapter.save_keys(&keys).unwrap();
[INFO] [stdout]    |                          ^^^^^^^^^------- argument #2 of type `&KeyCollection` is missing
[INFO] [stdout]    |
[INFO] [stdout] note: method defined here
[INFO] [stdout]   --> /opt/rustwide/workdir/src/file/format_manager.rs:80:8
[INFO] [stdout]    |
[INFO] [stdout] 80 |     fn save_keys(&self, path: &PathBuf, keys: &KeyCollection) -> Result<(), FluxError>;
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] help: provide the argument
[INFO] [stdout]    |
[INFO] [stdout] 45 |     let result = adapter.save_keys(&keys, /* &KeyCollection */).unwrap();
[INFO] [stdout]    |                                   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_json_adapter.rs:47:20
[INFO] [stdout]    |
[INFO] [stdout] 47 |     assert!(result.contains("\"name\": \"KEY1\""));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 47 |     assert!(result.contains_token("\"name\": \"KEY1\""));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_json_adapter.rs:48:20
[INFO] [stdout]    |
[INFO] [stdout] 48 |     assert!(result.contains("\"value\": \"VALUE1\""));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 48 |     assert!(result.contains_token("\"value\": \"VALUE1\""));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_json_adapter.rs:49:20
[INFO] [stdout]    |
[INFO] [stdout] 49 |     assert!(result.contains("\"name\": \"KEY2\""));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 49 |     assert!(result.contains_token("\"name\": \"KEY2\""));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_json_adapter.rs:50:20
[INFO] [stdout]    |
[INFO] [stdout] 50 |     assert!(result.contains("\"value\": \"VALUE2\""));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 50 |     assert!(result.contains_token("\"value\": \"VALUE2\""));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]   --> tests/file/test_toml_adapter.rs:24:34
[INFO] [stdout]    |
[INFO] [stdout] 24 |     let keys = adapter.load_keys(contents).unwrap();
[INFO] [stdout]    |                        --------- ^^^^^^^^ expected `&PathBuf`, found `&str`
[INFO] [stdout]    |                        |
[INFO] [stdout]    |                        arguments to this method are incorrect
[INFO] [stdout]    |
[INFO] [stdout]    = note: expected reference `&PathBuf`
[INFO] [stdout]               found reference `&str`
[INFO] [stdout] note: method defined here
[INFO] [stdout]   --> /opt/rustwide/workdir/src/file/format_manager.rs:77:8
[INFO] [stdout]    |
[INFO] [stdout] 77 |     fn load_keys(&self, path: &PathBuf) -> Result<KeyCollection, FluxError>;
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `len` found for enum `KeyCollection` in the current scope
[INFO] [stdout]   --> tests/file/test_toml_adapter.rs:26:21
[INFO] [stdout]    |
[INFO] [stdout] 26 |     assert_eq!(keys.len(), 2);
[INFO] [stdout]    |                     ^^^ method not found in `KeyCollection`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0608]: cannot index into a value of type `KeyCollection`
[INFO] [stdout]   --> tests/file/test_toml_adapter.rs:27:20
[INFO] [stdout]    |
[INFO] [stdout] 27 |     assert_eq!(keys["KEY1"].value, "VALUE1");
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0608]: cannot index into a value of type `KeyCollection`
[INFO] [stdout]   --> tests/file/test_toml_adapter.rs:28:20
[INFO] [stdout]    |
[INFO] [stdout] 28 |     assert_eq!(keys["KEY2"].value, "VALUE2");
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this method takes 2 arguments but 1 argument was supplied
[INFO] [stdout]   --> tests/file/test_toml_adapter.rs:35:26
[INFO] [stdout]    |
[INFO] [stdout] 35 |     let result = adapter.save_keys(&keys).unwrap();
[INFO] [stdout]    |                          ^^^^^^^^^------- argument #2 of type `&KeyCollection` is missing
[INFO] [stdout]    |
[INFO] [stdout] note: method defined here
[INFO] [stdout]   --> /opt/rustwide/workdir/src/file/format_manager.rs:80:8
[INFO] [stdout]    |
[INFO] [stdout] 80 |     fn save_keys(&self, path: &PathBuf, keys: &KeyCollection) -> Result<(), FluxError>;
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] help: provide the argument
[INFO] [stdout]    |
[INFO] [stdout] 35 |     let result = adapter.save_keys(&keys, /* &KeyCollection */).unwrap();
[INFO] [stdout]    |                                   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_toml_adapter.rs:37:20
[INFO] [stdout]    |
[INFO] [stdout] 37 |     assert!(result.contains("[KEY1]"));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 37 |     assert!(result.contains_token("[KEY1]"));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_toml_adapter.rs:38:20
[INFO] [stdout]    |
[INFO] [stdout] 38 |     assert!(result.contains("name = \"KEY1\""));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 38 |     assert!(result.contains_token("name = \"KEY1\""));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_toml_adapter.rs:39:20
[INFO] [stdout]    |
[INFO] [stdout] 39 |     assert!(result.contains("value = \"VALUE1\""));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 39 |     assert!(result.contains_token("value = \"VALUE1\""));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_toml_adapter.rs:40:20
[INFO] [stdout]    |
[INFO] [stdout] 40 |     assert!(result.contains("[KEY2]"));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 40 |     assert!(result.contains_token("[KEY2]"));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_toml_adapter.rs:41:20
[INFO] [stdout]    |
[INFO] [stdout] 41 |     assert!(result.contains("name = \"KEY2\""));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 41 |     assert!(result.contains_token("name = \"KEY2\""));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_toml_adapter.rs:42:20
[INFO] [stdout]    |
[INFO] [stdout] 42 |     assert!(result.contains("value = \"VALUE2\""));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 42 |     assert!(result.contains_token("value = \"VALUE2\""));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]   --> tests/file/test_yaml_adapter.rs:26:34
[INFO] [stdout]    |
[INFO] [stdout] 26 |     let keys = adapter.load_keys(contents).unwrap();
[INFO] [stdout]    |                        --------- ^^^^^^^^ expected `&PathBuf`, found `&str`
[INFO] [stdout]    |                        |
[INFO] [stdout]    |                        arguments to this method are incorrect
[INFO] [stdout]    |
[INFO] [stdout]    = note: expected reference `&PathBuf`
[INFO] [stdout]               found reference `&str`
[INFO] [stdout] note: method defined here
[INFO] [stdout]   --> /opt/rustwide/workdir/src/file/format_manager.rs:77:8
[INFO] [stdout]    |
[INFO] [stdout] 77 |     fn load_keys(&self, path: &PathBuf) -> Result<KeyCollection, FluxError>;
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `len` found for enum `KeyCollection` in the current scope
[INFO] [stdout]   --> tests/file/test_yaml_adapter.rs:28:21
[INFO] [stdout]    |
[INFO] [stdout] 28 |     assert_eq!(keys.len(), 2);
[INFO] [stdout]    |                     ^^^ method not found in `KeyCollection`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0608]: cannot index into a value of type `KeyCollection`
[INFO] [stdout]   --> tests/file/test_yaml_adapter.rs:29:20
[INFO] [stdout]    |
[INFO] [stdout] 29 |     assert_eq!(keys["KEY1"].value, "VALUE1");
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0608]: cannot index into a value of type `KeyCollection`
[INFO] [stdout]   --> tests/file/test_yaml_adapter.rs:30:20
[INFO] [stdout]    |
[INFO] [stdout] 30 |     assert_eq!(keys["KEY2"].value, "VALUE2");
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this method takes 2 arguments but 1 argument was supplied
[INFO] [stdout]   --> tests/file/test_yaml_adapter.rs:37:26
[INFO] [stdout]    |
[INFO] [stdout] 37 |     let result = adapter.save_keys(&keys).unwrap();
[INFO] [stdout]    |                          ^^^^^^^^^------- argument #2 of type `&KeyCollection` is missing
[INFO] [stdout]    |
[INFO] [stdout] note: method defined here
[INFO] [stdout]   --> /opt/rustwide/workdir/src/file/format_manager.rs:80:8
[INFO] [stdout]    |
[INFO] [stdout] 80 |     fn save_keys(&self, path: &PathBuf, keys: &KeyCollection) -> Result<(), FluxError>;
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] help: provide the argument
[INFO] [stdout]    |
[INFO] [stdout] 37 |     let result = adapter.save_keys(&keys, /* &KeyCollection */).unwrap();
[INFO] [stdout]    |                                   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_yaml_adapter.rs:39:20
[INFO] [stdout]    |
[INFO] [stdout] 39 |     assert!(result.contains("KEY1:"));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 39 |     assert!(result.contains_token("KEY1:"));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_yaml_adapter.rs:40:20
[INFO] [stdout]    |
[INFO] [stdout] 40 |     assert!(result.contains("name: KEY1"));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 40 |     assert!(result.contains_token("name: KEY1"));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_yaml_adapter.rs:41:20
[INFO] [stdout]    |
[INFO] [stdout] 41 |     assert!(result.contains("value: VALUE1"));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 41 |     assert!(result.contains_token("value: VALUE1"));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_yaml_adapter.rs:42:20
[INFO] [stdout]    |
[INFO] [stdout] 42 |     assert!(result.contains("KEY2:"));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 42 |     assert!(result.contains_token("KEY2:"));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_yaml_adapter.rs:43:20
[INFO] [stdout]    |
[INFO] [stdout] 43 |     assert!(result.contains("name: KEY2"));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 43 |     assert!(result.contains_token("name: KEY2"));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]   --> tests/file/test_yaml_adapter.rs:44:20
[INFO] [stdout]    |
[INFO] [stdout] 44 |     assert!(result.contains("value: VALUE2"));
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]    |
[INFO] [stdout] 44 |     assert!(result.contains_token("value: VALUE2"));
[INFO] [stdout]    |                    ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0308]: mismatched types
[INFO] [stdout]    --> tests/file/test_postman_adapter.rs:133:38
[INFO] [stdout]     |
[INFO] [stdout] 133 |         let keys = adapter.load_keys(contents).unwrap();
[INFO] [stdout]     |                            --------- ^^^^^^^^ expected `&PathBuf`, found `&str`
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            arguments to this method are incorrect
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected reference `&PathBuf`
[INFO] [stdout]                found reference `&str`
[INFO] [stdout] note: method defined here
[INFO] [stdout]    --> /opt/rustwide/workdir/src/file/format_manager.rs:77:8
[INFO] [stdout]     |
[INFO] [stdout] 77  |     fn load_keys(&self, path: &PathBuf) -> Result<KeyCollection, FluxError>;
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `len` found for enum `KeyCollection` in the current scope
[INFO] [stdout]    --> tests/file/test_postman_adapter.rs:135:25
[INFO] [stdout]     |
[INFO] [stdout] 135 |         assert_eq!(keys.len(), 2);
[INFO] [stdout]     |                         ^^^ method not found in `KeyCollection`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0608]: cannot index into a value of type `KeyCollection`
[INFO] [stdout]    --> tests/file/test_postman_adapter.rs:136:24
[INFO] [stdout]     |
[INFO] [stdout] 136 |         assert_eq!(keys["KEY1"].value, "VALUE1");
[INFO] [stdout]     |                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0608]: cannot index into a value of type `KeyCollection`
[INFO] [stdout]    --> tests/file/test_postman_adapter.rs:137:24
[INFO] [stdout]     |
[INFO] [stdout] 137 |         assert_eq!(keys["KEY2"].value, "VALUE2");
[INFO] [stdout]     |                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this method takes 2 arguments but 1 argument was supplied
[INFO] [stdout]    --> tests/file/test_postman_adapter.rs:144:30
[INFO] [stdout]     |
[INFO] [stdout] 144 |         let result = adapter.save_keys(&keys).unwrap();
[INFO] [stdout]     |                              ^^^^^^^^^------- argument #2 of type `&KeyCollection` is missing
[INFO] [stdout]     |
[INFO] [stdout] note: method defined here
[INFO] [stdout]    --> /opt/rustwide/workdir/src/file/format_manager.rs:80:8
[INFO] [stdout]     |
[INFO] [stdout] 80  |     fn save_keys(&self, path: &PathBuf, keys: &KeyCollection) -> Result<(), FluxError>;
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] help: provide the argument
[INFO] [stdout]     |
[INFO] [stdout] 144 |         let result = adapter.save_keys(&keys, /* &KeyCollection */).unwrap();
[INFO] [stdout]     |                                       ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]    --> tests/file/test_postman_adapter.rs:146:24
[INFO] [stdout]     |
[INFO] [stdout] 146 |         assert!(result.contains("\"key\": \"KEY1\""));
[INFO] [stdout]     |                        ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]     |
[INFO] [stdout] 146 |         assert!(result.contains_token("\"key\": \"KEY1\""));
[INFO] [stdout]     |                        ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]    --> tests/file/test_postman_adapter.rs:147:24
[INFO] [stdout]     |
[INFO] [stdout] 147 |         assert!(result.contains("\"value\": \"VALUE1\""));
[INFO] [stdout]     |                        ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]     |
[INFO] [stdout] 147 |         assert!(result.contains_token("\"value\": \"VALUE1\""));
[INFO] [stdout]     |                        ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]    --> tests/file/test_postman_adapter.rs:148:24
[INFO] [stdout]     |
[INFO] [stdout] 148 |         assert!(result.contains("\"key\": \"KEY2\""));
[INFO] [stdout]     |                        ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]     |
[INFO] [stdout] 148 |         assert!(result.contains_token("\"key\": \"KEY2\""));
[INFO] [stdout]     |                        ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `contains` found for unit type `()` in the current scope
[INFO] [stdout]    --> tests/file/test_postman_adapter.rs:149:24
[INFO] [stdout]     |
[INFO] [stdout] 149 |         assert!(result.contains("\"value\": \"VALUE2\""));
[INFO] [stdout]     |                        ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: there is a method `contains_token` with a similar name
[INFO] [stdout]     |
[INFO] [stdout] 149 |         assert!(result.contains_token("\"value\": \"VALUE2\""));
[INFO] [stdout]     |                        ~~~~~~~~~~~~~~
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0061, E0308, E0432, E0599, E0608.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0061`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `keyflux` (test "mod") due to 41 previous errors
[INFO] running `Command { std: "docker" "inspect" "366c809d4da9fe98b5bb371462b2e84dd48e8c0b0cc26b31e76a034d8aabd25b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "366c809d4da9fe98b5bb371462b2e84dd48e8c0b0cc26b31e76a034d8aabd25b", kill_on_drop: false }`
[INFO] [stdout] 366c809d4da9fe98b5bb371462b2e84dd48e8c0b0cc26b31e76a034d8aabd25b
