Index: test/webkit/stack-overflow-catch.js |
diff --git a/test/webkit/concat-while-having-a-bad-time.js b/test/webkit/stack-overflow-catch.js |
similarity index 58% |
copy from test/webkit/concat-while-having-a-bad-time.js |
copy to test/webkit/stack-overflow-catch.js |
index dfda1e08a0b36194b787a44ee12a9693acd8aeaf..440148eb659f0792d0df86620a83630aa3253108 100644 |
--- a/test/webkit/concat-while-having-a-bad-time.js |
+++ b/test/webkit/stack-overflow-catch.js |
@@ -21,11 +21,56 @@ |
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
-description( |
-"Tests the behavior of Array.prototype.concat while the array is having a bad time due to one of the elements we are concatenating." |
-); |
+description('Test that when the stack overflows, the exception goes to the last frame before the overflow'); |
-Object.defineProperty(Array.prototype, 0, { writable: false }); |
-shouldBe("[42].concat()", "[42]"); |
+var level = 0; |
+var stackLevel = 0; |
+var gotWrongCatch = false; |
+function test1() |
+{ |
+ var myLevel = level; |
+ var dummy; |
+ try { |
+ level = level + 1; |
+ // Dummy code to make this funciton different from test2() |
+ dummy = level * level + 1; |
+ if (dummy == 0) |
+ debug('Should never get here!!!!'); |
+ } catch(err) { |
+ gotWrongCatch = true; |
+ } |
+ |
+ try { |
+ test2(); |
+ } catch(err) { |
+ stackLevel = myLevel; |
+ } |
+} |
+ |
+function test2() |
+{ |
+ var myLevel = level; |
+ |
+ // Dummy code to make this funciton different from test1() |
+ if (gotWrongCatch) |
+ debug('Should never get here!!!!'); |
+ |
+ try { |
+ level = level + 1; |
+ } catch(err) { |
+ gotWrongCatch = true; |
+ } |
+ |
+ try { |
+ test1(); |
+ } catch(err) { |
+ stackLevel = myLevel; |
+ } |
+} |
+ |
+test1(); |
+ |
+shouldBeFalse("gotWrongCatch"); |
+shouldBe("(stackLevel)", "(level - 1)"); |