use serde::{Deserialize, Deserializer}; /// Possible filesystem types for rootfs #[derive(Debug, Clone, Copy, PartialEq, Eq)] pub enum FsType { Fat32, } impl<'de> Deserialize<'de> for FsType { fn deserialize(deserializer: D) -> Result where D: Deserializer<'de>, { let mut s = String::deserialize(deserializer)?; s.make_ascii_lowercase(); match s.as_str() { "fat32" => Ok(FsType::Fat32), _ => Err(serde::de::Error::custom("invalid fs type")), } } } #[cfg(test)] mod tests { use super::*; use serde_json::{self, Value}; fn deserialize_fs_type(input: &str) -> Result { let json = Value::String(input.to_string()); serde_json::from_value(json) } #[test] fn test_deserialize_fat32_lowercase() { let r = deserialize_fs_type("fat32"); assert_eq!(r.is_ok(), true); let fs_type = r.unwrap(); assert_eq!(fs_type, FsType::Fat32); } #[test] fn test_deserialize_fat32_mixed_case() { let r = deserialize_fs_type("FAT32"); assert_eq!(r.is_ok(), true); let fs_type = r.unwrap(); assert_eq!(fs_type, FsType::Fat32); } #[test] fn testdeserialize_random_string() { assert!(deserialize_fs_type("abc123").is_err()); } }