master
1const cmp = @import("cmp.zig");
2const testing = @import("std").testing;
3
4fn test__ucmpsi2(a: u32, b: u32, expected: i32) !void {
5 const result = cmp.__ucmpsi2(a, b);
6 try testing.expectEqual(expected, result);
7}
8
9test "ucmpsi2" {
10 // minInt == 0
11 // maxInt == 4294967295
12 // minInt/2 == 0
13 // maxInt/2 == 2147483647
14 // 1. equality 0, 1 maxInt/2, maxInt-1, maxInt
15 try test__ucmpsi2(0, 0, 1);
16 try test__ucmpsi2(1, 1, 1);
17 try test__ucmpsi2(2147483647, 2147483647, 1);
18 try test__ucmpsi2(4294967294, 4294967294, 1);
19 try test__ucmpsi2(4294967295, 4294967295, 1);
20 // 2. cmp minInt, {0, 1, maxInt/2, maxInt-1, maxInt}
21 try test__ucmpsi2(0, 1, 0);
22 try test__ucmpsi2(0, 2147483647, 0);
23 try test__ucmpsi2(0, 4294967294, 0);
24 try test__ucmpsi2(0, 4294967295, 0);
25 // 3. cmp minInt+1, {minInt, 0, maxInt/2, maxInt-1, maxInt}
26 try test__ucmpsi2(1, 0, 2);
27 try test__ucmpsi2(1, 2147483647, 0);
28 try test__ucmpsi2(1, 4294967294, 0);
29 try test__ucmpsi2(1, 4294967295, 0);
30 // 4. cmp minInt/2==minInt, {}
31 // 5. cmp -1 {}
32 // 6. cmp 0==minInt,{}
33 // 7. cmp 1==minInt+1, {}
34 // 8. cmp maxInt/2, {0, maxInt-1, maxInt}
35 try test__ucmpsi2(2147483647, 0, 2);
36 try test__ucmpsi2(2147483647, 1, 2);
37 try test__ucmpsi2(2147483647, 4294967294, 0);
38 try test__ucmpsi2(2147483647, 4294967295, 0);
39 // 9. cmp maxInt-1, {0,1,2, maxInt/2, maxInt}
40 try test__ucmpsi2(4294967294, 0, 2);
41 try test__ucmpsi2(4294967294, 1, 2);
42 try test__ucmpsi2(4294967294, 2147483647, 2);
43 try test__ucmpsi2(4294967294, 4294967295, 0);
44 // 10.cmp maxInt, {0,1,2, maxInt/2, maxInt-1}
45 try test__ucmpsi2(4294967295, 0, 2);
46 try test__ucmpsi2(4294967295, 1, 2);
47 try test__ucmpsi2(4294967295, 2147483647, 2);
48 try test__ucmpsi2(4294967295, 4294967294, 2);
49}