[INFO] fetching crate streamforge 0.3.0... [INFO] linting streamforge-0.3.0 against nightly for clippy-nonminimal_bool-denied [INFO] extracting crate streamforge 0.3.0 into /workspace/builds/worker-2-tc1/source [INFO] started tweaking crates.io crate streamforge 0.3.0 [INFO] removed 0 missing tests [INFO] finished tweaking crates.io crate streamforge 0.3.0 [INFO] tweaked toml for crates.io crate streamforge 0.3.0 written to /workspace/builds/worker-2-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate streamforge 0.3.0 on toolchain nightly [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+nightly" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate streamforge 0.3.0 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" "+nightly" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded plain v0.2.3 [INFO] [stderr] Downloaded filetime v0.2.27 [INFO] [stderr] Downloaded zstd v0.13.3 [INFO] [stderr] Downloaded redox_syscall v0.7.3 [INFO] [stderr] Downloaded proc-macro-crate v3.5.0 [INFO] [stderr] Downloaded sigchld v0.2.4 [INFO] [stderr] Downloaded rustls-native-certs v0.8.3 [INFO] [stderr] Downloaded hashlink v0.8.4 [INFO] [stderr] Downloaded os_pipe v1.2.3 [INFO] [stderr] Downloaded pest_generator v2.8.6 [INFO] [stderr] Downloaded pest_meta v2.8.6 [INFO] [stderr] Downloaded pest_derive v2.8.6 [INFO] [stderr] Downloaded schemars v1.2.1 [INFO] [stderr] Downloaded pest v2.8.6 [INFO] [stderr] Downloaded yaml-rust2 v0.8.1 [INFO] [stderr] Downloaded toml_edit v0.25.4+spec-1.1.0 [INFO] [stderr] Downloaded serde_with v3.17.0 [INFO] [stderr] Downloaded rdkafka v0.36.2 [INFO] [stderr] Downloaded bollard v0.18.1 [INFO] [stderr] Downloaded bollard-stubs v1.47.1-rc.27.3.1 [INFO] [stderr] Downloaded ron v0.8.1 [INFO] [stderr] Downloaded config v0.14.1 [INFO] [stderr] Downloaded rust-ini v0.20.0 [INFO] [stderr] Downloaded toml_datetime v1.0.0+spec-1.1.0 [INFO] [stderr] Downloaded rustls v0.23.37 [INFO] [stderr] Downloaded toml_parser v1.0.9+spec-1.1.0 [INFO] [stderr] Downloaded duct v0.13.7 [INFO] [stderr] Downloaded snap v1.1.1 [INFO] [stderr] Downloaded serde_with_macros v3.17.0 [INFO] [stderr] Downloaded tokio-tar v0.3.1 [INFO] [stderr] Downloaded testcontainers v0.23.3 [INFO] [stderr] Downloaded etcetera v0.8.0 [INFO] [stderr] Downloaded shared_child v1.1.1 [INFO] [stderr] Downloaded ref-cast-impl v1.0.25 [INFO] [stderr] Downloaded zstd-safe v7.2.4 [INFO] [stderr] Downloaded ref-cast v1.0.25 [INFO] [stderr] Downloaded zstd-sys v2.0.16+zstd.1.5.7 [INFO] [stderr] Downloaded sasl2-sys v0.1.22+2.1.28 [INFO] [stderr] Downloaded libz-sys v1.1.25 [INFO] [stderr] Downloaded rdkafka-sys v4.10.0+2.12.1 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+nightly" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 4e072e3e05c574ece8321587c7cd8ee15c4bc453108049222c3dab6b14d78617 [INFO] running `Command { std: "docker" "start" "-a" "4e072e3e05c574ece8321587c7cd8ee15c4bc453108049222c3dab6b14d78617", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "4e072e3e05c574ece8321587c7cd8ee15c4bc453108049222c3dab6b14d78617", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4e072e3e05c574ece8321587c7cd8ee15c4bc453108049222c3dab6b14d78617", kill_on_drop: false }` [INFO] [stdout] 4e072e3e05c574ece8321587c7cd8ee15c4bc453108049222c3dab6b14d78617 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+nightly" "clippy" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] dc4747961f496bb7ac524518615753cf37b2a8eee04fef3de70df0aa142d1c63 [INFO] running `Command { std: "docker" "start" "-a" "dc4747961f496bb7ac524518615753cf37b2a8eee04fef3de70df0aa142d1c63", kill_on_drop: false }` [INFO] [stderr] Compiling find-msvc-tools v0.1.9 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling memchr v2.8.0 [INFO] [stderr] Compiling serde v1.0.228 [INFO] [stderr] Checking once_cell v1.21.3 [INFO] [stderr] Compiling pkg-config v0.3.32 [INFO] [stderr] Checking smallvec v1.15.1 [INFO] [stderr] Checking pin-project-lite v0.2.17 [INFO] [stderr] Checking itoa v1.0.17 [INFO] [stderr] Compiling regex-syntax v0.8.10 [INFO] [stderr] Compiling parking_lot_core v0.9.12 [INFO] [stderr] Compiling libc v0.2.183 [INFO] [stderr] Checking futures-core v0.3.32 [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Checking lock_api v0.4.14 [INFO] [stderr] Checking errno v0.3.14 [INFO] [stderr] Checking mio v1.1.1 [INFO] [stderr] Checking socket2 v0.6.3 [INFO] [stderr] Checking futures-sink v0.3.32 [INFO] [stderr] Checking signal-hook-registry v1.4.8 [INFO] [stderr] Compiling signal-hook v0.3.18 [INFO] [stderr] Checking futures-channel v0.3.32 [INFO] [stderr] Compiling bitflags v2.11.0 [INFO] [stderr] Compiling zmij v1.0.21 [INFO] [stderr] Compiling serde_json v1.0.149 [INFO] [stderr] Compiling vcpkg v0.2.15 [INFO] [stderr] Compiling crunchy v0.2.4 [INFO] [stderr] Checking slab v0.4.12 [INFO] [stderr] Checking futures-task v0.3.32 [INFO] [stderr] Checking futures-io v0.3.32 [INFO] [stderr] Compiling ahash v0.8.12 [INFO] [stderr] Checking tracing-core v0.1.36 [INFO] [stderr] Compiling tiny-keccak v2.0.2 [INFO] [stderr] Checking parking_lot v0.12.5 [INFO] [stderr] Checking zeroize v1.8.2 [INFO] [stderr] Compiling winnow v0.7.15 [INFO] [stderr] Checking http v1.4.0 [INFO] [stderr] Compiling toml_datetime v1.0.0+spec-1.1.0 [INFO] [stderr] Checking rustls-pki-types v1.14.0 [INFO] [stderr] Compiling httparse v1.10.1 [INFO] [stderr] Checking aho-corasick v1.1.4 [INFO] [stderr] Compiling nom v7.1.3 [INFO] [stderr] Compiling ucd-trie v0.1.7 [INFO] [stderr] Checking getrandom v0.2.17 [INFO] [stderr] Checking try-lock v0.2.5 [INFO] [stderr] Checking untrusted v0.9.0 [INFO] [stderr] Checking hashbrown v0.16.1 [INFO] [stderr] Checking log v0.4.29 [INFO] [stderr] Compiling crossbeam-utils v0.8.21 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Compiling clang-sys v1.8.1 [INFO] [stderr] Compiling os_pipe v1.2.3 [INFO] [stderr] Compiling pest v2.8.6 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Compiling const-random-macro v0.1.16 [INFO] [stderr] Checking http-body v1.0.1 [INFO] [stderr] Compiling sigchld v0.2.4 [INFO] [stderr] Compiling shared_child v1.1.1 [INFO] [stderr] Checking want v0.3.1 [INFO] [stderr] Checking ryu v1.0.23 [INFO] [stderr] Compiling duct v0.13.7 [INFO] [stderr] Checking httpdate v1.0.3 [INFO] [stderr] Checking atomic-waker v1.1.2 [INFO] [stderr] Checking indexmap v2.13.0 [INFO] [stderr] Compiling rustls v0.23.37 [INFO] [stderr] Checking base64 v0.21.7 [INFO] [stderr] Checking const-random v0.1.18 [INFO] [stderr] Checking tower-service v0.3.3 [INFO] [stderr] Checking dlv-list v0.5.2 [INFO] [stderr] Compiling zstd-safe v7.2.4 [INFO] [stderr] Checking subtle v2.6.1 [INFO] [stderr] Checking regex-automata v0.4.14 [INFO] [stderr] Compiling rustix v1.1.4 [INFO] [stderr] Compiling crc32fast v1.5.0 [INFO] [stderr] Checking toml_write v0.1.2 [INFO] [stderr] Checking either v1.15.0 [INFO] [stderr] Compiling cmake v0.1.57 [INFO] [stderr] Checking crossbeam-epoch v0.9.18 [INFO] [stderr] Compiling pest_meta v2.8.6 [INFO] [stderr] Compiling toml_parser v1.0.9+spec-1.1.0 [INFO] [stderr] Checking form_urlencoded v1.2.2 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Checking encoding_rs v0.8.35 [INFO] [stderr] Checking unicode-segmentation v1.12.0 [INFO] [stderr] Checking simd-adler32 v0.3.8 [INFO] [stderr] Compiling anyhow v1.0.102 [INFO] [stderr] Checking arraydeque v0.5.1 [INFO] [stderr] Compiling thiserror v1.0.69 [INFO] [stderr] Checking linux-raw-sys v0.12.1 [INFO] [stderr] Checking minimal-lexical v0.2.1 [INFO] [stderr] Compiling rayon-core v1.13.0 [INFO] [stderr] Compiling snap v1.1.1 [INFO] [stderr] Checking adler2 v2.0.1 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling sasl2-sys v0.1.22+2.1.28 [INFO] [stderr] Compiling openssl-sys v0.9.111 [INFO] [stderr] Compiling libz-sys v1.1.25 [INFO] [stderr] Compiling rdkafka-sys v4.10.0+2.12.1 [INFO] [stderr] Compiling cexpr v0.6.0 [INFO] [stderr] Compiling toml_edit v0.25.4+spec-1.1.0 [INFO] [stderr] Checking miniz_oxide v0.8.9 [INFO] [stderr] Checking convert_case v0.6.0 [INFO] [stderr] Checking sharded-slab v0.1.7 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling darling_core v0.21.3 [INFO] [stderr] Compiling pest_generator v2.8.6 [INFO] [stderr] Compiling proc-macro-crate v3.5.0 [INFO] [stderr] Checking crossbeam-deque v0.8.6 [INFO] [stderr] Checking http-body-util v0.1.3 [INFO] [stderr] Compiling regex v1.12.3 [INFO] [stderr] Checking matchers v0.2.0 [INFO] [stderr] Checking tracing-log v0.2.0 [INFO] [stderr] Checking thread_local v1.1.9 [INFO] [stderr] Checking unsafe-libyaml v0.2.11 [INFO] [stderr] Checking clap_lex v1.0.0 [INFO] [stderr] Checking nu-ansi-term v0.50.3 [INFO] [stderr] Checking hex v0.4.3 [INFO] [stderr] Checking ciborium-io v0.2.2 [INFO] [stderr] Checking anstyle v1.0.13 [INFO] [stderr] Checking plotters-backend v0.3.7 [INFO] [stderr] Checking pathdiff v0.2.3 [INFO] [stderr] Checking openssl-probe v0.2.1 [INFO] [stderr] Checking home v0.5.12 [INFO] [stderr] Checking xattr v1.6.1 [INFO] [stderr] Checking flate2 v1.1.9 [INFO] [stderr] Checking clap_builder v4.5.60 [INFO] [stderr] Compiling bindgen v0.72.1 [INFO] [stderr] Checking rustls-native-certs v0.8.3 [INFO] [stderr] Checking itertools v0.10.5 [INFO] [stderr] Checking rustls-pemfile v2.2.0 [INFO] [stderr] Checking plotters-svg v0.3.7 [INFO] [stderr] Checking filetime v0.2.27 [INFO] [stderr] Checking cast v0.3.0 [INFO] [stderr] Checking same-file v1.0.6 [INFO] [stderr] Checking base64 v0.22.1 [INFO] [stderr] Checking rayon v1.11.0 [INFO] [stderr] Checking etcetera v0.8.0 [INFO] [stderr] Checking walkdir v2.5.0 [INFO] [stderr] Checking is-terminal v0.4.17 [INFO] [stderr] Checking oorandom v11.1.5 [INFO] [stderr] Checking anes v0.1.6 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.1 [INFO] [stderr] Compiling zerocopy-derive v0.8.42 [INFO] [stderr] Compiling tokio-macros v2.6.1 [INFO] [stderr] Compiling zerovec-derive v0.11.2 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling futures-macro v0.3.32 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling num_enum_derive v0.7.5 [INFO] [stderr] Checking tokio v1.50.0 [INFO] [stderr] Compiling structmeta-derive v0.3.0 [INFO] [stderr] Compiling async-trait v0.1.89 [INFO] [stderr] Compiling darling_macro v0.21.3 [INFO] [stderr] Checking futures-util v0.3.32 [INFO] [stderr] Compiling darling v0.21.3 [INFO] [stderr] Checking num_enum v0.7.5 [INFO] [stderr] Compiling pest_derive v2.8.6 [INFO] [stderr] Compiling serde_with_macros v3.17.0 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling serde_repr v0.1.20 [INFO] [stderr] Compiling structmeta v0.3.0 [INFO] [stderr] Compiling thiserror-impl v2.0.18 [INFO] [stderr] Checking zerofrom v0.1.6 [INFO] [stderr] Checking yoke v0.8.1 [INFO] [stderr] Checking clap v4.5.60 [INFO] [stderr] Compiling parse-display-derive v0.9.1 [INFO] [stderr] Checking criterion-plot v0.5.0 [INFO] [stderr] Checking plotters v0.3.7 [INFO] [stderr] Checking zerovec v0.11.5 [INFO] [stderr] Checking zerotrie v0.2.3 [INFO] [stderr] Checking tracing v0.1.44 [INFO] [stderr] Checking rustls-webpki v0.103.9 [INFO] [stderr] Checking tracing-subscriber v0.3.22 [INFO] [stderr] Checking tinystr v0.8.2 [INFO] [stderr] Checking potential_utf v0.1.4 [INFO] [stderr] Checking zerocopy v0.8.42 [INFO] [stderr] Checking icu_locale_core v2.1.1 [INFO] [stderr] Checking icu_collections v2.1.1 [INFO] [stderr] Checking thiserror v2.0.18 [INFO] [stderr] Checking serde_with v3.17.0 [INFO] [stderr] Checking icu_provider v2.1.1 [INFO] [stderr] Checking parse-display v0.9.1 [INFO] [stderr] Checking icu_normalizer v2.1.1 [INFO] [stderr] Checking icu_properties v2.1.2 [INFO] [stderr] Checking serde_spanned v0.6.9 [INFO] [stderr] Checking toml_datetime v0.6.11 [INFO] [stderr] Checking ron v0.8.1 [INFO] [stderr] Checking json5 v0.4.1 [INFO] [stderr] Checking serde_urlencoded v0.7.1 [INFO] [stderr] Checking serde_yaml v0.9.34+deprecated [INFO] [stderr] Checking docker_credential v1.3.2 [INFO] [stderr] Checking tinytemplate v1.2.1 [INFO] [stderr] Checking toml_edit v0.22.27 [INFO] [stderr] Compiling zstd-sys v2.0.16+zstd.1.5.7 [INFO] [stderr] Checking idna_adapter v1.2.1 [INFO] [stderr] Checking idna v1.1.0 [INFO] [stderr] Checking bollard-stubs v1.47.1-rc.27.3.1 [INFO] [stderr] Checking url v2.5.8 [INFO] [stderr] Checking futures-executor v0.3.32 [INFO] [stderr] Checking futures v0.3.32 [INFO] [stderr] Checking toml v0.8.23 [INFO] [stderr] Checking half v2.7.1 [INFO] [stderr] Checking hyper v1.8.1 [INFO] [stderr] Checking tokio-rustls v0.26.4 [INFO] [stderr] Checking tokio-util v0.7.18 [INFO] [stderr] Checking tokio-stream v0.1.18 [INFO] [stderr] Checking hashbrown v0.14.5 [INFO] [stderr] Checking ciborium-ll v0.2.2 [INFO] [stderr] Checking ciborium v0.2.2 [INFO] [stderr] Checking tokio-tar v0.3.1 [INFO] [stderr] Checking hyper-util v0.1.20 [INFO] [stderr] Checking ordered-multimap v0.7.3 [INFO] [stderr] Checking hashlink v0.8.4 [INFO] [stderr] Checking rust-ini v0.20.0 [INFO] [stderr] Checking yaml-rust2 v0.8.1 [INFO] [stderr] Checking criterion v0.5.1 [INFO] [stderr] Checking config v0.14.1 [INFO] [stderr] Checking hyper-rustls v0.27.7 [INFO] [stderr] Checking hyperlocal v0.9.1 [INFO] [stderr] Checking zstd v0.13.3 [INFO] [stderr] Checking bollard v0.18.1 [INFO] [stderr] Checking testcontainers v0.23.3 [INFO] [stderr] Checking rdkafka v0.36.2 [INFO] [stderr] Checking streamforge v0.3.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `bytes::Bytes` [INFO] [stdout] --> src/compression.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use bytes::Bytes; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::json` [INFO] [stdout] --> src/kafka/sink.rs:210:9 [INFO] [stdout] | [INFO] [stdout] 210 | use serde_json::json; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `bytes::Bytes` [INFO] [stdout] --> src/compression.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use bytes::Bytes; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `routing_path` is never read [INFO] [stdout] --> src/processor.rs:75:5 [INFO] [stdout] | [INFO] [stdout] 73 | pub struct MultiDestinationProcessor { [INFO] [stdout] | ------------------------- field in this struct [INFO] [stdout] 74 | destinations: Vec, [INFO] [stdout] 75 | routing_path: Option, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `extract_routing_value` is never used [INFO] [stdout] --> src/processor.rs:90:8 [INFO] [stdout] | [INFO] [stdout] 78 | impl MultiDestinationProcessor { [INFO] [stdout] | ------------------------------ method in this implementation [INFO] [stdout] ... [INFO] [stdout] 90 | fn extract_routing_value(&self, value: &Value) -> Option { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: using `Option.and_then(|x| Some(y))`, which is more succinctly expressed as `map(|x| y)` [INFO] [stdout] --> src/kafka/sink.rs:87:30 [INFO] [stdout] | [INFO] [stdout] 87 | let num_partitions = metadata [INFO] [stdout] | ______________________________^ [INFO] [stdout] 88 | | .topics() [INFO] [stdout] 89 | | .iter() [INFO] [stdout] 90 | | .find(|t| t.name() == target_topic) [INFO] [stdout] 91 | | .and_then(|t| Some(t.partitions().len() as i32)) [INFO] [stdout] | |____________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#bind_instead_of_map [INFO] [stdout] = note: `#[warn(clippy::bind_instead_of_map)]` on by default [INFO] [stdout] help: try [INFO] [stdout] | [INFO] [stdout] 87 ~ let num_partitions = metadata [INFO] [stdout] 88 + .topics() [INFO] [stdout] 89 + .iter() [INFO] [stdout] 90 + .find(|t| t.name() == target_topic).map(|t| t.partitions().len() as i32) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/kafka/sink.rs:241:13 [INFO] [stdout] | [INFO] [stdout] 241 | let mut multi = MultiSink::new(); [INFO] [stdout] | ----^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: you should consider adding a `Default` implementation for `MultiSink` [INFO] [stdout] --> src/kafka/sink.rs:177:5 [INFO] [stdout] | [INFO] [stdout] 177 | / pub fn new() -> Self { [INFO] [stdout] 178 | | Self { [INFO] [stdout] 179 | | sinks: HashMap::new(), [INFO] [stdout] 180 | | } [INFO] [stdout] 181 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default [INFO] [stdout] = note: `#[warn(clippy::new_without_default)]` on by default [INFO] [stdout] help: try adding this [INFO] [stdout] | [INFO] [stdout] 176 + impl Default for MultiSink { [INFO] [stdout] 177 + fn default() -> Self { [INFO] [stdout] 178 + Self::new() [INFO] [stdout] 179 + } [INFO] [stdout] 180 + } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:107:17 [INFO] [stdout] | [INFO] [stdout] 107 | actual.as_f64().map_or(false, |v| v > *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] = note: `#[warn(clippy::unnecessary_map_or)]` on by default [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 107 - actual.as_f64().map_or(false, |v| v > *expected) [INFO] [stdout] 107 + actual.as_f64().is_some_and(|v| v > *expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:110:17 [INFO] [stdout] | [INFO] [stdout] 110 | actual.as_f64().map_or(false, |v| v >= *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 110 - actual.as_f64().map_or(false, |v| v >= *expected) [INFO] [stdout] 110 + actual.as_f64().is_some_and(|v| v >= *expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:113:17 [INFO] [stdout] | [INFO] [stdout] 113 | actual.as_f64().map_or(false, |v| v < *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 113 - actual.as_f64().map_or(false, |v| v < *expected) [INFO] [stdout] 113 + actual.as_f64().is_some_and(|v| v < *expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:116:17 [INFO] [stdout] | [INFO] [stdout] 116 | actual.as_f64().map_or(false, |v| v <= *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 116 - actual.as_f64().map_or(false, |v| v <= *expected) [INFO] [stdout] 116 + actual.as_f64().is_some_and(|v| v <= *expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:119:17 [INFO] [stdout] | [INFO] [stdout] 119 | actual.as_f64().map_or(false, |v| (v - *expected).abs() < f64::EPSILON) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 119 - actual.as_f64().map_or(false, |v| (v - *expected).abs() < f64::EPSILON) [INFO] [stdout] 119 + actual.as_f64().is_some_and(|v| (v - *expected).abs() < f64::EPSILON) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:122:17 [INFO] [stdout] | [INFO] [stdout] 122 | actual.as_f64().map_or(true, |v| (v - *expected).abs() >= f64::EPSILON) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_none_or` instead [INFO] [stdout] | [INFO] [stdout] 122 - actual.as_f64().map_or(true, |v| (v - *expected).abs() >= f64::EPSILON) [INFO] [stdout] 122 + actual.as_f64().is_none_or(|v| (v - *expected).abs() >= f64::EPSILON) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:125:17 [INFO] [stdout] | [INFO] [stdout] 125 | actual.as_str().map_or(false, |v| v == expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 125 - actual.as_str().map_or(false, |v| v == expected) [INFO] [stdout] 125 + actual.as_str().is_some_and(|v| v == expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:128:17 [INFO] [stdout] | [INFO] [stdout] 128 | actual.as_str().map_or(true, |v| v != expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_none_or` instead [INFO] [stdout] | [INFO] [stdout] 128 - actual.as_str().map_or(true, |v| v != expected) [INFO] [stdout] 128 + actual.as_str().is_none_or(|v| v != expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:131:17 [INFO] [stdout] | [INFO] [stdout] 131 | actual.as_bool().map_or(false, |v| v == *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use a standard comparison instead [INFO] [stdout] | [INFO] [stdout] 131 - actual.as_bool().map_or(false, |v| v == *expected) [INFO] [stdout] 131 + actual.as_bool() == Some(*expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:134:17 [INFO] [stdout] | [INFO] [stdout] 134 | actual.as_bool().map_or(true, |v| v != *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use a standard comparison instead [INFO] [stdout] | [INFO] [stdout] 134 - actual.as_bool().map_or(true, |v| v != *expected) [INFO] [stdout] 134 + actual.as_bool() != Some(*expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: stripping a prefix manually [INFO] [stdout] --> src/filter_parser.rs:162:35 [INFO] [stdout] | [INFO] [stdout] 162 | parse_construct_transform(&expr[10..]) [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the prefix was tested here [INFO] [stdout] --> src/filter_parser.rs:161:5 [INFO] [stdout] | [INFO] [stdout] 161 | if expr.starts_with("CONSTRUCT:") { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_strip [INFO] [stdout] = note: `#[warn(clippy::manual_strip)]` on by default [INFO] [stdout] help: try using the `strip_prefix` method [INFO] [stdout] | [INFO] [stdout] 161 ~ if let Some() = expr.strip_prefix("CONSTRUCT:") { [INFO] [stdout] 162 ~ parse_construct_transform() [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: stripping a prefix manually [INFO] [stdout] --> src/filter_parser.rs:164:35 [INFO] [stdout] | [INFO] [stdout] 164 | parse_array_map_transform(&expr[10..]) [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the prefix was tested here [INFO] [stdout] --> src/filter_parser.rs:163:12 [INFO] [stdout] | [INFO] [stdout] 163 | } else if expr.starts_with("ARRAY_MAP:") { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_strip [INFO] [stdout] help: try using the `strip_prefix` method [INFO] [stdout] | [INFO] [stdout] 163 ~ } else if let Some() = expr.strip_prefix("ARRAY_MAP:") { [INFO] [stdout] 164 ~ parse_array_map_transform() [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: stripping a prefix manually [INFO] [stdout] --> src/filter_parser.rs:166:36 [INFO] [stdout] | [INFO] [stdout] 166 | parse_arithmetic_transform(&expr[11..]) [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the prefix was tested here [INFO] [stdout] --> src/filter_parser.rs:165:12 [INFO] [stdout] | [INFO] [stdout] 165 | } else if expr.starts_with("ARITHMETIC:") { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_strip [INFO] [stdout] help: try using the `strip_prefix` method [INFO] [stdout] | [INFO] [stdout] 165 ~ } else if let Some() = expr.strip_prefix("ARITHMETIC:") { [INFO] [stdout] 166 ~ parse_arithmetic_transform() [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/kafka/sink.rs:166:9 [INFO] [stdout] | [INFO] [stdout] 166 | self.producer.flush(Timeout::After(Duration::from_secs(30))); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 166 | let _ = self.producer.flush(Timeout::After(Duration::from_secs(30))); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this import is redundant [INFO] [stdout] --> src/main.rs:9:1 [INFO] [stdout] | [INFO] [stdout] 9 | use tracing_subscriber; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ help: remove it entirely [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_component_path_imports [INFO] [stdout] = note: `#[warn(clippy::single_component_path_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: using `Option.and_then(|x| Some(y))`, which is more succinctly expressed as `map(|x| y)` [INFO] [stdout] --> src/kafka/sink.rs:87:30 [INFO] [stdout] | [INFO] [stdout] 87 | let num_partitions = metadata [INFO] [stdout] | ______________________________^ [INFO] [stdout] 88 | | .topics() [INFO] [stdout] 89 | | .iter() [INFO] [stdout] 90 | | .find(|t| t.name() == target_topic) [INFO] [stdout] 91 | | .and_then(|t| Some(t.partitions().len() as i32)) [INFO] [stdout] | |____________________________________________________________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#bind_instead_of_map [INFO] [stdout] = note: `#[warn(clippy::bind_instead_of_map)]` on by default [INFO] [stdout] help: try [INFO] [stdout] | [INFO] [stdout] 87 ~ let num_partitions = metadata [INFO] [stdout] 88 + .topics() [INFO] [stdout] 89 + .iter() [INFO] [stdout] 90 + .find(|t| t.name() == target_topic).map(|t| t.partitions().len() as i32) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: you should consider adding a `Default` implementation for `MultiSink` [INFO] [stdout] --> src/kafka/sink.rs:177:5 [INFO] [stdout] | [INFO] [stdout] 177 | / pub fn new() -> Self { [INFO] [stdout] 178 | | Self { [INFO] [stdout] 179 | | sinks: HashMap::new(), [INFO] [stdout] 180 | | } [INFO] [stdout] 181 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default [INFO] [stdout] = note: `#[warn(clippy::new_without_default)]` on by default [INFO] [stdout] help: try adding this [INFO] [stdout] | [INFO] [stdout] 176 + impl Default for MultiSink { [INFO] [stdout] 177 + fn default() -> Self { [INFO] [stdout] 178 + Self::new() [INFO] [stdout] 179 + } [INFO] [stdout] 180 + } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this import is redundant [INFO] [stdout] --> src/main.rs:9:1 [INFO] [stdout] | [INFO] [stdout] 9 | use tracing_subscriber; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ help: remove it entirely [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_component_path_imports [INFO] [stdout] = note: `#[warn(clippy::single_component_path_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: manual `Range::contains` implementation [INFO] [stdout] --> src/partitioner.rs:89:17 [INFO] [stdout] | [INFO] [stdout] 89 | assert!(partition >= 0 && partition < 10); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use: `(0..10).contains(&partition)` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_range_contains [INFO] [stdout] = note: `#[warn(clippy::manual_range_contains)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:107:17 [INFO] [stdout] | [INFO] [stdout] 107 | actual.as_f64().map_or(false, |v| v > *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] = note: `#[warn(clippy::unnecessary_map_or)]` on by default [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 107 - actual.as_f64().map_or(false, |v| v > *expected) [INFO] [stdout] 107 + actual.as_f64().is_some_and(|v| v > *expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:110:17 [INFO] [stdout] | [INFO] [stdout] 110 | actual.as_f64().map_or(false, |v| v >= *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 110 - actual.as_f64().map_or(false, |v| v >= *expected) [INFO] [stdout] 110 + actual.as_f64().is_some_and(|v| v >= *expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:113:17 [INFO] [stdout] | [INFO] [stdout] 113 | actual.as_f64().map_or(false, |v| v < *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 113 - actual.as_f64().map_or(false, |v| v < *expected) [INFO] [stdout] 113 + actual.as_f64().is_some_and(|v| v < *expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:116:17 [INFO] [stdout] | [INFO] [stdout] 116 | actual.as_f64().map_or(false, |v| v <= *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 116 - actual.as_f64().map_or(false, |v| v <= *expected) [INFO] [stdout] 116 + actual.as_f64().is_some_and(|v| v <= *expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:119:17 [INFO] [stdout] | [INFO] [stdout] 119 | actual.as_f64().map_or(false, |v| (v - *expected).abs() < f64::EPSILON) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 119 - actual.as_f64().map_or(false, |v| (v - *expected).abs() < f64::EPSILON) [INFO] [stdout] 119 + actual.as_f64().is_some_and(|v| (v - *expected).abs() < f64::EPSILON) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:122:17 [INFO] [stdout] | [INFO] [stdout] 122 | actual.as_f64().map_or(true, |v| (v - *expected).abs() >= f64::EPSILON) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_none_or` instead [INFO] [stdout] | [INFO] [stdout] 122 - actual.as_f64().map_or(true, |v| (v - *expected).abs() >= f64::EPSILON) [INFO] [stdout] 122 + actual.as_f64().is_none_or(|v| (v - *expected).abs() >= f64::EPSILON) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:125:17 [INFO] [stdout] | [INFO] [stdout] 125 | actual.as_str().map_or(false, |v| v == expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_some_and` instead [INFO] [stdout] | [INFO] [stdout] 125 - actual.as_str().map_or(false, |v| v == expected) [INFO] [stdout] 125 + actual.as_str().is_some_and(|v| v == expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:128:17 [INFO] [stdout] | [INFO] [stdout] 128 | actual.as_str().map_or(true, |v| v != expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use `is_none_or` instead [INFO] [stdout] | [INFO] [stdout] 128 - actual.as_str().map_or(true, |v| v != expected) [INFO] [stdout] 128 + actual.as_str().is_none_or(|v| v != expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:131:17 [INFO] [stdout] | [INFO] [stdout] 131 | actual.as_bool().map_or(false, |v| v == *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use a standard comparison instead [INFO] [stdout] | [INFO] [stdout] 131 - actual.as_bool().map_or(false, |v| v == *expected) [INFO] [stdout] 131 + actual.as_bool() == Some(*expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `map_or` can be simplified [INFO] [stdout] --> src/filter.rs:134:17 [INFO] [stdout] | [INFO] [stdout] 134 | actual.as_bool().map_or(true, |v| v != *expected) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_map_or [INFO] [stdout] help: use a standard comparison instead [INFO] [stdout] | [INFO] [stdout] 134 - actual.as_bool().map_or(true, |v| v != *expected) [INFO] [stdout] 134 + actual.as_bool() != Some(*expected) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: stripping a prefix manually [INFO] [stdout] --> src/filter_parser.rs:162:35 [INFO] [stdout] | [INFO] [stdout] 162 | parse_construct_transform(&expr[10..]) [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the prefix was tested here [INFO] [stdout] --> src/filter_parser.rs:161:5 [INFO] [stdout] | [INFO] [stdout] 161 | if expr.starts_with("CONSTRUCT:") { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_strip [INFO] [stdout] = note: `#[warn(clippy::manual_strip)]` on by default [INFO] [stdout] help: try using the `strip_prefix` method [INFO] [stdout] | [INFO] [stdout] 161 ~ if let Some() = expr.strip_prefix("CONSTRUCT:") { [INFO] [stdout] 162 ~ parse_construct_transform() [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: stripping a prefix manually [INFO] [stdout] --> src/filter_parser.rs:164:35 [INFO] [stdout] | [INFO] [stdout] 164 | parse_array_map_transform(&expr[10..]) [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the prefix was tested here [INFO] [stdout] --> src/filter_parser.rs:163:12 [INFO] [stdout] | [INFO] [stdout] 163 | } else if expr.starts_with("ARRAY_MAP:") { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_strip [INFO] [stdout] help: try using the `strip_prefix` method [INFO] [stdout] | [INFO] [stdout] 163 ~ } else if let Some() = expr.strip_prefix("ARRAY_MAP:") { [INFO] [stdout] 164 ~ parse_array_map_transform() [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: stripping a prefix manually [INFO] [stdout] --> src/filter_parser.rs:166:36 [INFO] [stdout] | [INFO] [stdout] 166 | parse_arithmetic_transform(&expr[11..]) [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: the prefix was tested here [INFO] [stdout] --> src/filter_parser.rs:165:12 [INFO] [stdout] | [INFO] [stdout] 165 | } else if expr.starts_with("ARITHMETIC:") { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_strip [INFO] [stdout] help: try using the `strip_prefix` method [INFO] [stdout] | [INFO] [stdout] 165 ~ } else if let Some() = expr.strip_prefix("ARITHMETIC:") { [INFO] [stdout] 166 ~ parse_arithmetic_transform() [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused `std::result::Result` that must be used [INFO] [stdout] --> src/kafka/sink.rs:166:9 [INFO] [stdout] | [INFO] [stdout] 166 | self.producer.flush(Timeout::After(Duration::from_secs(30))); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stdout] = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] help: use `let _ = ...` to ignore the resulting value [INFO] [stdout] | [INFO] [stdout] 166 | let _ = self.producer.flush(Timeout::After(Duration::from_secs(30))); [INFO] [stdout] | +++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 27s [INFO] running `Command { std: "docker" "inspect" "dc4747961f496bb7ac524518615753cf37b2a8eee04fef3de70df0aa142d1c63", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "dc4747961f496bb7ac524518615753cf37b2a8eee04fef3de70df0aa142d1c63", kill_on_drop: false }` [INFO] [stdout] dc4747961f496bb7ac524518615753cf37b2a8eee04fef3de70df0aa142d1c63