#![cfg(feature = "gzip")]
pub(crate) mod decoder;
pub(crate) mod encoder;
#[cfg(test)]
mod tests {
use crate::action::Action;
use crate::gzip::decoder::GZipDecoder;
use crate::gzip::encoder::GZipEncoder;
use crate::traits::decoder::DecodeExt;
use crate::traits::encoder::EncodeExt;
#[cfg(not(feature = "std"))]
use alloc::vec::Vec;
use rand::distributions::Standard;
use rand::{thread_rng, Rng};
fn check(testarray: &[u8]) {
let encoded = testarray
.to_vec()
.encode(&mut GZipEncoder::new(), Action::Finish)
.collect::<Result<Vec<_>, _>>();
let decoded = encoded
.unwrap()
.decode(&mut GZipDecoder::new())
.collect::<Result<Vec<_>, _>>()
.unwrap();
assert_eq!(testarray.to_vec(), decoded);
}
#[test]
fn test_empty() {
check(&[]);
}
#[test]
fn test_unit() {
check(b"a");
}
#[test]
fn test_arr() {
check(b"aaaaaaaaaaa");
}
#[test]
fn test_std() {
check(b"aabbaabbaaabbbaaabbbaabbaabb");
}
#[test]
fn test_long() {
check(&(b"a".iter().cycle().take(260).cloned().collect::<Vec<u8>>()));
}
#[test]
fn test_multiblocks() {
let rng = thread_rng();
check(&(rng.sample_iter(&Standard).take(323_742).collect::<Vec<_>>()));
}
#[test]
fn test_multiblocks2() {
let rng = thread_rng();
check(&(rng.sample_iter(&Standard).take(323_742).collect::<Vec<_>>()));
}
#[test]
fn test_multiblocks3() {
let rng = thread_rng();
check(
&(rng
.sample_iter(&Standard)
.take(0xF_FFFF)
.collect::<Vec<_>>()),
);
}
fn test_rand_with_len(len: usize) {
let rng = thread_rng();
check(&(rng.sample_iter(&Standard).take(len).collect::<Vec<_>>()));
}
#[test]
fn test_multiblocks6() {
test_rand_with_len(6);
}
#[test]
fn test_multiblocks4() {
test_rand_with_len(0x10_000);
}
#[test]
fn test_multiblocks5() {
test_rand_with_len(0x10_0001);
}
}