browser_ui_bookmarks_sidebar.js
Go to the documentation of this file.
1 /* ***** BEGIN LICENSE BLOCK *****
2  * Version: MPL 1.1/GPL 2.0/LGPL 2.1
3  *
4  * The contents of this file are subject to the Mozilla Public License Version
5  * 1.1 (the "License"); you may not use this file except in compliance with
6  * the License. You may obtain a copy of the License at
7  * http://www.mozilla.org/MPL/
8  *
9  * Software distributed under the License is distributed on an "AS IS" basis,
10  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
11  * for the specific language governing rights and limitations under the
12  * License.
13  *
14  * The Original Code is mozilla.org code.
15  *
16  * The Initial Developer of the Original Code is
17  * Mozilla Corporation.
18  * Portions created by the Initial Developer are Copyright (C) 2008
19  * the Initial Developer. All Rights Reserved.
20  *
21  * Contributor(s):
22  * Dietrich Ayala <dietrich@mozilla.com>
23  *
24  * Alternatively, the contents of this file may be used under the terms of
25  * either the GNU General Public License Version 2 or later (the "GPL"), or
26  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
27  * in which case the provisions of the GPL or the LGPL are applicable instead
28  * of those above. If you wish to allow use of your version of this file only
29  * under the terms of either the GPL or the LGPL, and not to allow others to
30  * use your version of this file under the terms of the MPL, indicate your
31  * decision by deleting the provisions above and replace them with the notice
32  * and other provisions required by the GPL or the LGPL. If you do not delete
33  * the provisions above, a recipient may use your version of this file under
34  * the terms of any one of the MPL, the GPL or the LGPL.
35  *
36  * ***** END LICENSE BLOCK ***** */
37 
38 /*
39 Tests the performance of opening the bookmarks sidebar
40 
41 */
42 
43 /*********************** begin header **********************/
45 
46 const TEST_IDENTIFIER = "ui-perf-test";
47 const TEST_SUITE = "places";
48 
49 const Cc = Components.classes;
50 const Ci = Components.interfaces;
51 const Cr = Components.results;
52 
53 var wm = Cc["@mozilla.org/appshell/window-mediator;1"].
54  getService(Ci.nsIWindowMediator);
55 var win = wm.getMostRecentWindow("navigator:browser");
56 
57 var ios = Cc["@mozilla.org/network/io-service;1"].
58  getService(Ci.nsIIOService);
59 var hs = Cc["@mozilla.org/browser/nav-history-service;1"].
60  getService(Ci.nsINavHistoryService);
61 var bs = Cc["@mozilla.org/browser/nav-bookmarks-service;1"].
62  getService(Ci.nsINavBookmarksService);
63 
64 function add_visit(aURI, aDate) {
65  var placeID = hs.addVisit(aURI,
66  aDate,
67  null, // no referrer
68  hs.TRANSITION_TYPED, // user typed in URL bar
69  false, // not redirect
70  0);
71  return placeID;
72 }
73 
74 function add_bookmark(aURI) {
75  var bId = bs.insertBookmark(bs.unfiledBookmarksFolder, aURI,
76  bs.DEFAULT_INDEX, "bookmark/" + aURI.spec);
77  return bId;
78 }
79 
80 function make_test_report(testName, result, units) {
81  return [TEST_IDENTIFIER, TEST_SUITE, testName, result, units||"ms"].join(":");
82 }
83 
84 // Each test is an obj w/ a name property and run method
85 var ptests = [];
86 
87 /*********************** end header **********************/
88 
89 const TEST_REPEAT_COUNT = 10;
90 
91 // test duration of bookmarks sidebar opening
92 ptests.push({
93  name: "open_bookmarks_sidebar",
94  times: [],
95  run: function() {
96  var self = this;
97  var start = Date.now();
98  var sb = document.getElementById("sidebar");
99  sb.addEventListener("load", function() {
100  var duration = Date.now() - start;
101  sb.removeEventListener("load", arguments.callee, true);
102  toggleSidebar("viewBookmarksSidebar", false);
103  self.times.push(duration);
104  if (self.times.length == TEST_REPEAT_COUNT)
105  self.finish();
106  else
107  self.run();
108  }, true);
109  toggleSidebar("viewBookmarksSidebar", true);
110  },
111  finish: function() {
112  this.times.sort(); // sort the scores
113  this.times.pop(); // remove worst
114  this.times.shift(); // remove best
115  var totalDuration = this.times.reduce(function(time, total){ return time + total; });
116  var avgDuration = totalDuration/this.times.length;
117  var report = make_test_report("open_bookmarks_sidebar", avgDuration);
118  ok(true, report);
119  runNextTest();
120  }
121 });
122 
123 function test() {
124  // kick off tests
125  runNextTest();
126 }
127 
128 function runNextTest() {
129  if (ptests.length > 0)
130  ptests.shift().run();
131  else
132  finish();
133 }
function start(ch)
var total
const TEST_REPEAT_COUNT
const TEST_IDENTIFIER
getService(Ci.sbIFaceplateManager)
function test()
function add_visit(aURI, aDate)
_hideDatepicker duration
function make_test_report(testName, result, units)
return null
Definition: FeedWriter.js:1143
return!aWindow arguments!aWindow arguments[0]
waitForExplicitFinish()
function runNextTest()
function add_bookmark(aURI)