From 0c80602333a1fb462034fae1562b8d4e71fbe717 Mon Sep 17 00:00:00 2001 From: Peter Glotfelty Date: Sat, 20 Nov 2021 11:30:11 -0800 Subject: [PATCH] Add tests for nostd environment (#196) Co-authored-by: Peter Glotfelty --- Cargo.toml | 6 +++--- strum_nostd_tests/Cargo.toml | 13 ++++++++++++ strum_nostd_tests/src/lib.rs | 37 +++++++++++++++++++++++++++++++++++ strum_tests/tests/from_str.rs | 2 +- 4 files changed, 54 insertions(+), 4 deletions(-) create mode 100644 strum_nostd_tests/Cargo.toml create mode 100644 strum_nostd_tests/src/lib.rs diff --git a/Cargo.toml b/Cargo.toml index 619d955b..094b6e69 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -2,7 +2,7 @@ members = [ "strum", "strum_macros", - "strum_tests" + "strum_tests", + "strum_nostd_tests" ] - -exclude = [ "strum_tests_rename" ] \ No newline at end of file + \ No newline at end of file diff --git a/strum_nostd_tests/Cargo.toml b/strum_nostd_tests/Cargo.toml new file mode 100644 index 00000000..9e44e16e --- /dev/null +++ b/strum_nostd_tests/Cargo.toml @@ -0,0 +1,13 @@ +[package] +name = "strum_nostd_tests" +version = "0.23.1" +edition = "2018" + +# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html + +[dependencies] +strum = { path = "../strum", features = ["derive"] } +strum_macros = { path = "../strum_macros", features = [] } + +[dev-dependencies] +rustversion = "1.0" \ No newline at end of file diff --git a/strum_nostd_tests/src/lib.rs b/strum_nostd_tests/src/lib.rs new file mode 100644 index 00000000..816c0736 --- /dev/null +++ b/strum_nostd_tests/src/lib.rs @@ -0,0 +1,37 @@ +#![no_std] + +#[cfg(test)] +mod tests { + use core::str::FromStr; + use strum::EnumString; + + #[derive(Debug, Eq, PartialEq, EnumString)] + enum Color { + Red, + Blue { + hue: usize, + }, + #[strum(serialize = "y", serialize = "yellow")] + Yellow, + #[strum(to_string = "purp")] + Purple, + #[strum(serialize = "blk", serialize = "Black", ascii_case_insensitive)] + Black, + } + + #[test] + fn from_str_no_std() { + assert_eq!(Color::Yellow, Color::from_str("yellow").unwrap()); + } + + #[test] + #[rustversion::since(1.34)] + fn try_from_str_no_std() { + use core::convert::TryFrom; + assert_eq!(Color::Yellow, Color::try_from("yellow").unwrap()); + } + + #[test] + #[rustversion::before(1.34)] + fn try_from_str_no_std() {} +} diff --git a/strum_tests/tests/from_str.rs b/strum_tests/tests/from_str.rs index 463e3b52..845768cc 100644 --- a/strum_tests/tests/from_str.rs +++ b/strum_tests/tests/from_str.rs @@ -131,7 +131,7 @@ fn lifetime_test() { #[derive(Debug, Eq, PartialEq, EnumString)] enum Generic { Gen(T), - None, + Error, } #[test]