From 8ad5cc866bb9d6b49470790e3b0dd40690f63a09 Mon Sep 17 00:00:00 2001 From: tyranron Date: Fri, 1 Jul 2022 16:05:28 +0200 Subject: [PATCH] Upgrade to 1.62 Rust and bump up MSRV - refactor to use `bool::then_some()` - tune up lints --- .github/workflows/ci.yml | 2 +- CHANGELOG.md | 2 +- Cargo.toml | 2 +- README.md | 2 +- book/src/writing/asserting.md | 2 +- codegen/CHANGELOG.md | 2 +- codegen/Cargo.toml | 2 +- codegen/README.md | 2 +- codegen/src/attribute.rs | 13 ++++++------- codegen/src/lib.rs | 3 +++ src/cucumber.rs | 6 +++--- src/lib.rs | 3 +++ src/runner/basic.rs | 2 +- src/step.rs | 2 ++ src/writer/basic.rs | 2 +- src/writer/mod.rs | 3 ++- src/writer/summarize.rs | 2 +- 17 files changed, 30 insertions(+), 22 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 2ede1886..4822b9d4 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -109,7 +109,7 @@ jobs: strategy: fail-fast: false matrix: - msrv: ["1.61.0"] + msrv: ["1.62.0"] crate: - cucumber-codegen - cucumber diff --git a/CHANGELOG.md b/CHANGELOG.md index 9afc3ed5..267a1e56 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -13,7 +13,7 @@ All user visible changes to `cucumber` crate will be documented in this file. Th ### BC Breaks -- Bump up [MSRV] to 1.61 for more clever support of [Cargo feature]s and simplified codegen. ([fbd08ec2], [cf055ac0]) +- Bump up [MSRV] to 1.62 for more clever support of [Cargo feature]s and simplified codegen. ([fbd08ec2], [cf055ac0], [todo]) ### Changed diff --git a/Cargo.toml b/Cargo.toml index 051e63c4..87b5b0db 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -2,7 +2,7 @@ name = "cucumber" version = "0.14.0-dev" edition = "2021" -rust-version = "1.61" +rust-version = "1.62" description = """\ Cucumber testing framework for Rust, with async support. \ Fully native, no external test runners or dependencies.\ diff --git a/README.md b/README.md index b06dea3c..590c754b 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,7 @@ Cucumber testing framework for Rust [![Crates.io](https://img.shields.io/crates/v/cucumber.svg?maxAge=2592000)](https://crates.io/crates/cucumber) [![Documentation](https://docs.rs/cucumber/badge.svg)](https://docs.rs/cucumber) [![CI](https://github.com/cucumber-rs/cucumber/workflows/CI/badge.svg?branch=main "CI")](https://github.com/cucumber-rs/cucumber/actions?query=workflow%3ACI+branch%3Amain) -[![Rust 1.61+](https://img.shields.io/badge/rustc-1.61+-lightgray.svg "Rust 1.61+")](https://blog.rust-lang.org/2022/05/19/Rust-1.61.0.html) +[![Rust 1.62+](https://img.shields.io/badge/rustc-1.62+-lightgray.svg "Rust 1.62+")](https://blog.rust-lang.org/2022/06/30/Rust-1.62.0.html) [![Unsafe Forbidden](https://img.shields.io/badge/unsafe-forbidden-success.svg)](https://github.com/rust-secure-code/safety-dance) An implementation of the [Cucumber] testing framework for Rust. Fully native, no external test runners or dependencies. diff --git a/book/src/writing/asserting.md b/book/src/writing/asserting.md index d6da98ef..d198c739 100644 --- a/book/src/writing/asserting.md +++ b/book/src/writing/asserting.md @@ -125,7 +125,7 @@ fn feed_cat(_: &mut AnimalWorld) {} #[then("the cat is not hungry")] fn cat_is_fed(world: &mut AnimalWorld) -> Result<(), &'static str> { - (!world.cat.hungry).then(|| ()).ok_or("Cat is still hungry!") + (!world.cat.hungry).then_some(()).ok_or("Cat is still hungry!") } # # #[tokio::main] diff --git a/codegen/CHANGELOG.md b/codegen/CHANGELOG.md index 1dc5ee28..19a90104 100644 --- a/codegen/CHANGELOG.md +++ b/codegen/CHANGELOG.md @@ -13,7 +13,7 @@ All user visible changes to `cucumber-codegen` crate will be documented in this ### BC Breaks -- Bump up [MSRV] to 1.61 for more clever support of [Cargo feature]s and simplified codegen. ([fbd08ec2], [cf055ac0]) +- Bump up [MSRV] to 1.62 for more clever support of [Cargo feature]s and simplified codegen. ([fbd08ec2], [cf055ac0], [todo]) [cf055ac0]: /../../commit/cf055ac06c7b72f572882ce15d6a60da92ad60a0 [fbd08ec2]: /../../commit/fbd08ec24dbd036c89f5f0af4d936b616790a166 diff --git a/codegen/Cargo.toml b/codegen/Cargo.toml index 68123a04..49505792 100644 --- a/codegen/Cargo.toml +++ b/codegen/Cargo.toml @@ -2,7 +2,7 @@ name = "cucumber-codegen" version = "0.14.0-dev" # should be the same as main crate version edition = "2021" -rust-version = "1.61" +rust-version = "1.62" description = "Code generation for `cucumber` crate." license = "MIT OR Apache-2.0" authors = [ diff --git a/codegen/README.md b/codegen/README.md index 5780e375..bb289ca8 100644 --- a/codegen/README.md +++ b/codegen/README.md @@ -4,7 +4,7 @@ [![Crates.io](https://img.shields.io/crates/v/cucumber-codegen.svg?maxAge=2592000)](https://crates.io/crates/cucumber-codegen) [![Documentation](https://docs.rs/cucumber-codegen/badge.svg)](https://docs.rs/cucumber-codegen) [![CI](https://github.com/cucumber-rs/cucumber/workflows/CI/badge.svg?branch=main "CI")](https://github.com/cucumber-rs/cucumber/actions?query=workflow%3ACI+branch%3Amain) -[![Rust 1.61+](https://img.shields.io/badge/rustc-1.61+-lightgray.svg "Rust 1.61+")](https://blog.rust-lang.org/2022/05/19/Rust-1.61.0.html) +[![Rust 1.62+](https://img.shields.io/badge/rustc-1.62+-lightgray.svg "Rust 1.62+")](https://blog.rust-lang.org/2022/06/30/Rust-1.62.0.html) [![Unsafe Forbidden](https://img.shields.io/badge/unsafe-forbidden-success.svg)](https://github.com/rust-secure-code/safety-dance) - [Changelog](https://github.com/cucumber-rs/cucumber/blob/main/codegen/CHANGELOG.md) diff --git a/codegen/src/attribute.rs b/codegen/src/attribute.rs index 194304ec..ade7de97 100644 --- a/codegen/src/attribute.rs +++ b/codegen/src/attribute.rs @@ -228,7 +228,7 @@ impl Step { .map(|(_, (_, s))| s.as_str()), ) .fold(None, |acc, s| { - acc.or_else(|| (!s.is_empty()).then(|| s)) + acc.or_else(|| (!s.is_empty()).then_some(s)) }) .unwrap_or_default(); @@ -367,10 +367,9 @@ impl Step { .take(to_take) .map(|(_, s)| s.as_str()), ) - .fold( - None, - |acc, s| acc.or_else(|| (!s.is_empty()).then(|| s)), - ) + .fold(None, |acc, s| { + acc.or_else(|| (!s.is_empty()).then_some(s)) + }) .unwrap_or_default() }; let #ident = #ident.parse::<#ty>().expect(#parsing_err); @@ -523,7 +522,7 @@ impl<'p> Parameters<'p> { Err(err) => return Some(Err(err)), }; let is_step = step.map(|s| s == ident).unwrap_or_default(); - (!is_step).then(|| Ok(ty)) + (!is_step).then_some(Ok(ty)) }) .collect::>>()?; @@ -666,7 +665,7 @@ impl<'p> Parameters<'p> { .iter() .filter_map(|par| { let name = par.param.input.fragment(); - (!DEFAULT_PARAMETERS.contains(name)).then(|| (*name, &par.ty)) + (!DEFAULT_PARAMETERS.contains(name)).then_some((*name, &par.ty)) }) .unzip(); diff --git a/codegen/src/lib.rs b/codegen/src/lib.rs index 87e63928..0dcb23ef 100644 --- a/codegen/src/lib.rs +++ b/codegen/src/lib.rs @@ -32,7 +32,9 @@ clippy::decimal_literal_representation, clippy::default_union_representation, clippy::else_if_without_else, + clippy::empty_drop, clippy::empty_line_after_outer_attr, + clippy::empty_structs_with_brackets, clippy::equatable_if_let, clippy::exit, clippy::expect_used, @@ -45,6 +47,7 @@ clippy::imprecise_flops, clippy::index_refutable_slice, clippy::iter_with_drain, + clippy::large_include_file, clippy::let_underscore_must_use, clippy::lossy_float_literal, clippy::map_err_ignore, diff --git a/src/cucumber.rs b/src/cucumber.rs index 2ba3edb4..807f0b08 100644 --- a/src/cucumber.rs +++ b/src/cucumber.rs @@ -1278,7 +1278,7 @@ where if failed_steps > 0 { msg.push(format!( "{failed_steps} step{} failed", - (failed_steps > 1).then(|| "s").unwrap_or_default(), + (failed_steps > 1).then_some("s").unwrap_or_default(), )); } @@ -1286,7 +1286,7 @@ where if parsing_errors > 0 { msg.push(format!( "{parsing_errors} parsing error{}", - (parsing_errors > 1).then(|| "s").unwrap_or_default(), + (parsing_errors > 1).then_some("s").unwrap_or_default(), )); } @@ -1294,7 +1294,7 @@ where if hook_errors > 0 { msg.push(format!( "{hook_errors} hook error{}", - (hook_errors > 1).then(|| "s").unwrap_or_default(), + (hook_errors > 1).then_some("s").unwrap_or_default(), )); } diff --git a/src/lib.rs b/src/lib.rs index 8139f3fe..9e9d48e5 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -33,7 +33,9 @@ clippy::decimal_literal_representation, clippy::default_union_representation, clippy::else_if_without_else, + clippy::empty_drop, clippy::empty_line_after_outer_attr, + clippy::empty_structs_with_brackets, clippy::equatable_if_let, clippy::exit, clippy::expect_used, @@ -47,6 +49,7 @@ clippy::imprecise_flops, clippy::index_refutable_slice, clippy::iter_with_drain, + clippy::large_include_file, clippy::let_underscore_must_use, clippy::lossy_float_literal, clippy::map_err_ignore, diff --git a/src/runner/basic.rs b/src/runner/basic.rs index 01cd71a2..3e73a207 100644 --- a/src/runner/basic.rs +++ b/src/runner/basic.rs @@ -194,7 +194,7 @@ impl Default for Basic { .tags .iter() .any(|tag| tag == "serial") - .then(|| ScenarioType::Serial) + .then_some(ScenarioType::Serial) .unwrap_or(ScenarioType::Concurrent) }; diff --git a/src/step.rs b/src/step.rs index 09ca06e0..91d99cd0 100644 --- a/src/step.rs +++ b/src/step.rs @@ -86,6 +86,8 @@ impl fmt::Debug for Collection { } } +// Implemented manually to omit redundant `World: Default` trait bound, imposed +// by `#[derive(Default)]`. impl Default for Collection { fn default() -> Self { Self { diff --git a/src/writer/basic.rs b/src/writer/basic.rs index eccb3ab0..602c83e7 100644 --- a/src/writer/basic.rs +++ b/src/writer/basic.rs @@ -909,7 +909,7 @@ fn format_table(table: &gherkin::Table, indent: usize) -> String { .rows .iter() .fold(None, |mut acc: Option>, row| { - // false positive due to mut borrowing + // false positive: due to mut borrowing #[allow(clippy::option_if_let_else)] if let Some(existing_len) = acc.as_mut() { for (cell, max_len) in row.iter().zip(existing_len) { diff --git a/src/writer/mod.rs b/src/writer/mod.rs index a1c67952..664ec3ec 100644 --- a/src/writer/mod.rs +++ b/src/writer/mod.rs @@ -420,10 +420,11 @@ impl Ext for T { pub trait NonTransforming {} /// Standard verbosity levels of a [`Writer`]. -#[derive(Clone, Copy, Debug)] +#[derive(Clone, Copy, Debug, Default)] #[repr(u8)] pub enum Verbosity { /// None additional info. + #[default] Default = 0, /// Outputs the whole [`World`] on [`Failed`] [`Step`]s whenever is diff --git a/src/writer/summarize.rs b/src/writer/summarize.rs index bbe5cfab..439c958a 100644 --- a/src/writer/summarize.rs +++ b/src/writer/summarize.rs @@ -539,7 +539,7 @@ impl Styles { self.bold(format!( "{num} {}{}", singular.into(), - (num != 1).then(|| "s").unwrap_or_default(), + (num != 1).then_some("s").unwrap_or_default(), )) } }