2007-05-25 17:19:18 -07:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
2007-03-22 10:30:00 -07:00
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
* http://www.mozilla.org/MPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
|
|
|
*
|
|
|
|
* The Original Code is JavaScript Engine testing utilities.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is
|
|
|
|
* Netscape Communications Corp.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 2002
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
* brendan@mozilla.org, pschwartau@netscape.com
|
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
|
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
*
|
2007-05-25 17:19:18 -07:00
|
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
|
|
|
|
/*
|
2007-03-22 10:30:00 -07:00
|
|
|
*
|
|
|
|
* Date: 28 Feb 2002
|
|
|
|
* SUMMARY: Testing that Error.stack distinguishes between:
|
|
|
|
*
|
|
|
|
* A) top-level calls: myFunc();
|
|
|
|
* B) no-name function calls: function() { myFunc();} ()
|
|
|
|
*
|
|
|
|
* The stack frame for A) should begin with '@'
|
|
|
|
* The stack frame for B) should begin with '()'
|
|
|
|
*
|
|
|
|
* This behavior was coded by Brendan during his fix for bug 127136.
|
|
|
|
* See http://bugzilla.mozilla.org/show_bug.cgi?id=127136#c13
|
|
|
|
*
|
|
|
|
* Note: our function getStackFrames(err) orders the array of stack frames
|
|
|
|
* so that the 0th element will correspond to the highest frame, i.e. will
|
|
|
|
* correspond to a line in top-level code. The 1st element will correspond
|
|
|
|
* to the function that is called first, and so on...
|
|
|
|
*
|
|
|
|
* NOTE: At present Rhino does not have an Error.stack property. It is an
|
|
|
|
* ECMA extension, see http://bugzilla.mozilla.org/show_bug.cgi?id=123177
|
|
|
|
*/
|
|
|
|
//-----------------------------------------------------------------------------
|
2007-05-25 17:19:18 -07:00
|
|
|
var gTestfile = 'errstack-001.js';
|
2007-03-22 10:30:00 -07:00
|
|
|
var UBound = 0;
|
2007-05-25 17:19:18 -07:00
|
|
|
var BUGNUMBER = '(none)';
|
2007-03-22 10:30:00 -07:00
|
|
|
var summary = 'Testing Error.stack';
|
|
|
|
var status = '';
|
|
|
|
var statusitems = [];
|
|
|
|
var actual = '';
|
|
|
|
var actualvalues = [];
|
|
|
|
var expect= '';
|
|
|
|
var expectedvalues = [];
|
|
|
|
var myErr = '';
|
|
|
|
var stackFrames = '';
|
|
|
|
|
|
|
|
|
|
|
|
function A(x,y)
|
|
|
|
{
|
|
|
|
return B(x+1,y+1);
|
|
|
|
}
|
|
|
|
|
|
|
|
function B(x,z)
|
|
|
|
{
|
|
|
|
return C(x+1,z+1);
|
|
|
|
}
|
|
|
|
|
|
|
|
function C(x,y)
|
|
|
|
{
|
|
|
|
return D(x+1,y+1);
|
|
|
|
}
|
|
|
|
|
|
|
|
function D(x,z)
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
throw new Error('meep!');
|
|
|
|
}
|
|
|
|
catch (e)
|
|
|
|
{
|
|
|
|
return e;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
myErr = A(44,13);
|
|
|
|
stackFrames = getStackFrames(myErr);
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(1);
|
|
|
|
actual = stackFrames[0].substring(0,1);
|
|
|
|
expect = '@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(2);
|
|
|
|
actual = stackFrames[1].substring(0,9);
|
|
|
|
expect = 'A(44,13)@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(3);
|
|
|
|
actual = stackFrames[2].substring(0,9);
|
|
|
|
expect = 'B(45,14)@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(4);
|
|
|
|
actual = stackFrames[3].substring(0,9);
|
|
|
|
expect = 'C(46,15)@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(5);
|
|
|
|
actual = stackFrames[4].substring(0,9);
|
|
|
|
expect = 'D(47,16)@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
myErr = A('44:foo','13:bar');
|
|
|
|
stackFrames = getStackFrames(myErr);
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(6);
|
|
|
|
actual = stackFrames[0].substring(0,1);
|
|
|
|
expect = '@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(7);
|
|
|
|
actual = stackFrames[1].substring(0,21);
|
|
|
|
expect = 'A("44:foo","13:bar")@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(8);
|
|
|
|
actual = stackFrames[2].substring(0,23);
|
|
|
|
expect = 'B("44:foo1","13:bar1")@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(9);
|
|
|
|
actual = stackFrames[3].substring(0,25);
|
|
|
|
expect = 'C("44:foo11","13:bar11")@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(10);
|
|
|
|
actual = stackFrames[4].substring(0,27);
|
|
|
|
expect = 'D("44:foo111","13:bar111")@';;
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Make the first frame occur in a function with an empty name -
|
|
|
|
*/
|
|
|
|
myErr = function() { return A(44,13); } ();
|
|
|
|
stackFrames = getStackFrames(myErr);
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(11);
|
|
|
|
actual = stackFrames[0].substring(0,1);
|
|
|
|
expect = '@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(12);
|
|
|
|
actual = stackFrames[1].substring(0,3);
|
|
|
|
expect = '()@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(13);
|
|
|
|
actual = stackFrames[2].substring(0,9);
|
|
|
|
expect = 'A(44,13)@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
// etc. for the rest of the frames as above
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Make the first frame occur in a function with name 'anonymous' -
|
|
|
|
*/
|
|
|
|
var f = Function('return A(44,13);');
|
|
|
|
myErr = f();
|
|
|
|
stackFrames = getStackFrames(myErr);
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(14);
|
|
|
|
actual = stackFrames[0].substring(0,1);
|
|
|
|
expect = '@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(15);
|
|
|
|
actual = stackFrames[1].substring(0,12);
|
|
|
|
expect = 'anonymous()@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(16);
|
|
|
|
actual = stackFrames[2].substring(0,9);
|
|
|
|
expect = 'A(44,13)@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
// etc. for the rest of the frames as above
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Make a user-defined error via the Error() function -
|
|
|
|
*/
|
|
|
|
var message = 'Hi there!'; var fileName = 'file name'; var lineNumber = 0;
|
|
|
|
myErr = Error(message, fileName, lineNumber);
|
|
|
|
stackFrames = getStackFrames(myErr);
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(17);
|
|
|
|
actual = stackFrames[0].substring(0,1);
|
|
|
|
expect = '@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Now use the |new| keyword. Re-use the same params -
|
|
|
|
*/
|
|
|
|
myErr = new Error(message, fileName, lineNumber);
|
|
|
|
stackFrames = getStackFrames(myErr);
|
2007-05-25 17:19:18 -07:00
|
|
|
status = inSection(18);
|
|
|
|
actual = stackFrames[0].substring(0,1);
|
|
|
|
expect = '@';
|
|
|
|
addThis();
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
test();
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Split the string |err.stack| along its '\n' delimiter.
|
|
|
|
* As of 2002-02-28 |err.stack| ends with the delimiter, so
|
|
|
|
* the resulting array has an empty string as its last element.
|
|
|
|
*
|
|
|
|
* Pop that useless element off before doing anything.
|
|
|
|
* Then reverse the array, for convenience of indexing -
|
|
|
|
*/
|
|
|
|
function getStackFrames(err)
|
|
|
|
{
|
|
|
|
var arr = err.stack.split('\n');
|
|
|
|
arr.pop();
|
|
|
|
return arr.reverse();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function addThis()
|
|
|
|
{
|
|
|
|
statusitems[UBound] = status;
|
|
|
|
actualvalues[UBound] = actual;
|
|
|
|
expectedvalues[UBound] = expect;
|
|
|
|
UBound++;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function test()
|
|
|
|
{
|
|
|
|
enterFunc('test');
|
2007-05-25 17:19:18 -07:00
|
|
|
printBugNumber(BUGNUMBER);
|
2007-03-22 10:30:00 -07:00
|
|
|
printStatus(summary);
|
|
|
|
|
|
|
|
for (var i=0; i<UBound; i++)
|
|
|
|
{
|
|
|
|
reportCompare(expectedvalues[i], actualvalues[i], statusitems[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
exitFunc ('test');
|
|
|
|
}
|