1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/js/src/tests/js1_8_1/jit/regress-462459-02.js Wed Dec 31 06:09:35 2014 +0100 1.3 @@ -0,0 +1,74 @@ 1.4 +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ 1.5 +/* This Source Code Form is subject to the terms of the Mozilla Public 1.6 + * License, v. 2.0. If a copy of the MPL was not distributed with this 1.7 + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ 1.8 + 1.9 +//----------------------------------------------------------------------------- 1.10 +var BUGNUMBER = 462459; 1.11 +var summary = 'TM: trace Array(1)'; 1.12 +var actual = ''; 1.13 +var expect = ''; 1.14 + 1.15 +printBugNumber(BUGNUMBER); 1.16 +printStatus (summary); 1.17 + 1.18 +jit(true); 1.19 + 1.20 +if (!this.tracemonkey || this.tracemonkey.adaptive) 1.21 +{ 1.22 + jit(false); 1.23 + expect = actual = 'Test skipped due to lack of tracemonkey jitstats'; 1.24 + reportCompare(expect, actual, summary); 1.25 +} 1.26 +else 1.27 +{ 1.28 + jit(true); 1.29 + 1.30 + expect = 'recorder started, recorder not aborted, trace completed'; 1.31 + actual = ''; 1.32 + 1.33 + var recorderStartedStart = this.tracemonkey.recorderStarted; 1.34 + var recorderAbortedStart = this.tracemonkey.recorderAborted; 1.35 + var traceCompletedStart = this.tracemonkey.traceCompleted; 1.36 + 1.37 + for (var i = 0; i < RUNLOOP; i++) 1.38 + { 1.39 + Array(1); 1.40 + } 1.41 + 1.42 + jit(false); 1.43 + 1.44 + var recorderStartedEnd = this.tracemonkey.recorderStarted; 1.45 + var recorderAbortedEnd = this.tracemonkey.recorderAborted; 1.46 + var traceCompletedEnd = this.tracemonkey.traceCompleted; 1.47 + 1.48 + if (recorderStartedEnd > recorderStartedStart) 1.49 + { 1.50 + actual = 'recorder started, '; 1.51 + } 1.52 + else 1.53 + { 1.54 + actual = 'recorder not started, '; 1.55 + } 1.56 + 1.57 + if (recorderAbortedEnd > recorderAbortedStart) 1.58 + { 1.59 + actual += 'recorder aborted, '; 1.60 + } 1.61 + else 1.62 + { 1.63 + actual += 'recorder not aborted, '; 1.64 + } 1.65 + 1.66 + if (traceCompletedEnd > traceCompletedStart) 1.67 + { 1.68 + actual += 'trace completed'; 1.69 + } 1.70 + else 1.71 + { 1.72 + actual += 'trace not completed'; 1.73 + } 1.74 + 1.75 + reportCompare(expect, actual, summary); 1.76 +} 1.77 +