diff options
| author | Andrew Kelley <andrew@ziglang.org> | 2020-07-26 05:54:30 +0000 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-07-26 05:54:30 +0000 |
| commit | 40d81a8364899626ad787f03d94111cd21b9263d (patch) | |
| tree | 3897fdeb330d6a5c8882363314d7c6e85d509366 /lib/std/testing.zig | |
| parent | a36772ee642607326c48a4ddb3acfa600cb502b6 (diff) | |
| parent | 46106b018cc5c870648cf26d4e7413e8a60ad1e4 (diff) | |
| download | zig-40d81a8364899626ad787f03d94111cd21b9263d.tar.gz zig-40d81a8364899626ad787f03d94111cd21b9263d.zip | |
Merge pull request #5678 from antlilja/float-testing
Add functions for testing floats with margins and epsilons to standard library
Diffstat (limited to 'lib/std/testing.zig')
| -rw-r--r-- | lib/std/testing.zig | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/lib/std/testing.zig b/lib/std/testing.zig index 44c221d76a..423f537f74 100644 --- a/lib/std/testing.zig +++ b/lib/std/testing.zig @@ -171,6 +171,59 @@ test "expectEqual.union(enum)" { expectEqual(a10, a10); } +/// This function is intended to be used only in tests. When the actual value is not +/// within the margin of the expected value, +/// prints diagnostics to stderr to show exactly how they are not equal, then aborts. +/// The types must be floating point +pub fn expectWithinMargin(expected: var, actual: @TypeOf(expected), margin: @TypeOf(expected)) void { + std.debug.assert(margin >= 0.0); + + switch (@typeInfo(@TypeOf(actual))) { + .Float, + .ComptimeFloat, + => { + if (@fabs(expected - actual) > margin) { + std.debug.panic("actual {}, not within margin {} of expected {}", .{ actual, margin, expected }); + } + }, + else => @compileError("Unable to compare non floating point values"), + } +} + +test "expectWithinMargin.f32" { + const x: f32 = 12.0; + const y: f32 = 12.06; + + expectWithinMargin(x, y, 0.1); +} + +/// This function is intended to be used only in tests. When the actual value is not +/// within the epsilon of the expected value, +/// prints diagnostics to stderr to show exactly how they are not equal, then aborts. +/// The types must be floating point +pub fn expectWithinEpsilon(expected: var, actual: @TypeOf(expected), epsilon: @TypeOf(expected)) void { + std.debug.assert(epsilon >= 0.0 and epsilon <= 1.0); + + const margin = epsilon * expected; + switch (@typeInfo(@TypeOf(actual))) { + .Float, + .ComptimeFloat, + => { + if (@fabs(expected - actual) > margin) { + std.debug.panic("actual {}, not within epsilon {}, of expected {}", .{ actual, epsilon, expected }); + } + }, + else => @compileError("Unable to compare non floating point values"), + } +} + +test "expectWithinEpsilon.f32" { + const x: f32 = 12.0; + const y: f32 = 13.2; + + expectWithinEpsilon(x, y, 0.1); +} + /// This function is intended to be used only in tests. When the two slices are not /// equal, prints diagnostics to stderr to show exactly how they are not equal, /// then aborts. |
