introduce interface and support code for encoders
[nihav.git] / nihav-codec-support / src / test / mod.rs
CommitLineData
fb8e3177
KS
1//! Decoder testing functionality.
2//!
3//! This module provides functions that may be used in internal test to check that decoders produce output and that they produce expected output.
379fd781 4pub mod dec_video;
0b257d9f 5pub mod enc_video;
cc0859d6 6pub mod wavwriter;
eca0802b
KS
7
8mod md5; // for internal checksums only
9
fb8e3177
KS
10/// Decoder testing modes.
11///
12/// 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).
eca0802b 13pub enum ExpectedTestResult {
fb8e3177 14 /// Decoding runs without errors.
eca0802b 15 Decodes,
fb8e3177 16 /// Full decoded output is expected to be equal to this MD5 hash.
eca0802b 17 MD5([u32; 4]),
fb8e3177 18 /// Each decoded frame hash should be equal to the corresponding MD5 hash.
eca0802b 19 MD5Frames(Vec<[u32; 4]>),
fb8e3177 20 /// Test function should report decoded frame hashes to be used as the reference later.
eca0802b
KS
21 GenerateMD5Frames,
22}