test262/implementation-contributed/javascriptcore/stress/mutual-tail-call-no-stack-overflow.js
test262-automation e9a5a7f918 [javascriptcore-test262-automation] changes from git@github.com:WebKit/webkit.git at sha 949e26452cfa153a7f4afe593da97e2fe9e1b706 on Tue Jul 03 2018 14:35:15 GMT-0400 (Eastern Daylight Time) (#1620)
* [javascriptcore-test262-automation] changes from git@github.com:WebKit/webkit.git at sha 949e26452cfa153a7f4afe593da97e2fe9e1b706 on Tue Jul 03 2018 14:35:15 GMT-0400 (Eastern Daylight Time)
2018-07-03 15:59:58 -04:00

74 lines
1.3 KiB
JavaScript

//@ defaultNoSamplingProfilerRun
function shouldThrow(func, errorMessage) {
var errorThrown = false;
var error = null;
try {
func();
} catch (e) {
errorThrown = true;
error = e;
}
if (!errorThrown)
throw new Error('not thrown');
if (String(error) !== errorMessage)
throw new Error(`bad error: ${String(error)}`);
}
function sloppyCountdown(n) {
function even(n) {
if (n == 0)
return n;
return odd(n - 1);
}
function odd(n) {
if (n == 1)
return n;
return even(n - 1);
}
if (n % 2 === 0)
return even(n);
else
return odd(n);
}
function strictCountdown(n) {
"use strict";
function even(n) {
if (n == 0)
return n;
return odd(n - 1);
}
function odd(n) {
if (n == 1)
return n;
return even(n - 1);
}
if (n % 2 === 0)
return even(n);
else
return odd(n);
}
shouldThrow(function () { sloppyCountdown(100000); }, "RangeError: Maximum call stack size exceeded.");
strictCountdown(100000);
// Parity alterning
function odd(n) {
"use strict";
if (n > 0)
return even(n, 0);
}
function even(n) {
"use strict";
return odd(n - 1);
}
odd(100000);