// Test some double-truncation edge cases with parseInt(double).

function testPos1() {
    with({}) {}
    var fun = d => parseInt(d);
    for (var i = 0; i < 2000; i++) {
        assertEq(fun(i + 0.5), i);
    }
    assertEq(fun(0xf_ffff_ffff) + 345, 68719477080);
}
testPos1();

function testPos2() {
    with({}) {}
    var fun = d => parseInt(d);
    for (var i = 0; i < 2000; i++) {
        assertEq(fun(i + 0.5), i);
    }
    assertEq(fun(0x8000_0000) + 345, 2147483993);
}
testPos2();

function testNeg1() {
    with({}) {}
    var fun = d => parseInt(d);
    for (var i = 0; i < 2000; i++) {
        assertEq(fun(i + 0.5), i);
    }
    assertEq(fun(-0xf_ffff_ffff) - 345, -68719477080);
}
testNeg1();

function testNeg2() {
    with({}) {}
    var fun = d => parseInt(d);
    for (var i = 0; i < 2000; i++) {
        assertEq(fun(i + 0.5), i);
    }
    assertEq(fun(-0x8000_0001) - 345, -2147483994);
}
testNeg2();