Estimated time: 1 day
Rust testing ecosystem hasn't grown quite well yet, but provides some interesting libraries and solutions.
Rust provides quite good built-in testing capabilities, which are very well described in the following articles:
BDD (behavior-driven development) testing style implies that test cases represent a program specification, while tests themselves prove the specification correctness.
While Rust ecosystem has some BDD testing style crates (the most mature one is cucumber_rust crate), it's not a requirement to use them to follow BDD style (as they may be too complex for some trivial cases). There is nothing which prevents you from following BDD style in usual Rust tests. So, instead of:
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_hash() {
let h = hash("some_string");
assert_eq!(h.len(), 64);
assert!(!h.contains("z"));
}
}
You're always free to write it more meaningfully:
#[cfg(test)]
mod hash_spec {
use super::*;
#[test]
fn has_64_symbols_len() {
assert_eq!(hash("some_string").len(), 64);
}
#[test]
fn contains_hex_chars_only() {
assert!(!hash("some_string").contains("z"));
}
}
This makes tests more granular (so more meaningful test failures) and testing intentions become more understandable for reader.
Unfortunately, for mocking Rust ecosystem does not provide mature solutions. However, still there are some crates out there.
The most interested one is mockiato crate at the moment, as is quite ergonomic in use and supports stable Rust.
Additionally, mockito crate should be mentioned as a quite useful one for HTTP testing.
For better overview and familiarity with mocking in Rust, read through the following articles:
Property testing is another testing paradigm for considering. In a nutshell, it can be explained in the following way:
Property testing is a system of testing code by checking that certain properties of its output or behaviour are fulfilled for all inputs. These inputs are generated automatically, and, critically, when a failing input is found, the input is automatically reduced to a minimal test case.
Rust ecosystem has quite good proptest and quickcheck crates, which provide tools and primitives for property testing.
For better understanding and familiarity with property testing in Rust, read through the following articles:
Fuzzing is another testing technique, which involves providing invalid, unexpected, or random data as inputs to a computer program. It really helps to spot program crashes and memory leaks in edge cases.
Rust ecosystem has several tools for fuzzing at the moment. Most known are:
- cargo-fuzz is a command-line wrapper for using libFuzzer.
- afl.rs allows to run AFL (american fuzzy lop) on code written in Rust.
- honggfuzz is a security oriented fuzzer with powerful analysis options, which supports evolutionary, feedback-driven fuzzing based on code coverage (software- and hardware-based).
For better understanding and familiarity with fuzzing in Rust, read through the following articles:
For the implementation of a small guessing game in this step's crate provide all possible tests you're able to write.