diff options
| author | Jakub Konka <kubkon@jakubkonka.com> | 2022-02-19 14:23:12 +0100 |
|---|---|---|
| committer | Jakub Konka <kubkon@jakubkonka.com> | 2022-02-19 14:24:03 +0100 |
| commit | 59df39e949907183e76ac78d7ace07e96f72e8a8 (patch) | |
| tree | 1606f01b012850701dbc87ef3d8b6d2f5063f0ca /test | |
| parent | da86839af085bb5921d7f0112fda5ad9536dda10 (diff) | |
| download | zig-59df39e949907183e76ac78d7ace07e96f72e8a8.tar.gz zig-59df39e949907183e76ac78d7ace07e96f72e8a8.zip | |
add integer division tests
Diffstat (limited to 'test')
| -rw-r--r-- | test/behavior.zig | 1 | ||||
| -rw-r--r-- | test/behavior/int_div.zig | 93 |
2 files changed, 94 insertions, 0 deletions
diff --git a/test/behavior.zig b/test/behavior.zig index 5b575ba190..b94b0b631a 100644 --- a/test/behavior.zig +++ b/test/behavior.zig @@ -50,6 +50,7 @@ test { _ = @import("behavior/tuple.zig"); _ = @import("behavior/type.zig"); _ = @import("behavior/var_args.zig"); + _ = @import("behavior/int_div.zig"); // tests that don't pass for stage1 if (builtin.zig_backend != .stage1) { diff --git a/test/behavior/int_div.zig b/test/behavior/int_div.zig new file mode 100644 index 0000000000..8ab8ad9e42 --- /dev/null +++ b/test/behavior/int_div.zig @@ -0,0 +1,93 @@ +const std = @import("std"); +const builtin = @import("builtin"); +const expect = std.testing.expect; + +test "integer division" { + if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; + if (builtin.zig_backend == .stage2_c) return error.SkipZigTest; + if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest; + if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; + + try testDivision(); + comptime try testDivision(); +} +fn testDivision() !void { + try expect(div(u32, 13, 3) == 4); + try expect(div(u64, 13, 3) == 4); + try expect(div(u8, 13, 3) == 4); + + try expect(divExact(u32, 55, 11) == 5); + try expect(divExact(i32, -55, 11) == -5); + try expect(divExact(i64, -55, 11) == -5); + try expect(divExact(i16, -55, 11) == -5); + + try expect(divFloor(i8, 5, 3) == 1); + try expect(divFloor(i16, -5, 3) == -2); + try expect(divFloor(i64, -0x80000000, -2) == 0x40000000); + try expect(divFloor(i32, 0, -0x80000000) == 0); + try expect(divFloor(i64, -0x40000001, 0x40000000) == -2); + try expect(divFloor(i32, -0x80000000, 1) == -0x80000000); + try expect(divFloor(i32, 10, 12) == 0); + try expect(divFloor(i32, -14, 12) == -2); + try expect(divFloor(i32, -2, 12) == -1); + + try expect(divTrunc(i32, 5, 3) == 1); + try expect(divTrunc(i32, -5, 3) == -1); + try expect(divTrunc(i32, 9, -10) == 0); + try expect(divTrunc(i32, -9, 10) == 0); + try expect(divTrunc(i32, 10, 12) == 0); + try expect(divTrunc(i32, -14, 12) == -1); + try expect(divTrunc(i32, -2, 12) == 0); + + try expect(mod(u32, 10, 12) == 10); + try expect(mod(i32, 10, 12) == 10); + try expect(mod(i64, -14, 12) == 10); + try expect(mod(i16, -2, 12) == 10); + try expect(mod(i8, -2, 12) == 10); + + try expect(rem(i32, 10, 12) == 10); + try expect(rem(i32, -14, 12) == -2); + try expect(rem(i32, -2, 12) == -2); + + comptime { + try expect( + 1194735857077236777412821811143690633098347576 % 508740759824825164163191790951174292733114988 == 177254337427586449086438229241342047632117600, + ); + try expect( + @rem(-1194735857077236777412821811143690633098347576, 508740759824825164163191790951174292733114988) == -177254337427586449086438229241342047632117600, + ); + try expect( + 1194735857077236777412821811143690633098347576 / 508740759824825164163191790951174292733114988 == 2, + ); + try expect( + @divTrunc(-1194735857077236777412821811143690633098347576, 508740759824825164163191790951174292733114988) == -2, + ); + try expect( + @divTrunc(1194735857077236777412821811143690633098347576, -508740759824825164163191790951174292733114988) == -2, + ); + try expect( + @divTrunc(-1194735857077236777412821811143690633098347576, -508740759824825164163191790951174292733114988) == 2, + ); + try expect( + 4126227191251978491697987544882340798050766755606969681711 % 10 == 1, + ); + } +} +fn div(comptime T: type, a: T, b: T) T { + return a / b; +} +fn divExact(comptime T: type, a: T, b: T) T { + return @divExact(a, b); +} +fn divFloor(comptime T: type, a: T, b: T) T { + return @divFloor(a, b); +} +fn divTrunc(comptime T: type, a: T, b: T) T { + return @divTrunc(a, b); +} +fn mod(comptime T: type, a: T, b: T) T { + return @mod(a, b); +} +fn rem(comptime T: type, a: T, b: T) T { + return @rem(a, b); +} |
