summaryrefslogtreecommitdiff
path: root/vendor/weezl/tests/roundtrip_vec.rs
diff options
context:
space:
mode:
authorValentin Popov <valentin@popov.link>2024-01-08 00:21:28 +0300
committerValentin Popov <valentin@popov.link>2024-01-08 00:21:28 +0300
commit1b6a04ca5504955c571d1c97504fb45ea0befee4 (patch)
tree7579f518b23313e8a9748a88ab6173d5e030b227 /vendor/weezl/tests/roundtrip_vec.rs
parent5ecd8cf2cba827454317368b68571df0d13d7842 (diff)
downloadfparkan-1b6a04ca5504955c571d1c97504fb45ea0befee4.tar.xz
fparkan-1b6a04ca5504955c571d1c97504fb45ea0befee4.zip
Initial vendor packages
Signed-off-by: Valentin Popov <valentin@popov.link>
Diffstat (limited to 'vendor/weezl/tests/roundtrip_vec.rs')
-rw-r--r--vendor/weezl/tests/roundtrip_vec.rs65
1 files changed, 65 insertions, 0 deletions
diff --git a/vendor/weezl/tests/roundtrip_vec.rs b/vendor/weezl/tests/roundtrip_vec.rs
new file mode 100644
index 0000000..d8bfd84
--- /dev/null
+++ b/vendor/weezl/tests/roundtrip_vec.rs
@@ -0,0 +1,65 @@
+use std::{env, fs};
+use weezl::{decode, encode, BitOrder};
+
+#[derive(Clone, Copy, Debug)]
+enum Flavor {
+ Gif,
+ Tiff,
+}
+
+#[test]
+fn roundtrip_all() {
+ let file = env::args().next().unwrap();
+ let data = fs::read(file).unwrap();
+
+ for &flavor in &[Flavor::Gif, Flavor::Tiff] {
+ for &bit_order in &[BitOrder::Lsb, BitOrder::Msb] {
+ for bit_width in 2..8 {
+ let data: Vec<_> = data
+ .iter()
+ .copied()
+ .map(|b| b & ((1 << bit_width) - 1))
+ .collect();
+
+ println!("Roundtrip test {:?} {:?} {}", flavor, bit_order, bit_width);
+ assert_roundtrips(&*data, flavor, bit_width, bit_order);
+ }
+ }
+ }
+}
+
+fn assert_roundtrips(data: &[u8], flavor: Flavor, bit_width: u8, bit_order: BitOrder) {
+ let (c, d): (
+ fn(BitOrder, u8) -> encode::Encoder,
+ fn(BitOrder, u8) -> decode::Decoder,
+ ) = match flavor {
+ Flavor::Gif => (encode::Encoder::new, decode::Decoder::new),
+ Flavor::Tiff => (
+ encode::Encoder::with_tiff_size_switch,
+ decode::Decoder::with_tiff_size_switch,
+ ),
+ };
+ let mut encoder = c(bit_order, bit_width);
+ let mut buffer = Vec::with_capacity(2 * data.len() + 40);
+
+ let _ = encoder.into_vec(&mut buffer).encode_all(data);
+
+ let mut decoder = d(bit_order, bit_width);
+ let mut compare = vec![];
+ let result = decoder.into_vec(&mut compare).decode_all(buffer.as_slice());
+ assert!(
+ result.status.is_ok(),
+ "{:?}, {}, {:?}",
+ bit_order,
+ bit_width,
+ result.status
+ );
+ assert!(
+ data == &*compare,
+ "{:?}, {}\n{:?}\n{:?}",
+ bit_order,
+ bit_width,
+ data,
+ compare
+ );
+}