2008-09-09 21:08:49 -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 mozilla.org code.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is
|
|
|
|
* Mozilla Corporation.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 2008
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
* Dietrich Ayala <dietrich@mozilla.com>
|
2009-10-13 06:32:00 -07:00
|
|
|
* Marco Bonardo <mak77@bonardo.net>
|
2008-09-09 21:08:49 -07:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
|
|
|
|
/*
|
|
|
|
Tests the performance of opening the location bar dropdown.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*********************** begin header **********************/
|
|
|
|
waitForExplicitFinish();
|
|
|
|
|
|
|
|
const TEST_IDENTIFIER = "ui-perf-test";
|
|
|
|
const TEST_SUITE = "places";
|
|
|
|
|
|
|
|
const Cc = Components.classes;
|
|
|
|
const Ci = Components.interfaces;
|
|
|
|
const Cr = Components.results;
|
|
|
|
|
|
|
|
var wm = Cc["@mozilla.org/appshell/window-mediator;1"].
|
|
|
|
getService(Ci.nsIWindowMediator);
|
|
|
|
var win = wm.getMostRecentWindow("navigator:browser");
|
|
|
|
|
|
|
|
var ios = Cc["@mozilla.org/network/io-service;1"].
|
|
|
|
getService(Ci.nsIIOService);
|
|
|
|
var hs = Cc["@mozilla.org/browser/nav-history-service;1"].
|
|
|
|
getService(Ci.nsINavHistoryService);
|
|
|
|
var bs = Cc["@mozilla.org/browser/nav-bookmarks-service;1"].
|
|
|
|
getService(Ci.nsINavBookmarksService);
|
2009-10-13 06:32:00 -07:00
|
|
|
var prefs = Cc["@mozilla.org/preferences-service;1"].
|
|
|
|
getService(Ci.nsIPrefBranch);
|
|
|
|
|
|
|
|
var maxResults = prefs.getIntPref("browser.urlbar.maxRichResults");
|
|
|
|
var onSearchComplete = gURLBar.onSearchComplete;
|
2008-09-09 21:08:49 -07:00
|
|
|
|
|
|
|
function add_visit(aURI, aDate) {
|
2009-10-13 06:32:00 -07:00
|
|
|
var visitId = hs.addVisit(aURI,
|
2008-09-09 21:08:49 -07:00
|
|
|
aDate,
|
|
|
|
null, // no referrer
|
|
|
|
hs.TRANSITION_TYPED, // user typed in URL bar
|
|
|
|
false, // not redirect
|
|
|
|
0);
|
2009-10-13 06:32:00 -07:00
|
|
|
return visitId;
|
2008-09-09 21:08:49 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
function add_bookmark(aURI) {
|
|
|
|
var bId = bs.insertBookmark(bs.unfiledBookmarksFolder, aURI,
|
|
|
|
bs.DEFAULT_INDEX, "bookmark/" + aURI.spec);
|
|
|
|
return bId;
|
|
|
|
}
|
|
|
|
|
|
|
|
function make_test_report(testName, result, units) {
|
|
|
|
return [TEST_IDENTIFIER, TEST_SUITE, testName, result, units||"ms"].join(":");
|
|
|
|
}
|
|
|
|
|
|
|
|
// Each test is an obj w/ a name property and run method
|
|
|
|
var ptests = [];
|
|
|
|
|
|
|
|
/*********************** end header **********************/
|
|
|
|
|
2009-10-13 06:32:00 -07:00
|
|
|
const TEST_REPEAT_COUNT = 6;
|
|
|
|
|
|
|
|
// test duration of locationbar searching
|
2008-09-09 21:08:49 -07:00
|
|
|
ptests.push({
|
|
|
|
name: "open_locationbar_default",
|
2009-10-13 06:32:00 -07:00
|
|
|
times: [],
|
2008-09-09 21:08:49 -07:00
|
|
|
run: function() {
|
2009-10-13 06:32:00 -07:00
|
|
|
var self = this;
|
|
|
|
var start = Date.now();
|
|
|
|
var acItemsCount = 1;
|
|
|
|
gURLBar.onSearchComplete = function() {
|
|
|
|
executeSoon(function() {
|
|
|
|
var duration = Date.now() - start;
|
|
|
|
self.times.push(duration);
|
|
|
|
if (self.times.length == TEST_REPEAT_COUNT)
|
|
|
|
self.finish();
|
|
|
|
else
|
|
|
|
self.run();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
window.focus();
|
|
|
|
gURLBar.focus();
|
|
|
|
var synthesizeSearch = function() {
|
|
|
|
EventUtils.synthesizeKey("VK_BACK_SPACE", {});
|
|
|
|
EventUtils.synthesizeKey("e", {});
|
|
|
|
};
|
|
|
|
waitForFocus(synthesizeSearch);
|
|
|
|
},
|
|
|
|
finish: function() {
|
|
|
|
gURLBar.value = "";
|
|
|
|
processTestResult(this);
|
|
|
|
setTimeout(runNextTest, 0);
|
2008-09-09 21:08:49 -07:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2009-10-13 06:32:00 -07:00
|
|
|
function processTestResult(aTest) {
|
|
|
|
aTest.times.sort(); // sort the scores
|
|
|
|
aTest.times.pop(); // remove worst
|
|
|
|
aTest.times.shift(); // remove best
|
|
|
|
var totalDuration = aTest.times.reduce(function(time, total){ return time + total; });
|
|
|
|
var avgDuration = totalDuration/aTest.times.length;
|
|
|
|
var report = make_test_report(aTest.name, avgDuration);
|
|
|
|
ok(true, report);
|
|
|
|
}
|
|
|
|
|
2008-09-09 21:08:49 -07:00
|
|
|
function test() {
|
|
|
|
// kick off tests
|
2009-10-13 06:32:00 -07:00
|
|
|
setTimeout(runNextTest, 0);
|
2008-09-09 21:08:49 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
function runNextTest() {
|
|
|
|
if (ptests.length > 0)
|
|
|
|
ptests.shift().run();
|
2009-10-13 06:32:00 -07:00
|
|
|
else {
|
|
|
|
gURLBar.onSearchComplete = onSearchComplete;
|
2008-09-09 21:08:49 -07:00
|
|
|
finish();
|
2009-10-13 06:32:00 -07:00
|
|
|
}
|
2008-09-09 21:08:49 -07:00
|
|
|
}
|