pub(crate) mod coded;
pub(crate) mod composite;
pub(crate) mod strings;
#[inline]
#[allow(dead_code)] pub(crate) fn coin(g: &mut ::quickcheck::Gen) -> bool {
<bool as ::quickcheck::Arbitrary>::arbitrary(g)
}
#[inline]
#[allow(dead_code)]
pub(crate) fn arb_string(g: &mut ::quickcheck::Gen) -> ::std::string::String {
<::std::string::String as ::quickcheck::Arbitrary>::arbitrary(g)
}
#[cfg(test)]
mod tests {
use ::quickcheck::{Arbitrary, Gen};
fn drive<F: FnMut(&mut Gen)>(size: usize, rounds: usize, mut body: F) {
let mut g = Gen::new(size);
for _ in 0..rounds {
body(&mut g);
}
}
#[test]
fn geo_location_invariant_lat_lon_in_range() {
drive(64, 256, |g| {
let geo = crate::capture::GeoLocation::arbitrary(g);
assert!(
(-90.0..=90.0).contains(&geo.lat()),
"lat out of range: {}",
geo.lat()
);
assert!(
(-180.0..=180.0).contains(&geo.lon()),
"lon out of range: {}",
geo.lon()
);
if let Some(alt) = geo.altitude() {
assert!(
alt.is_finite(),
"altitude must be finite when Some, got {alt}"
);
}
});
}
#[test]
fn fingerprint_invariant_algorithm_non_empty() {
drive(64, 256, |g| {
let fp = crate::audio::Fingerprint::arbitrary(g);
assert!(!fp.algorithm().is_empty(), "algorithm must be non-empty");
});
}
#[test]
fn cover_art_invariant_mime_and_data_non_empty() {
drive(64, 256, |g| {
let c = crate::audio::CoverArt::arbitrary(g);
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(64, 64, |g| {
let _ = crate::codec::VideoCodec::arbitrary(g);
let _ = crate::color::Info::arbitrary(g);
let _ = crate::frame::FrameRate::arbitrary(g);
let _ = crate::lang::Language::arbitrary(g);
let _ = crate::disposition::TrackDisposition::arbitrary(g);
let _ = crate::audio::Tags::arbitrary(g);
});
}
#[test]
fn reachability_small_coded_enums_hit_all_named() {
use ::std::collections::HashSet;
let mut br: HashSet<crate::audio::BitRateMode> = HashSet::new();
let mut to: HashSet<crate::subtitle::TrackOrigin> = HashSet::new();
drive(64, 2048, |g| {
br.insert(crate::audio::BitRateMode::arbitrary(g));
to.insert(crate::subtitle::TrackOrigin::arbitrary(g));
});
assert_eq!(br.len(), 3, "BitRateMode coverage: {br:?}");
assert_eq!(to.len(), 3, "TrackOrigin coverage: {to:?}");
}
#[test]
fn reachability_weighted_rotation_hits_named_and_unknown() {
use crate::frame::Rotation;
let mut saw_named = false;
let mut saw_unknown = false;
drive(64, 2048, |g| match Rotation::arbitrary(g) {
Rotation::Unknown(_) => saw_unknown = true,
_ => saw_named = true,
});
assert!(
saw_named && saw_unknown,
"Rotation missing arms: named={saw_named} unknown={saw_unknown}"
);
}
#[test]
fn reachability_sample_format_all_named_plus_arms() {
use crate::audio::SampleFormat;
use ::std::collections::HashSet;
let mut named: HashSet<::std::string::String> = HashSet::new();
let mut saw_unknown = false;
let mut saw_other = false;
drive(64, 4096, |g| match SampleFormat::arbitrary(g) {
SampleFormat::Unknown(_) => saw_unknown = true,
SampleFormat::Other(_) => saw_other = true,
other => {
named.insert(other.as_str().to_string());
}
});
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::HashSet;
let mut matrix: HashSet<u32> = HashSet::new();
let mut primaries: HashSet<u32> = HashSet::new();
let mut transfer: HashSet<u32> = HashSet::new();
let mut pixel: HashSet<u32> = HashSet::new();
drive(64, 8192, |g| {
matrix.insert(crate::color::Matrix::arbitrary(g).to_u32());
primaries.insert(crate::color::Primaries::arbitrary(g).to_u32());
transfer.insert(crate::color::Transfer::arbitrary(g).to_u32());
pixel.insert(crate::pixel_format::PixelFormat::arbitrary(g).to_u32());
});
let in_range = |s: &HashSet<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(64, 128, |g| {
let m = crate::color::Matrix::arbitrary(g);
assert_eq!(crate::color::Matrix::from_u32(m.to_u32()), m);
let p = crate::pixel_format::PixelFormat::arbitrary(g);
assert_eq!(crate::pixel_format::PixelFormat::from_u32(p.to_u32()), p);
let r = crate::frame::Rotation::arbitrary(g);
assert_eq!(crate::frame::Rotation::from_u32(r.to_u32()), r);
let d = crate::disposition::TrackDisposition::arbitrary(g);
assert_eq!(
crate::disposition::TrackDisposition::from_u32(d.to_u32()),
d
);
});
}
#[test]
fn reachability_tags_language_hits_none_and_some() {
let mut saw_none = false;
let mut saw_some = false;
drive(64, 1024, |g| {
match crate::audio::Tags::arbitrary(g).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(_)`");
}
#[cfg(feature = "serde")]
#[test]
fn arbitrary_values_survive_serde_round_trip() {
drive(64, 4096, |g| {
let sf = crate::audio::SampleFormat::arbitrary(g);
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(g);
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(g);
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}");
});
}
}