#![allow( // clippy is broken and shows wrong warnings // clippy on stable does not know yet about the lint name unknown_lints, // https://github.com/rust-lang/rust-clippy/issues/8867 clippy::derive_partial_eq_without_eq, // This allows the tests to be written more uniform and not have to special case the last clone(). clippy::redundant_clone, )] mod utils; use crate::utils::{check_deserialization, check_error_deserialization, is_equal}; use expect_test::expect; use serde::{Deserialize, Serialize}; use serde_with::{ base64::{Base64, Bcrypt, BinHex, Crypt, ImapMutf7, Standard, UrlSafe}, formats::{Padded, Unpadded}, serde_as, }; #[test] fn base64_vec() { let check_equal = vec![vec![0, 1, 2, 13], vec![14, 5, 6, 7]]; let check_deser = vec![vec![0xaa, 0xbc, 0xff], vec![0xe0, 0x7d], vec![0xe0, 0x7d]]; let check_deser_from = r#"["qrz/","4H0=","4H0"]"#; #[serde_as] #[derive(Debug, Serialize, Deserialize, PartialEq)] pub struct BDefault(#[serde_as(as = "Vec")] Vec>); is_equal( BDefault(check_equal.clone()), expect![[r#" [ "AAECDQ==", "DgUGBw==" ]"#]], ); // Check mixed padding deserialization check_deserialization(BDefault(check_deser.clone()), check_deser_from); check_error_deserialization::( r#"["0"]"#, expect!["Encoded text cannot have a 6-bit remainder. at line 1 column 4"], ); check_error_deserialization::( r#"["zz"]"#, expect!["Invalid last symbol 122, offset 1. at line 1 column 5"], ); #[serde_as] #[derive(Debug, Serialize, Deserialize, PartialEq)] pub struct BPadded(#[serde_as(as = "Vec>")] Vec>); is_equal( BPadded(check_equal.clone()), expect![[r#" [ "AAECDQ==", "DgUGBw==" ]"#]], ); check_deserialization(BPadded(check_deser.clone()), check_deser_from); #[serde_as] #[derive(Debug, Serialize, Deserialize, PartialEq)] pub struct BUnpadded(#[serde_as(as = "Vec>")] Vec>); is_equal( BUnpadded(check_equal.clone()), expect![[r#" [ "AAECDQ", "DgUGBw" ]"#]], ); check_deserialization(BUnpadded(check_deser.clone()), check_deser_from); } #[test] fn base64_different_charsets() { let bytes = [ 0x69_u8, 0xb7, 0x1d, 0x79, 0xf8, 0x21, 0x8a, 0x39, 0x25, 0x9a, 0x7a, 0x29, 0xaa, 0xbb, 0x2d, 0xba, 0xfc, 0x31, 0xcb, 0x30, 0x01, 0x08, 0x31, 0x05, 0x18, 0x72, 0x09, 0x28, 0xb3, 0x0d, 0x38, 0xf4, 0x11, 0x49, 0x35, 0x15, 0x59, 0x76, 0x19, 0xd3, 0x5d, 0xb7, 0xe3, 0x9e, 0xbb, 0xf3, 0xdf, 0xbf, 0x00, ]; #[serde_as] #[derive(Debug, Serialize, Deserialize, PartialEq)] pub struct B64Standard(#[serde_as(as = "Base64")] Vec); is_equal( B64Standard(bytes.to_vec()), expect![[r#""abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/AA==""#]], ); #[serde_as] #[derive(Debug, Serialize, Deserialize, PartialEq)] pub struct B64UrlSafe(#[serde_as(as = "Base64")] Vec); is_equal( B64UrlSafe(bytes.to_vec()), expect![[r#""abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_AA==""#]], ); #[serde_as] #[derive(Debug, Serialize, Deserialize, PartialEq)] pub struct B64Crypt(#[serde_as(as = "Base64")] Vec); is_equal( B64Crypt(bytes.to_vec()), expect![[r#""OPQRSTUVWXYZabcdefghijklmn./0123456789ABCDEFGHIJKLMNopqrstuvwxyz..==""#]], ); #[serde_as] #[derive(Debug, Serialize, Deserialize, PartialEq)] pub struct B64Bcrypt(#[serde_as(as = "Base64")] Vec); is_equal( B64Bcrypt(bytes.to_vec()), expect![[r#""YZabcdefghijklmnopqrstuvwx./ABCDEFGHIJKLMNOPQRSTUVWXyz0123456789..==""#]], ); #[serde_as] #[derive(Debug, Serialize, Deserialize, PartialEq)] pub struct B64ImapMutf7(#[serde_as(as = "Base64")] Vec); is_equal( B64ImapMutf7(bytes.to_vec()), expect![[r#""abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+,AA==""#]], ); #[serde_as] #[derive(Debug, Serialize, Deserialize, PartialEq)] pub struct B64BinHex(#[serde_as(as = "Base64")] Vec); is_equal( B64BinHex(bytes.to_vec()), expect![[r##""CDEFGHIJKLMNPQRSTUVXYZ[`ab!\"#$%&'()*+,-0123456789@ABcdehijklmpqr!!==""##]], ); }