| var intMin = -2147483648; |
| var intMax = 2147483647; |
| var negativeZero = -0; |
| var zero = 0; |
| |
| function testModNegativeZero() { |
| assertEq(intMin % -2147483648, -0); |
| assertEq(intMin % -1, -0); |
| assertEq(intMin % 1, -0); |
| assertEq(intMin % -2147483648, -0); |
| |
| assertEq(((intMin|0) % -2147483648)|0, 0); |
| assertEq(((intMin|0) % -1)|0, 0); |
| assertEq(((intMin|0) % 1)|0, 0); |
| assertEq(((intMin|0) % -2147483648)|0, 0); |
| } |
| |
| testModNegativeZero(); |
| testModNegativeZero(); |
| |
| function testMinModulus1() { |
| assertEq(intMin % -3, -2); |
| assertEq(intMin % 3, -2); |
| assertEq(intMin % 10, -8); |
| assertEq(intMin % 2147483647, -1); |
| |
| assertEq(((intMin|0) % -3)|0, -2); |
| assertEq(((intMin|0) % 3)|0, -2); |
| assertEq(((intMin|0) % 10)|0, -8); |
| assertEq(((intMin|0) % 2147483647)|0, -1); |
| } |
| |
| testMinModulus1(); |
| testMinModulus1(); |
| |
| function testMinModulus2() { |
| for (var i = -10; i <= 10; ++i) |
| assertEq(i % -2147483648, i); |
| assertEq(intMax % -2147483648, intMax); |
| |
| for (var i = -10; i <= 10; ++i) |
| assertEq(((i|0) % -2147483648)|0, i); |
| assertEq(((intMax|0) % -2147483648)|0, intMax); |
| } |
| |
| testMinModulus2(); |
| testMinModulus2(); |
| |
| function testDivEdgeCases() { |
| assertEq(intMin / -2147483648, 1); |
| assertEq(intMin / -1, -intMin); |
| assertEq(negativeZero / -2147483648, 0); |
| assertEq(zero / -2147483648, -0); |
| |
| assertEq(((intMin|0) / -2147483648)|0, 1); |
| assertEq(((intMin|0) / -1)|0, intMin); |
| assertEq(((negativeZero|0) / -2147483648)|0, 0); |
| assertEq(((zero|0) / -2147483648)|0, 0); |
| } |
| |
| testDivEdgeCases(); |
| testDivEdgeCases(); |