4 releases
0.1.4 | May 2, 2024 |
---|---|
0.1.3 | Apr 27, 2024 |
0.1.2 |
|
0.1.1 | Aug 20, 2023 |
0.1.0 | Aug 11, 2023 |
#940 in Rust patterns
269 downloads per month
9KB
139 lines
Gilder
Gilder is an assertion library for lazy folks (also say a golden testing library).
The golden test is a testing method commonly used to detect changes in program output. It ensures that the results remain consistent even when modifying the code.
In a golden test, the program's output is saved in a file known as the golden file to preserve it. During testing, the actual output is compared against the content of the golden file.
Gilder is designed to minimize the implementation cost and provides only one API for usage, which is the assert_golden!
macro. It can be used similar to assert_eq!
but without the second argument.
Getting Started
- Add Gilder as a dependency in your Cargo.toml file:
[dev-dependencies]
gilder = "0.1"
- Write a new test using
assert_golden!
macro:
#[test]
fn my_test() {
use gilder::assert_golden;
let target = something_you_want_to_test();
assert_golden!(target);
}
The argument to assert_golden!
must implement the ToString
trait to write to the golden file.
- Create golden files:
Golden files are generated by running the tests for the first time.
cargo test
A golden file with the .gld
extension will be saved in the same directory as the source file containing the test code.
- Testing:
When running the tests with the golden files present, the behavior is the same as a regular test.
cargo test
The macro will raise an error if it detects a change in value.
- Updating the golden files:
When you change the output of your function, it is necessary to update the golden files accordingly.
To update the golden files, delete the existing ones and rerun the tests.
Copyright
Copyright (c) 2023 carrotflakes (carrotflakes@gmail.com)
License
Licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.