blob: c2a695da4680e511224a4571b98bd2227ce213a8 [file] [log] [blame]
Ben Murdochb8a8cc12014-11-26 15:28:44 +00001// Copyright 2013 the V8 project authors. All rights reserved.
2// Copyright (C) 2005, 2006, 2007, 2008, 2009 Apple Inc. All rights reserved.
3//
4// Redistribution and use in source and binary forms, with or without
5// modification, are permitted provided that the following conditions
6// are met:
7// 1. Redistributions of source code must retain the above copyright
8// notice, this list of conditions and the following disclaimer.
9// 2. Redistributions in binary form must reproduce the above copyright
10// notice, this list of conditions and the following disclaimer in the
11// documentation and/or other materials provided with the distribution.
12//
13// THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND ANY
14// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
15// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
16// DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY
17// DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
18// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
19// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
20// ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
21// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
22// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
23
24description("This test how deep we can recurse, and that we get an exception when we do, as opposed to a stack overflow.");
25
26 function simpleRecursion(depth) {
27 if (depth)
28 simpleRecursion(depth - 1);
29 }
30
31 try {
32 simpleRecursion(17472);
33 } catch (ex) {
34 debug("FAIL: " + ex);
35 }
36
37 try {
38 simpleRecursion(10000000);
39 } catch (ex) {
40 var msg = String(eval(ex));
41 shouldBe("msg", "'RangeError: Maximum call stack size exceeded.'");
42 }
43
44 try {
45 simpleRecursion(1000000000);
46 } catch (ex) {
47 var msg = String(eval(ex));
48 shouldBe("msg", "'RangeError: Maximum call stack size exceeded.'");
49 }
50
51 var tooFewArgsDepth = 0;
52
53 function tooFewArgsRecursion(a) {
54 if (tooFewArgsDepth) {
55 tooFewArgsDepth--;
56 tooFewArgsRecursion();
57 }
58 }
59
60 try {
61 tooFewArgsDepth = 10000000;
62 tooFewArgsRecursion();
63 } catch (ex) {
64 var msg = String(eval(ex));
65 shouldBe("msg", "'RangeError: Maximum call stack size exceeded.'");
66 }
67
68 function tooManyArgsRecursion(depth) {
69 if (depth)
70 tooManyArgsRecursion(depth - 1, 1);
71 }
72
73 try {
74 tooManyArgsRecursion(10000000, 1);
75 } catch (ex) {
76 var msg = String(eval(ex));
77 shouldBe("msg", "'RangeError: Maximum call stack size exceeded.'");
78 }