gecko/js/src/trace-test.js

568 lines
11 KiB
JavaScript
Raw Normal View History

var testName = null;
if ("arguments" in this && arguments.length > 0)
testName = arguments[0];
2008-07-17 01:58:34 -07:00
var fails = [], passes=[];
function test(f)
{
if (!testName || testName == f.name)
check(f.name, f(), f.expected);
}
function check(desc, actual, expected)
{
2008-07-17 01:58:34 -07:00
if (expected == actual) {
passes.push(desc);
return print(desc, ": passed");
2008-07-17 01:58:34 -07:00
}
fails.push(desc);
print(desc, ": FAILED: expected", typeof(expected), "(", expected, ") != actual",
typeof(actual), "(", actual, ")");
}
function ifInsideLoop()
{
2008-07-18 08:01:51 -07:00
var cond = true, intCond = 5, count = 0;
for (var i = 0; i < 100; i++) {
if (cond)
count++;
2008-07-18 08:01:51 -07:00
if (intCond)
count++;
}
return count;
}
ifInsideLoop.expected = 200;
test(ifInsideLoop);
function bitwiseAnd_inner(bitwiseAndValue) {
for (var i = 0; i < 60000; i++)
bitwiseAndValue = bitwiseAndValue & i;
return bitwiseAndValue;
}
function bitwiseAnd()
{
return bitwiseAnd_inner(12341234);
}
bitwiseAnd.expected = 0;
test(bitwiseAnd);
if (!testName || testName == "bitwiseGlobal") {
bitwiseAndValue = Math.pow(2,32);
for (var i = 0; i < 60000; i++)
bitwiseAndValue = bitwiseAndValue & i;
check("bitwiseGlobal", bitwiseAndValue, 0);
}
2008-07-09 18:09:11 -07:00
function equalInt()
{
2008-07-13 19:33:08 -07:00
var i1 = 55;
var hits = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];
for (var i = 0; i < 5000; i++) {
2008-07-13 19:33:08 -07:00
if (i1 == 55) hits[0]++;
if (i1 != 56) hits[1]++;
if (i1 < 56) hits[2]++;
if (i1 > 50) hits[3]++;
if (i1 <= 60) hits[4]++;
if (i1 >= 30) hits[5]++;
if (i1 == 7) hits[6]++;
if (i1 != 55) hits[7]++;
if (i1 < 30) hits[8]++;
if (i1 > 90) hits[9]++;
if (i1 <= 40) hits[10]++;
if (i1 >= 70) hits[11]++;
}
2008-07-13 19:33:08 -07:00
return hits.toString();
}
equalInt.expected = "5000,5000,5000,5000,5000,5000,0,0,0,0,0,0,0,0,0,0,0,0,0";
test(equalInt);
2008-07-13 19:33:08 -07:00
var a;
function setelem()
{
a = [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0];
a = a.concat(a, a, a);
var l = a.length;
for (var i = 0; i < l; i++) {
a[i] = i;
}
2008-07-13 19:33:08 -07:00
return a.toString();
}
setelem.expected = "0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83";
test(setelem);
function getelem_inner(a)
{
var accum = 0;
var l = a.length;
for (var i = 0; i < l; i++) {
accum += a[i];
}
return accum;
}
function getelem()
{
return getelem_inner(a);
}
getelem.expected = 3486;
test(getelem);
globalName = 907;
function name()
{
var a = 0;
for (var i = 0; i < 100; i++)
a = globalName;
return a;
}
name.expected = 907;
test(name);
var globalInt = 0;
if (!testName || testName == "globalGet") {
for (var i = 0; i < 500; i++)
globalInt = globalName + i;
check("globalGet", globalInt, globalName + 499);
}
if (!testName || testName == "globalSet") {
for (var i = 0; i < 500; i++)
globalInt = i;
check("globalSet", globalInt, 499);
}
function arith()
{
var accum = 0;
for (var i = 0; i < 100; i++) {
accum += (i * 2) - 1;
}
return accum;
}
arith.expected = 9800;
test(arith);
function lsh_inner(n)
{
var r;
for (var i = 0; i < 35; i++)
r = 0x1 << n;
return r;
}
function lsh()
{
return [lsh_inner(15),lsh_inner(55),lsh_inner(1),lsh_inner(0)];
}
lsh.expected = "32768,8388608,2,1";
test(lsh);
function rsh_inner(n)
{
var r;
for (var i = 0; i < 35; i++)
r = 0x11010101 >> n;
return r;
}
function rsh()
{
return [rsh_inner(8),rsh_inner(5),rsh_inner(35),rsh_inner(-1)];
}
rsh.expected = "1114369,8914952,35659808,0";
test(rsh);
function ursh_inner(n)
{
var r;
for (var i = 0; i < 35; i++)
r = -55 >>> n;
return r;
}
function ursh() {
return [ursh_inner(8),ursh_inner(33),ursh_inner(0),ursh_inner(1)];
}
ursh.expected = "16777215,2147483620,4294967241,2147483620";
test(ursh);
2008-07-11 14:47:51 -07:00
function doMath_inner(cos)
{
var s = 0;
2008-07-15 20:37:57 -07:00
var sin = Math.sin;
for (var i = 0; i < 200; i++)
2008-07-15 20:37:57 -07:00
s = -Math.pow(sin(i) + cos(i * 0.75), 4);
return s;
}
function doMath() {
return doMath_inner(Math.cos);
}
doMath.expected = -0.5405549555611059;
test(doMath);
2008-07-11 14:47:51 -07:00
function fannkuch() {
var count = Array(8);
var r = 8;
2008-07-11 14:47:51 -07:00
var done = 0;
while (done < 40) {
// write-out the first 30 permutations
done += r;
while (r != 1) { count[r - 1] = r; r--; }
while (true) {
count[r] = count[r] - 1;
if (count[r] > 0) break;
r++;
}
}
return done;
}
fannkuch.expected = 41;
test(fannkuch);
2008-07-15 10:17:51 -07:00
function xprop()
{
a = 0;
for (var i = 0; i < 20; i++)
a += 7;
return a;
}
xprop.expected = 140;
test(xprop);
2008-07-15 10:17:51 -07:00
var a = 2;
function getprop_inner(o2)
2008-07-15 10:17:51 -07:00
{
var o = {a:5};
var t = this;
2008-07-15 10:17:51 -07:00
var x = 0;
for (var i = 0; i < 20; i++) {
t = this;
x += o.a + o2.a + this.a + t.a;
}
2008-07-15 10:17:51 -07:00
return x;
}
function getprop() {
return getprop_inner({a:9});
}
getprop.expected = 360;
test(getprop);
2008-07-15 20:19:29 -07:00
function mod()
{
var mods = [-1,-1,-1,-1];
var a = 9.5, b = -5, c = 42, d = (1/0);
for (var i = 0; i < 20; i++) {
mods[0] = a % b;
mods[1] = b % 1;
mods[2] = c % d;
mods[3] = c % a;
mods[4] = b % 0;
}
return mods.toString();
}
mod.expected = "4.5,0,42,4,NaN";
test(mod);
2008-07-16 15:26:51 -07:00
function glob_f1() {
return 1;
}
function glob_f2() {
return glob_f1();
}
2008-07-16 15:26:51 -07:00
function call()
{
2008-07-16 22:08:59 -07:00
var q1 = 0, q2 = 0, q3 = 0, q4 = 0, q5 = 0;
2008-07-16 15:53:04 -07:00
var o = {};
2008-07-16 15:26:51 -07:00
function f1() {
return 1;
}
function f2(f) {
2008-07-16 22:08:59 -07:00
return f();
}
2008-07-16 15:53:04 -07:00
o.f = f1;
2008-07-16 15:26:51 -07:00
for (var i = 0; i < 100; ++i) {
q1 += f1();
q2 += f2(f1);
q3 += glob_f1();
2008-07-16 15:53:04 -07:00
q4 += o.f();
2008-07-16 22:08:59 -07:00
q5 += glob_f2();
2008-07-17 01:58:34 -07:00
}
2008-07-16 22:08:59 -07:00
var ret = [q1, q2, q3, q4, q5];
2008-07-16 15:26:51 -07:00
return ret;
}
call.expected = "100,100,100,100,100";
test(call);
function setprop()
{
var obj = { a:-1 };
var obj2 = { b:-1, a:-1 };
for (var i = 0; i < 20; i++) {
obj2.b = obj.a = i;
}
return [obj.a, obj2.a, obj2.b].toString();
}
setprop.expected = "19,-1,19";
test(setprop);
2008-07-17 02:03:56 -07:00
function testif() {
var q = 0;
for (var i = 0; i < 100; i++) {
if ((i & 1) == 0)
q++;
else
q--;
}
return q;
}
testif.expected = "0";
test(testif);
function testincops(n) {
var i = 0, o = {p:0}, a = [0];
n = 100;
for (i = 0; i < n; i++);
while (i-- > 0);
for (i = 0; i < n; ++i);
while (--i >= 0);
for (o.p = 0; o.p < n; o.p++);
while (o.p-- > 0);
for (o.p = 0; o.p < n; ++o.p);
while (--o.p >= 0);
++i; // set to 0
for (a[i] = 0; a[i] < n; a[i]++);
while (a[i]-- > 0);
for (a[i] = 0; a[i] < n; ++a[i]);
while (--a[i] >= 0);
return [++o.p, ++a[i]].toString();
}
testincops.expected = "0,0";
test(testincops);
2008-07-25 19:10:23 -07:00
function trees() {
var i = 0, o = [0,0,0];
2008-07-25 19:10:23 -07:00
for (i = 0; i < 100; ++i) {
if ((i & 1) == 0) o[0]++;
else if ((i & 2) == 0) o[1]++;
else o[2]++;
}
return o;
}
trees.expected = "50,25,25";
test(trees);
2008-07-25 19:10:23 -07:00
function unboxint() {
var q = 0;
var o = [4];
for (var i = 0; i < 100; ++i)
q = o[0] << 1;
return q;
}
unboxint.expected = "8";
test(unboxint);
function strings()
{
var a = [], b = -1;
var s = "abcdefghij", s2 = "a";
var f = "f";
var c = 0, d = 0, e = 0, g = 0;
for (var i = 0; i < 10; i++) {
a[i] = (s.substring(i, i+1) + s[i] + String.fromCharCode(s2.charCodeAt(0) + i)).concat(i);
if (s[i] == f)
c++;
if (s[i] != 'b')
d++;
if ("B" > s2)
g++; // f already used
if (s2 < "b")
e++;
b = s.length;
}
return a.toString() + b + c + d + e + g;
}
strings.expected = "aaa0,bbb1,ccc2,ddd3,eee4,fff5,ggg6,hhh7,iii8,jjj91019100";
test(strings);
function stringConvert()
{
var a = [];
var s1 = "F", s2 = "1.3", s3 = "5";
for (var i = 0; i < 10; i++) {
a[0] = 1 >> s1;
a[1] = 10 - s2;
a[2] = 15 * s3;
a[3] = s3 | 32;
// a[4] = s2 + 60;
// a[5] = 9 + s3;
// a[6] = -s3;
a[7] = s3 & "7";
// a[8] = ~s3;
}
return a.toString();
}
stringConvert.expected = "1,8.7,75,37,,,,5";
test(stringConvert);
function orTestHelper(a, b, n)
{
var k = 0;
for (var i = 0; i < n; i++) {
if (a || b)
k += i;
}
return k;
}
function andTestHelper(a, b, n)
{
var k = 0;
for (var i = 0; i < n; i++) {
if (a && b)
k += i;
}
return k;
}
if (!testName || testName == "truthies") {
(function () {
var opsies = ["||", "&&"];
var falsies = [null, undefined, false, NaN, 0, ""];
var truthies = [{}, true, 1, 42, 1/0, -1/0, "blah"];
var boolies = [falsies, truthies];
// The for each here should abort tracing, so that this test framework
// relies only on the interpreter while the orTestHelper and andTestHelper
// functions get trace-JITed.
for each (var op in opsies) {
for (var i in boolies) {
for (var j in boolies[i]) {
var x = uneval(boolies[i][j]);
for (var k in boolies) {
for (var l in boolies[k]) {
var y = uneval(boolies[k][l]);
var prefix = (op == "||") ? "or" : "and";
var f = new Function("return " + prefix + "TestHelper(" + x + "," + y + ",10)");
f.name = prefix + "Test(" + x + "," + y + ")";
f.expected = eval(x + op + y) ? 45 : 0;
test(f);
}
}
}
}
}
})();
}
function nonEmptyStack1Helper(o, farble) {
var a = [];
var j = 0;
for (var i in o)
a[j++] = i;
2008-08-06 17:44:39 -07:00
return a.join("");
}
function nonEmptyStack1() {
2008-08-06 17:44:39 -07:00
return nonEmptyStack1Helper({a:1,b:2,c:3,d:4,e:5,f:6,g:7,h:8}, "hi");
}
nonEmptyStack1.expected = "abcdefgh";
2008-08-06 17:44:39 -07:00
test(nonEmptyStack1);
function nonEmptyStack2()
{
var a = 0;
for (var c in {a:1, b:2, c:3}) {
for (var i = 0; i < 10; i++)
a += i;
}
return String(a);
}
nonEmptyStack2.expected = "135";
test(nonEmptyStack2);
function arityMismatchMissingArg(arg)
{
for (var a = 0, i = 1; i < 10000; i *= 2) {
a += i;
}
return a;
}
arityMismatchMissingArg.expected = 16383;
test(arityMismatchMissingArg);
function arityMismatchExtraArg()
{
return arityMismatchMissingArg(1, 2);
}
arityMismatchExtraArg.expected = 16383;
test(arityMismatchExtraArg);
function MyConstructor(i)
{
this.i = i;
}
MyConstructor.prototype.toString = function() {return this.i + ""};
function NewTest()
{
var a = [];
for (var i = 0; i < 10; i++)
a[i] = new MyConstructor(i);
return a.join("");
}
NewTest.expected = "0123456789";
test(NewTest);
function ShapelessArgCalleeLoop(f, a)
{
for (var i = 0; i < 10; i++)
f(i, a);
}
function ShapelessVarCalleeLoop(f, a)
{
var g = f;
for (var i = 0; i < 10; i++)
g(i, a);
}
function ShapelessLetCalleeLoop(f, a)
{
for (var i = 0; i < 10; i++) {
let g = f;
g(i, a);
}
}
function ShapelessUnknownCalleeLoop(f, g, a)
{
for (var i = 0; i < 10; i++) {
(f || g)(i, a);
f = null;
}
}
function ShapelessCalleeTest()
{
var a = [];
ShapelessArgCalleeLoop(function (i, a) a[i] = i, a);
ShapelessVarCalleeLoop(function (i, a) a[10 + i] = i, a);
ShapelessLetCalleeLoop(function (i, a) a[20 + i] = i, a);
ShapelessUnknownCalleeLoop(null, function (i, a) a[30 + i] = i, a);
try {
ShapelessUnknownCalleeLoop(null, {hack: 42}, a);
} catch (e) {
if (e + "" != "TypeError: g is not a function")
print("ShapelessUnknownCalleeLoop: unexpected exception " + e);
}
return a.join("");
}
ShapelessCalleeTest.expected = "0123456789012345678901234567890123456789";
test(ShapelessCalleeTest);
/* Keep these at the end so that we can see the summary after the trace-debug spew. */
print("\npassed:", passes.length && passes.join(","));
print("\nFAILED:", fails.length && fails.join(","));