zig/std/special/compiler_rt/fixunssfsi_test.zig
Andrew Kelley c2db077574
std.debug.assert: remove special case for test builds
Previously, std.debug.assert would `@panic` in test builds,
if the assertion failed. Now, it's always `unreachable`.

This makes release mode test builds more accurately test
the actual code that will be run.

However this requires tests to call `std.testing.expect`
rather than `std.debug.assert` to make sure output is correct.

Here is the explanation of when to use either one, copied from
the assert doc comments:

Inside a test block, it is best to use the `std.testing` module
rather than assert, because assert may not detect a test failure
in ReleaseFast and ReleaseSafe mode. Outside of a test block, assert
is the correct function to use.

closes #1304
2019-02-08 18:23:38 -05:00

37 lines
1.0 KiB
Zig

const __fixunssfsi = @import("fixunssfsi.zig").__fixunssfsi;
const testing = @import("std").testing;
fn test__fixunssfsi(a: f32, expected: u32) void {
const x = __fixunssfsi(a);
testing.expect(x == expected);
}
test "fixunssfsi" {
test__fixunssfsi(0.0, 0);
test__fixunssfsi(0.5, 0);
test__fixunssfsi(0.99, 0);
test__fixunssfsi(1.0, 1);
test__fixunssfsi(1.5, 1);
test__fixunssfsi(1.99, 1);
test__fixunssfsi(2.0, 2);
test__fixunssfsi(2.01, 2);
test__fixunssfsi(-0.5, 0);
test__fixunssfsi(-0.99, 0);
test__fixunssfsi(-1.0, 0);
test__fixunssfsi(-1.5, 0);
test__fixunssfsi(-1.99, 0);
test__fixunssfsi(-2.0, 0);
test__fixunssfsi(-2.01, 0);
test__fixunssfsi(0x1.000000p+31, 0x80000000);
test__fixunssfsi(0x1.000000p+32, 0xFFFFFFFF);
test__fixunssfsi(0x1.FFFFFEp+31, 0xFFFFFF00);
test__fixunssfsi(0x1.FFFFFEp+30, 0x7FFFFF80);
test__fixunssfsi(0x1.FFFFFCp+30, 0x7FFFFF00);
test__fixunssfsi(-0x1.FFFFFEp+30, 0);
test__fixunssfsi(-0x1.FFFFFCp+30, 0);
}