mod coded;
mod composite;
mod strings;
#[allow(unused_macros)]
macro_rules! arb_via_code {
($($ty:path),* $(,)?) => { $(
impl<'a> ::arbitrary::Arbitrary<'a> for $ty {
fn arbitrary(u: &mut ::arbitrary::Unstructured<'a>) -> ::arbitrary::Result<Self> {
Ok(<$ty>::from_u32(<u32 as ::arbitrary::Arbitrary>::arbitrary(u)?))
}
}
)* };
}
#[allow(unused_imports)]
pub(crate) use arb_via_code;
#[allow(unused_macros)]
macro_rules! arb_via_named_variants {
($ty:path, [$($variant:ident),+ $(,)?]) => {
impl<'a> ::arbitrary::Arbitrary<'a> for $ty {
fn arbitrary(u: &mut ::arbitrary::Unstructured<'a>) -> ::arbitrary::Result<Self> {
const NAMED: &[$ty] = &[$(<$ty>::$variant),+];
Ok(*u.choose(NAMED)?)
}
}
};
}
#[allow(unused_imports)]
pub(crate) use arb_via_named_variants;
#[allow(unused_macros)]
macro_rules! arb_via_code_weighted {
($ty:path, [$($variant:ident),+ $(,)?]) => {
impl<'a> ::arbitrary::Arbitrary<'a> for $ty {
fn arbitrary(u: &mut ::arbitrary::Unstructured<'a>) -> ::arbitrary::Result<Self> {
if <bool as ::arbitrary::Arbitrary>::arbitrary(u)? {
const NAMED: &[$ty] = &[$(<$ty>::$variant),+];
Ok(*u.choose(NAMED)?)
} else {
Ok(<$ty>::from_u32(<u32 as ::arbitrary::Arbitrary>::arbitrary(u)?))
}
}
}
};
}
#[allow(unused_imports)]
pub(crate) use arb_via_code_weighted;
#[allow(unused_macros)]
macro_rules! arb_via_code_weighted_range {
($ty:path, max_named = $max:expr) => {
impl<'a> ::arbitrary::Arbitrary<'a> for $ty {
fn arbitrary(u: &mut ::arbitrary::Unstructured<'a>) -> ::arbitrary::Result<Self> {
let code = if <bool as ::arbitrary::Arbitrary>::arbitrary(u)? {
u.int_in_range(0u32..=$max)?
} else {
<u32 as ::arbitrary::Arbitrary>::arbitrary(u)?
};
Ok(<$ty>::from_u32(code))
}
}
};
}
#[allow(unused_imports)]
pub(crate) use arb_via_code_weighted_range;
#[allow(unused_macros)]
macro_rules! arb_open_string_enum {
($ty:path, [$($slug:literal),+ $(,)?]) => {
impl<'a> ::arbitrary::Arbitrary<'a> for $ty {
fn arbitrary(u: &mut ::arbitrary::Unstructured<'a>) -> ::arbitrary::Result<Self> {
const SAMPLES: &[&str] = &[$($slug),+];
if <bool as ::arbitrary::Arbitrary>::arbitrary(u)? {
Ok(<$ty as ::core::str::FromStr>::from_str(u.choose(SAMPLES)?).unwrap())
} else {
let s = <::std::string::String as ::arbitrary::Arbitrary>::arbitrary(u)?;
Ok(<$ty as ::core::str::FromStr>::from_str(&s).unwrap())
}
}
}
};
}
#[allow(unused_imports)]
pub(crate) use arb_open_string_enum;
#[cfg(test)]
mod tests {
use ::arbitrary::{Arbitrary, Unstructured};
fn drive<F: FnMut(&mut Unstructured<'_>)>(seed: u64, rounds: usize, mut body: F) {
let mut bytes = ::std::vec![0u8; 4096];
for (i, b) in bytes.iter_mut().enumerate() {
*b = ((seed.wrapping_mul(0x9E37_79B9_7F4A_7C15) ^ i as u64) & 0xff) as u8;
}
let mut u = Unstructured::new(&bytes);
for _ in 0..rounds {
body(&mut u);
}
}
#[test]
fn geo_location_invariant_lat_lon_in_range() {
drive(0xA11CE, 256, |u| {
let g = crate::capture::GeoLocation::arbitrary(u).unwrap();
assert!(
(-90.0..=90.0).contains(&g.lat()),
"lat out of range: {}",
g.lat()
);
assert!(
(-180.0..=180.0).contains(&g.lon()),
"lon out of range: {}",
g.lon()
);
if let Some(alt) = g.altitude() {
assert!(
alt.is_finite(),
"altitude must be finite when Some, got {alt}"
);
}
});
}
#[test]
fn fingerprint_invariant_algorithm_non_empty() {
drive(0xB0B, 256, |u| {
let fp = crate::audio::Fingerprint::arbitrary(u).unwrap();
assert!(!fp.algorithm().is_empty(), "algorithm must be non-empty");
});
}
#[test]
fn cover_art_invariant_mime_and_data_non_empty() {
drive(0xC0FFEE, 256, |u| {
let c = crate::audio::CoverArt::arbitrary(u).unwrap();
assert!(!c.mime().is_empty(), "mime must be non-empty");
assert!(!c.data().is_empty(), "data must be non-empty");
});
}
#[test]
fn smoke_yields_values_for_representative_types() {
drive(0xD1CE, 64, |u| {
let _ = crate::codec::VideoCodec::arbitrary(u).unwrap();
let _ = crate::color::Info::arbitrary(u).unwrap();
let _ = crate::frame::FrameRate::arbitrary(u).unwrap();
let _ = crate::lang::Language::arbitrary(u).unwrap();
let _ = crate::disposition::TrackDisposition::arbitrary(u).unwrap();
});
}
fn drive_per_round<F: FnMut(&mut Unstructured<'_>)>(seed: u64, rounds: usize, mut body: F) {
let mut state = seed
.wrapping_mul(0x9E37_79B9_7F4A_7C15)
.wrapping_add(0xDEAD_BEEF_CAFE_F00D);
for _ in 0..rounds {
let mut bytes = ::std::vec![0u8; 64];
for b in bytes.iter_mut() {
state = state
.wrapping_add(0x9E37_79B9_7F4A_7C15)
.wrapping_mul(0xBF58_476D_1CE4_E5B9);
let mixed = state ^ (state >> 27);
*b = (mixed.wrapping_mul(0x94D0_49BB_1331_11EB) >> 56) as u8;
}
let mut u = Unstructured::new(&bytes);
body(&mut u);
}
}
#[test]
fn reachability_small_closed_coded_enums_hit_all_named() {
use ::std::collections::BTreeSet;
let mut br: BTreeSet<u32> = BTreeSet::new();
let mut to: BTreeSet<u32> = BTreeSet::new();
drive_per_round(0x12C0DE5_u64, 2048, |u| {
br.insert(crate::audio::BitRateMode::arbitrary(u).unwrap().to_u32());
to.insert(crate::subtitle::TrackOrigin::arbitrary(u).unwrap().to_u32());
});
assert_eq!(br.len(), 3, "BitRateMode coverage: {br:?}");
assert_eq!(to.len(), 3, "TrackOrigin coverage: {to:?}");
}
#[test]
fn reachability_weighted_coded_enum_hits_all_named_and_unknown() {
use crate::frame::Rotation;
let mut saw_d0 = false;
let mut saw_d90 = false;
let mut saw_d180 = false;
let mut saw_d270 = false;
let mut saw_unknown = false;
drive_per_round(0x20C0DE5_u64, 2048, |u| {
match Rotation::arbitrary(u).unwrap() {
Rotation::D0 => saw_d0 = true,
Rotation::D90 => saw_d90 = true,
Rotation::D180 => saw_d180 = true,
Rotation::D270 => saw_d270 = true,
Rotation::Unknown(_) => saw_unknown = true,
}
});
assert!(
saw_d0 && saw_d90 && saw_d180 && saw_d270 && saw_unknown,
"Rotation coverage: D0={saw_d0} D90={saw_d90} D180={saw_d180} D270={saw_d270} Unknown={saw_unknown}"
);
}
#[test]
fn reachability_sample_format_all_named_plus_arms() {
use crate::audio::SampleFormat;
use ::std::collections::BTreeSet;
let mut named: BTreeSet<::std::string::String> = BTreeSet::new();
let mut saw_unknown = false;
let mut saw_other = false;
drive_per_round(0x3F0_FEED_u64, 4096, |u| {
match SampleFormat::arbitrary(u).unwrap() {
SampleFormat::Unknown(_) => saw_unknown = true,
SampleFormat::Other(_) => saw_other = true,
other => {
named.insert(::std::string::String::from(other.as_str()));
}
}
});
assert_eq!(
named.len(),
12,
"missing named SampleFormat variants; observed: {named:?}"
);
assert!(saw_unknown, "SampleFormat: never observed `Unknown(_)`");
assert!(saw_other, "SampleFormat: never observed `Other(_)`");
}
#[test]
fn reachability_range_weighted_enums_hit_named_codes() {
use ::std::collections::BTreeSet;
let mut matrix: BTreeSet<u32> = BTreeSet::new();
let mut primaries: BTreeSet<u32> = BTreeSet::new();
let mut transfer: BTreeSet<u32> = BTreeSet::new();
let mut pixel: BTreeSet<u32> = BTreeSet::new();
drive_per_round(0x4A_C0DE5_u64, 8192, |u| {
matrix.insert(crate::color::Matrix::arbitrary(u).unwrap().to_u32());
primaries.insert(crate::color::Primaries::arbitrary(u).unwrap().to_u32());
transfer.insert(crate::color::Transfer::arbitrary(u).unwrap().to_u32());
pixel.insert(
crate::pixel_format::PixelFormat::arbitrary(u)
.unwrap()
.to_u32(),
);
});
let in_range = |s: &BTreeSet<u32>, max: u32| s.iter().filter(|&&c| c <= max).count();
assert!(
in_range(&matrix, 17) >= 10,
"Matrix named-range coverage too low: {matrix:?}"
);
assert!(
matrix.contains(&crate::color::DOMAIN_EXT_BASE),
"Matrix::Bt601 (DOMAIN_EXT_BASE) never generated"
);
assert!(
in_range(&primaries, 22) >= 8,
"Primaries named-range coverage too low: {primaries:?}"
);
assert!(
in_range(&transfer, 18) >= 10,
"Transfer named-range coverage too low: {transfer:?}"
);
assert!(
in_range(&pixel, 947) >= 40,
"PixelFormat named-range coverage too low: {} distinct",
in_range(&pixel, 947)
);
}
#[test]
fn coded_enums_roundtrip_through_code() {
drive(0xE11E, 128, |u| {
let m = crate::color::Matrix::arbitrary(u).unwrap();
assert_eq!(crate::color::Matrix::from_u32(m.to_u32()), m);
let p = crate::pixel_format::PixelFormat::arbitrary(u).unwrap();
assert_eq!(crate::pixel_format::PixelFormat::from_u32(p.to_u32()), p);
let r = crate::frame::Rotation::arbitrary(u).unwrap();
assert_eq!(crate::frame::Rotation::from_u32(r.to_u32()), r);
let d = crate::disposition::TrackDisposition::arbitrary(u).unwrap();
assert_eq!(
crate::disposition::TrackDisposition::from_u32(d.to_u32()),
d
);
});
}
#[cfg(feature = "serde")]
#[test]
fn arbitrary_values_survive_serde_round_trip() {
drive_per_round(0x5E2DE_u64, 4096, |u| {
let sf = crate::audio::SampleFormat::arbitrary(u).unwrap();
let json = serde_json::to_string(&sf).unwrap();
let back: crate::audio::SampleFormat = serde_json::from_str(&json).unwrap();
assert_eq!(back, sf, "SampleFormat lost identity via serde: {json}");
let vc = crate::codec::VideoCodec::arbitrary(u).unwrap();
let json = serde_json::to_string(&vc).unwrap();
let back: crate::codec::VideoCodec = serde_json::from_str(&json).unwrap();
assert_eq!(back, vc, "VideoCodec lost identity via serde: {json}");
let ld = crate::audio::Loudness::arbitrary(u).unwrap();
let json = serde_json::to_string(&ld).unwrap();
let back: crate::audio::Loudness = serde_json::from_str(&json).unwrap();
assert_eq!(back, ld, "Loudness lost identity via serde: {json}");
});
}
#[test]
fn reachability_tags_language_hits_none_and_some() {
let mut saw_none = false;
let mut saw_some = false;
drive_per_round(
0x7A65_1A_u64,
1024,
|u| match crate::audio::Tags::arbitrary(u).unwrap().language() {
None => saw_none = true,
Some(_) => saw_some = true,
},
);
assert!(saw_none, "Tags.language never generated `None`");
assert!(saw_some, "Tags.language never generated `Some(_)`");
}
}