1 //! Decoder testing functionality.
3 //! This module provides functions that may be used in internal test to check that decoders produce output and that they produce expected output.
4 #[allow(clippy::identity_op)]
9 #[allow(clippy::identity_op)]
10 #[allow(clippy::unreadable_literal)]
11 mod md5; // for internal checksums only
13 /// Decoder testing modes.
15 /// NihAV has its own MD5 hasher that calculates hash for input frame in a deterministic way (i.e. no endianness issues) and it outputs hash as `[u32; 4]`. During testing the resulting hash will be printed out so when the test fails you can find what was the calculated hash (and use it as a reference if you are implementing a new test).
16 pub enum ExpectedTestResult {
17 /// Decoding runs without errors.
19 /// Full decoded output is expected to be equal to this MD5 hash.
21 /// Each decoded frame hash should be equal to the corresponding MD5 hash.
22 MD5Frames(Vec<[u32; 4]>),
23 /// Test function should report decoded frame hashes to be used as the reference later.