зеркало из https://github.com/mozilla/pjs.git
Bug 414486 - Lazily load stringbundle and lazily load strings for DownloadUtils. r=sdwilsh, a1.9=schrep
This commit is contained in:
Родитель
fb17767637
Коммит
881a75e0bf
|
@ -72,8 +72,8 @@ const kDownloadProperties =
|
|||
"chrome://mozapps/locale/downloads/downloads.properties";
|
||||
|
||||
// These strings will be converted to the corresponding ones from the string
|
||||
// bundle on load
|
||||
let gStr = {
|
||||
// bundle on use
|
||||
let kStrings = {
|
||||
statusFormat: "statusFormat2",
|
||||
transferSameUnits: "transferSameUnits",
|
||||
transferDiffUnits: "transferDiffUnits",
|
||||
|
@ -90,19 +90,55 @@ let gStr = {
|
|||
timeUnits: ["seconds", "minutes", "hours", "days"],
|
||||
};
|
||||
|
||||
// Convert strings to those in the string bundle
|
||||
let (getStr = Cc["@mozilla.org/intl/stringbundle;1"].
|
||||
// This object will lazily load the strings defined in kStrings
|
||||
let gStr = {
|
||||
/**
|
||||
* Initialize lazy string getters
|
||||
*/
|
||||
_init: function()
|
||||
{
|
||||
// Make each "name" a lazy-loading string that knows how to load itself. We
|
||||
// need to locally scope name and value to keep them around for the getter.
|
||||
for (let [name, value] in Iterator(kStrings))
|
||||
let ([n, v] = [name, value])
|
||||
gStr.__defineGetter__(n, function() gStr._getStr(n, v));
|
||||
},
|
||||
|
||||
/**
|
||||
* Convert strings to those in the string bundle. This lazily loads the
|
||||
* string bundle *once* only when used the first time.
|
||||
*/
|
||||
get _getStr()
|
||||
{
|
||||
// Delete the getter to be overwritten
|
||||
delete gStr._getStr;
|
||||
|
||||
// Lazily load the bundle into the closure on first call to _getStr
|
||||
let getStr = Cc["@mozilla.org/intl/stringbundle;1"].
|
||||
getService(Ci.nsIStringBundleService).
|
||||
createBundle(kDownloadProperties).
|
||||
GetStringFromName) {
|
||||
for (let [name, value] in Iterator(gStr)) {
|
||||
GetStringFromName;
|
||||
|
||||
// _getStr is a function that sets string "name" to stringbundle's "value"
|
||||
return gStr._getStr = function(name, value) {
|
||||
// Delete the getter to be overwritten
|
||||
delete gStr[name];
|
||||
|
||||
try {
|
||||
gStr[name] = typeof value == "string" ? getStr(value) : value.map(getStr);
|
||||
// "name" is a string or array of the stringbundle-loaded "value"
|
||||
return gStr[name] = typeof value == "string" ?
|
||||
getStr(value) :
|
||||
value.map(getStr);
|
||||
} catch (e) {
|
||||
log(["Couldn't get string '", name, "' from property '", value, "'"]);
|
||||
// Don't return anything (undefined), and because we deleted ourselves,
|
||||
// future accesses will also be undefined
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
},
|
||||
};
|
||||
// Initialize the lazy string getters!
|
||||
gStr._init();
|
||||
|
||||
let DownloadUtils = {
|
||||
/**
|
||||
|
|
|
@ -21,6 +21,7 @@
|
|||
#
|
||||
# Contributor(s):
|
||||
# Shawn Wilsher <me@shawnwilsher.com> (Original Author)
|
||||
# Edward Lee <edward.lee@engineering.uiuc.edu>
|
||||
#
|
||||
# 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
|
||||
|
@ -42,6 +43,12 @@ srcdir = @srcdir@
|
|||
VPATH = @srcdir@
|
||||
include $(DEPTH)/config/autoconf.mk
|
||||
|
||||
MODULE = test_downloads
|
||||
|
||||
XPCSHELL_TESTS = \
|
||||
unit \
|
||||
$(NULL)
|
||||
|
||||
DIRS += browser
|
||||
|
||||
include $(topsrcdir)/config/rules.mk
|
||||
|
|
|
@ -0,0 +1,128 @@
|
|||
/* ***** 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 DownloadUtils Test Code.
|
||||
*
|
||||
* The Initial Developer of the Original Code is
|
||||
* Edward Lee <edward.lee@engineering.uiuc.edu>.
|
||||
* Portions created by the Initial Developer are Copyright (C) 2008
|
||||
* the Initial Developer. All Rights Reserved.
|
||||
*
|
||||
* Contributor(s):
|
||||
*
|
||||
* 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 ***** */
|
||||
|
||||
let Cu = Components.utils;
|
||||
Cu.import("resource://gre/modules/DownloadUtils.jsm");
|
||||
|
||||
// Get the em-dash character because typing it directly here doesn't work :(
|
||||
let gDash = DownloadUtils.getDownloadStatus(0)[0].match(/remaining (.) 0 bytes/)[1];
|
||||
|
||||
let gVals = [0, 100, 2345, 55555, 982341, 23194134, 1482, 58, 9921949201, 13498132];
|
||||
|
||||
function testStatus(aCurr, aMore, aRate, aTest)
|
||||
{
|
||||
dump("Status Test: " + [aCurr, aMore, aRate, aTest] + "\n");
|
||||
let curr = gVals[aCurr];
|
||||
let max = curr + gVals[aMore];
|
||||
let speed = gVals[aRate];
|
||||
|
||||
let [status, last] =
|
||||
DownloadUtils.getDownloadStatus(curr, max, speed);
|
||||
|
||||
if (0) {
|
||||
dump("testStatus(" + aCurr + ", " + aMore + ", " + aRate + ", [\"" +
|
||||
status.replace(gDash, "--") + "\", " + last.toFixed(3) + "]);\n");
|
||||
}
|
||||
|
||||
// Make sure the status text matches
|
||||
do_check_eq(status, aTest[0].replace(/--/, gDash));
|
||||
|
||||
// Make sure the lastSeconds matches
|
||||
if (last == Infinity)
|
||||
do_check_eq(last, aTest[1]);
|
||||
else
|
||||
do_check_true(Math.abs(last - aTest[1]) < .1);
|
||||
}
|
||||
|
||||
function testURI(aURI, aDisp, aHost)
|
||||
{
|
||||
dump("URI Test: " + [aURI, aDisp, aHost] + "\n");
|
||||
|
||||
let [disp, host] = DownloadUtils.getURIHost(aURI);
|
||||
|
||||
// Make sure we have the right display host and full host
|
||||
do_check_eq(disp, aDisp);
|
||||
do_check_eq(host, aHost);
|
||||
}
|
||||
|
||||
function run_test()
|
||||
{
|
||||
if (0) {
|
||||
// Help find some interesting test cases
|
||||
let r = function() Math.floor(Math.random() * 10);
|
||||
for (let i = 0; i < 100; i++) {
|
||||
testStatus(r(), r(), r());
|
||||
}
|
||||
}
|
||||
|
||||
testStatus(2, 1, 7, ["A few seconds remaining -- 2.3 of 2.4 KB (58.0 bytes/sec)", 1.724]);
|
||||
testStatus(1, 2, 6, ["A few seconds remaining -- 100 bytes of 2.4 KB (1.4 KB/sec)", 1.582]);
|
||||
testStatus(4, 3, 9, ["A few seconds remaining -- 959 KB of 1.0 MB (12.9 MB/sec)", 0.004]);
|
||||
testStatus(2, 3, 8, ["A few seconds remaining -- 2.3 of 56.5 KB (9.2 GB/sec)", 0.000]);
|
||||
|
||||
testStatus(8, 4, 3, ["17 seconds remaining -- 9.2 of 9.2 GB (54.3 KB/sec)", 17.682]);
|
||||
testStatus(1, 3, 2, ["23 seconds remaining -- 100 bytes of 54.4 KB (2.3 KB/sec)", 23.691]);
|
||||
testStatus(9, 3, 2, ["23 seconds remaining -- 12.9 of 12.9 MB (2.3 KB/sec)", 23.691]);
|
||||
testStatus(5, 6, 7, ["25 seconds remaining -- 22.1 of 22.1 MB (58.0 bytes/sec)", 25.552]);
|
||||
|
||||
testStatus(3, 9, 3, ["4 minutes remaining -- 54.3 KB of 12.9 MB (54.3 KB/sec)", 242.969]);
|
||||
testStatus(2, 3, 1, ["9 minutes remaining -- 2.3 of 56.5 KB (100 bytes/sec)", 555.550]);
|
||||
testStatus(4, 3, 7, ["15 minutes remaining -- 959 KB of 1.0 MB (58.0 bytes/sec)", 957.845]);
|
||||
testStatus(5, 3, 7, ["15 minutes remaining -- 22.1 of 22.2 MB (58.0 bytes/sec)", 957.845]);
|
||||
|
||||
testStatus(1, 9, 2, ["1 hour, 35 minutes remaining -- 100 bytes of 12.9 MB (2.3 KB/sec)", 5756.133]);
|
||||
testStatus(2, 9, 6, ["2 hours, 31 minutes remaining -- 2.3 KB of 12.9 MB (1.4 KB/sec)", 9108.051]);
|
||||
testStatus(2, 4, 1, ["2 hours, 43 minutes remaining -- 2.3 of 962 KB (100 bytes/sec)", 9823.410]);
|
||||
testStatus(6, 4, 7, ["4 hours, 42 minutes remaining -- 1.4 of 961 KB (58.0 bytes/sec)", 16936.914]);
|
||||
|
||||
testStatus(6, 9, 1, ["1 day, 13 hours remaining -- 1.4 KB of 12.9 MB (100 bytes/sec)", 134981.320]);
|
||||
testStatus(3, 8, 3, ["2 days, 1 hour remaining -- 54.3 KB of 9.2 GB (54.3 KB/sec)", 178596.872]);
|
||||
testStatus(1, 8, 6, ["77 days, 11 hours remaining -- 100 bytes of 9.2 GB (1.4 KB/sec)", 6694972.470]);
|
||||
testStatus(6, 8, 7, ["1979 days, 22 hours remaining -- 1.4 KB of 9.2 GB (58.0 bytes/sec)", 171068089.672]);
|
||||
|
||||
testStatus(0, 0, 5, ["Unknown time remaining -- 0 of 0 bytes (22.1 MB/sec)", Infinity]);
|
||||
testStatus(0, 6, 0, ["Unknown time remaining -- 0 bytes of 1.4 KB (0 bytes/sec)", Infinity]);
|
||||
testStatus(6, 6, 0, ["Unknown time remaining -- 1.4 of 2.9 KB (0 bytes/sec)", Infinity]);
|
||||
testStatus(8, 5, 0, ["Unknown time remaining -- 9.2 of 9.3 GB (0 bytes/sec)", Infinity]);
|
||||
|
||||
testURI("http://www.mozilla.org/", "mozilla.org", "www.mozilla.org");
|
||||
testURI("http://www.city.mikasa.hokkaido.jp/", "city.mikasa.hokkaido.jp", "www.city.mikasa.hokkaido.jp");
|
||||
testURI("data:text/html,Hello World", "data resource", "data resource");
|
||||
testURI("jar:http://www.mozilla.com/file!/magic", "mozilla.com", "www.mozilla.com");
|
||||
testURI("file:///C:/Cool/Stuff/", "local file", "local file");
|
||||
testURI("moz-icon:file:///test.extension", "moz-icon resource", "moz-icon resource");
|
||||
testURI("about:blank", "about resource", "about resource");
|
||||
}
|
Загрузка…
Ссылка в новой задаче