diff options
author | Richard Walters <rwalters@digitalstirling.com> | 2020-10-09 17:03:02 -0700 |
---|---|---|
committer | Richard Walters <rwalters@digitalstirling.com> | 2020-10-09 17:03:02 -0700 |
commit | 4ed2297a7e31f7093582a00783c9c1f59f492a0d (patch) | |
tree | 0d2466ed39dfe39e60f535d7d30059d6b9b5a42f /src/percent_encoded_character_decoder.rs | |
parent | 6b406535576246d3a003139b56f98114b91e0939 (diff) |
Use named_tuple! to simplify test vector declarations
Diffstat (limited to 'src/percent_encoded_character_decoder.rs')
-rw-r--r-- | src/percent_encoded_character_decoder.rs | 36 |
1 files changed, 15 insertions, 21 deletions
diff --git a/src/percent_encoded_character_decoder.rs b/src/percent_encoded_character_decoder.rs index 08a92e1..01f65f4 100644 --- a/src/percent_encoded_character_decoder.rs +++ b/src/percent_encoded_character_decoder.rs @@ -26,9 +26,6 @@ lazy_static! { .collect(); } -// TODO: Learn about using thiserror to define library errors -// [14:05] ABuffSeagull: You should use https://lib.rs/crates/thiserror for the errors -// [14:07] 715209: i also recommend thiserror #[derive(Debug, Clone, thiserror::Error, PartialEq)] pub enum Error { #[error("illegal character")] @@ -91,31 +88,28 @@ mod tests { #[test] fn good_sequences() { - - // TODO: consider named tuples instead - // - // [14:07] LeinardoSmith: Looks like there is a macro for named tuples: - // https://docs.rs/named_tuple/0.1.3/named_tuple/ - struct TestVector { - sequence: [char; 2], - expected_output: u8, - } - let test_vectors = [ - TestVector{sequence: ['4', '1'], expected_output: b'A'}, - TestVector{sequence: ['5', 'A'], expected_output: b'Z'}, - TestVector{sequence: ['6', 'e'], expected_output: b'n'}, - TestVector{sequence: ['e', '1'], expected_output: b'\xe1'}, - TestVector{sequence: ['C', 'A'], expected_output: b'\xca'}, + named_tuple!( + struct TestVector { + sequence: [char; 2], + expected_output: u8, + } + ); + let test_vectors: [TestVector; 5] = [ + (['4', '1'], b'A').into(), + (['5', 'A'], b'Z').into(), + (['6', 'e'], b'n').into(), + (['e', '1'], b'\xe1').into(), + (['C', 'A'], b'\xca').into(), ]; for test_vector in &test_vectors { let mut pec = PercentEncodedCharacterDecoder::new(); assert_eq!( Ok(None), - pec.next(test_vector.sequence[0]) + pec.next(test_vector.sequence()[0]) ); assert_eq!( - Ok(Some(test_vector.expected_output)), - pec.next(test_vector.sequence[1]) + Ok(Some(*test_vector.expected_output())), + pec.next(test_vector.sequence()[1]) ); } } |