michael@0: /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ michael@0: /* This Source Code Form is subject to the terms of the Mozilla Public michael@0: * License, v. 2.0. If a copy of the MPL was not distributed with this michael@0: * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ michael@0: michael@0: //----------------------------------------------------------------------------- michael@0: var BUGNUMBER = 471635; michael@0: var summary = 'TM: trace js shell print()'; michael@0: var actual = ''; michael@0: var expect = ''; michael@0: michael@0: //----------------------------------------------------------------------------- michael@0: test(); michael@0: //----------------------------------------------------------------------------- michael@0: michael@0: function test() michael@0: { michael@0: enterFunc ('test'); michael@0: printBugNumber(BUGNUMBER); michael@0: printStatus (summary); michael@0: michael@0: jit(true); michael@0: michael@0: (function(){ michael@0: for (var i = 1; i < 20; ++i) { michael@0: print("#"); michael@0: } michael@0: })(); michael@0: michael@0: var recorderStarted; michael@0: var recorderAborted; michael@0: var traceCompleted; michael@0: var skip = true; michael@0: michael@0: if (this.tracemonkey && !this.tracemonkey.adaptive) michael@0: { michael@0: recorderStarted = this.tracemonkey.recorderStarted; michael@0: recorderAborted = this.tracemonkey.recorderAborted; michael@0: traceCompleted = this.tracemonkey.traceCompleted; michael@0: skip = false; michael@0: } michael@0: michael@0: jit(false); michael@0: michael@0: if (!skip) michael@0: { michael@0: expect = 'recorderStarted=1, recorderAborted=0, traceCompleted=1'; michael@0: actual = 'recorderStarted=' + recorderStarted + ', recorderAborted=' + recorderAborted + ', traceCompleted=' + traceCompleted; michael@0: } michael@0: else michael@0: { michael@0: expect = actual = 'Test skipped due to lack of tracemonkey jitstats object.'; michael@0: } michael@0: michael@0: reportCompare(expect, actual, summary); michael@0: michael@0: exitFunc ('test'); michael@0: }