mirror of https://github.com/tc39/test262.git
Add tests for tail-call optimization
ECMAScript 2015 introduced tail call optimization for function calls occuring in a number of positions in the grammar. Assert expected behavior by triggering a large (but configurable) number of recursive function calls in these positions. Compliant runtimes will execute such programs without error; non-compliant runtimes are expected to fail these tests by throwing an error or crashing when system resources are exhausted.
This commit is contained in:
parent
fbad34959f
commit
4dc81d3788
|
@ -0,0 +1,4 @@
|
|||
// This defines the number of consecutive recursive function calls that must be
|
||||
// made in order to prove that stack frames are properly destroyed according to
|
||||
// ES2015 tail call optimization semantics.
|
||||
var $MAX_ITERATIONS = 100000;
|
|
@ -0,0 +1,20 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Expression is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
function getF() { return f; }
|
||||
return getF()(n - 1);
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Expression is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
return f(n - 1);
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Expression is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
return 0, f(n - 1);
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Expression is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
return true ? f(n - 1) : 0;
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Expression is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
return false ? 0 : f(n - 1);
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Expression is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
return true && f(n - 1);
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Expression is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
return false || f(n - 1);
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,25 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Expression is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
(function() {
|
||||
var finished = false;
|
||||
function getF() {
|
||||
return f;
|
||||
}
|
||||
function f(_, n) {
|
||||
if (n === 0) {
|
||||
finished = true;
|
||||
return;
|
||||
}
|
||||
return getF()`${n-1}`;
|
||||
}
|
||||
f(null, $MAX_ITERATIONS);
|
||||
return finished;
|
||||
}());
|
|
@ -0,0 +1,22 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Expression is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
(function() {
|
||||
var finished = false;
|
||||
function f(_, n) {
|
||||
if (n === 0) {
|
||||
finished = true;
|
||||
return;
|
||||
}
|
||||
return f`${n-1}`;
|
||||
}
|
||||
f(null, $MAX_ITERATIONS);
|
||||
return finished;
|
||||
}());
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Expression is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
return (f(n - 1));
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
{ void 0; return f(n - 1); }
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
{ return f(n - 1); }
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,21 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
do {
|
||||
return f(n - 1);
|
||||
} while (false)
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,21 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
for (const x = 0; ;) {
|
||||
return f(n - 1);
|
||||
}
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,21 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
for (let x = 0; ;) {
|
||||
return f(n - 1);
|
||||
}
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,22 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
var x;
|
||||
for (x = 0; x < 1; ++x) {
|
||||
return f(n - 1);
|
||||
}
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,21 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
for (var x = 0; ;) {
|
||||
return f(n - 1);
|
||||
}
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
if (false) { } else { return f(n - 1); }
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
if (true) { return f(n - 1); }
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
test262: return f(n - 1);
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Expression within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
return f(n - 1);
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
switch(0) { case 0: return f(n - 1); default: }
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
switch(0) { case 0: return f(n - 1); }
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,19 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
switch(0) { default: return f(n - 1); }
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,21 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
try { } catch (err) { } finally {
|
||||
return f(n - 1);
|
||||
}
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,23 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
try {
|
||||
throw null;
|
||||
} catch (err) {
|
||||
return f(n - 1);
|
||||
}
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,21 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
try { } finally {
|
||||
return f(n - 1);
|
||||
}
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
|
@ -0,0 +1,21 @@
|
|||
// Copyright (C) 2016 the V8 project authors. All rights reserved.
|
||||
// This code is governed by the BSD license found in the LICENSE file.
|
||||
/*---
|
||||
description: Statement within statement is a candidate for tail-call optimization.
|
||||
id: static-semantics-hasproductionintailposition
|
||||
flags: [onlyStrict]
|
||||
features: [tail-call-optimization]
|
||||
includes: [tco-helper.js]
|
||||
---*/
|
||||
|
||||
var callCount = 0;
|
||||
(function f(n) {
|
||||
if (n === 0) {
|
||||
callCount += 1
|
||||
return;
|
||||
}
|
||||
while (true) {
|
||||
return f(n - 1);
|
||||
}
|
||||
}($MAX_ITERATIONS));
|
||||
assert.sameValue(callCount, 1);
|
Loading…
Reference in New Issue