Revision control

Copy as Markdown

Other Tools

<?xml version="1.0"?>
<!--
/* ***** 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
*
* 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
* the Mozilla Foundation.
* Portions created by the Initial Developer are Copyright (C) 2008-2009
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
* Anoop Saldanha <poonaatsoc@gmail.com> (Original Author)
* Robert Kaiser <kairo@kairo.at>
*
* 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 ***** */
/**
* This tests bug 474620 - opening a progress dialog with the "properties"
* item in the download manager.
*/
-->
<window title="Download Manager Test"
onload="runTest();"
<script>
<![CDATA[
const nsIDownloadManager = Ci.nsIDownloadManager;
var dmFile = Services.dirsvc.get("TmpD", Ci.nsIFile);
dmFile.append("dm-ui-test.file");
dmFile.createUnique(Ci.nsIFile.NORMAL_FILE_TYPE, 0666);
var gTestPath = Services.io.newFileURI(dmFile).spec;
const DoneDownloadData = [
{ name: "Dead",
target: gTestPath,
startTime: 1180493839859230,
endTime: 1180493839859239,
state: nsIDownloadManager.DOWNLOAD_CANCELED,
currBytes: 0, maxBytes: -1, preferredAction: 0, autoResume: 0 }
];
const ActiveDownloadData = [
{ name: "Patch",
target: gTestPath,
startTime: 1180493839859230,
endTime: 1180493839859239,
state: nsIDownloadManager.DOWNLOAD_DOWNLOADING,
currBytes: 0, maxBytes: -1, preferredAction: 0, autoResume: 0 }
];
function runTest()
{
var dm = Cc["@mozilla.org/download-manager;1"]
.getService(Ci.nsIDownloadManager);
var db = dm.DBConnection;
// Empty any old downloads
db.executeSimpleSQL("DELETE FROM moz_downloads");
var stmt = db.createStatement(
"INSERT INTO moz_downloads (name, source, target, startTime, endTime, " +
"state, currBytes, maxBytes, preferredAction, autoResume) " +
"VALUES (:name, :source, :target, :startTime, :endTime, :state, " +
":currBytes, :maxBytes, :preferredAction, :autoResume)");
for (let dl of DoneDownloadData) {
for (let [prop, value] of Object.entries(dl))
stmt.params[prop] = value;
stmt.execute();
}
//stmt.finalize();
// Close the UI if necessary
var win = Services.wm.getMostRecentWindow("Download:Manager");
if (win) win.close();
var obs = Cc["@mozilla.org/observer-service;1"]
.getService(Ci.nsIObserverService);
const DLMGR_UI_DONE = "download-manager-ui-done";
var dmview;
var testStartTime = Date.now();
var testPhase = 0;
var testObs = {
observe: function(aSubject, aTopic, aData) {
switch (testPhase++) {
case 0:
ok(!!aSubject.document.getElementById("dlWinCommands"),
"The download manager window is active");
// the download manager is started, select the first download
dmview = aSubject.document.getElementById("downloadTree").view;
dmview.selection.select(0);
// call "properties"
aSubject.document.getElementById("dlMenu_properties").doCommand();
break;
case 1:
ok(!!aSubject.document.getElementById("dlProgressCommands"),
"The progress dialog was called for a canceled download");
var endTimeSeconds = Math.round(DoneDownloadData[0].endTime / 1000);
is(aSubject.gEndTime, endTimeSeconds, "End time matches data");
// Close the progress window
aSubject.close();
// Populate the download manager with an active download now, and
// rebuild the list
stmt.reset();
for (let dl of ActiveDownloadData) {
for (let [prop, value] of Object.entries(dl))
stmt.params[prop] = value;
stmt.execute();
}
stmt.finalize();
dm.cleanUp();
break;
case 2:
ok(!!aSubject.document.getElementById("dlWinCommands"),
"The download manager window got an event");
// the download manager UI is rebuilt, select the first download
dmview.selection.select(0);
// call "properties"
aSubject.document.getElementById("dlMenu_properties").doCommand();
break;
case 3:
ok(!!aSubject.document.getElementById("dlProgressCommands"),
"The progress dialog was called for an active download");
// active downloads updated to current time,
// just check if it's set to later than start of the test
ok(aSubject.gEndTime >= testStartTime, "End time within test run");
// Close the progress window
aSubject.close();
obs.removeObserver(testObs, DLMGR_UI_DONE);
db.executeSimpleSQL("DELETE FROM moz_downloads");
SimpleTest.finish();
break;
}
}
};
obs.addObserver(testObs, DLMGR_UI_DONE);
Cc["@mozilla.org/download-manager-ui;1"]
.getService(Ci.nsISuiteDownloadManagerUI)
.showManager();
SimpleTest.waitForExplicitFinish();
}
]]>
</script>
<p id="display"></p>
<div id="content" style="display: none"></div>
<pre id="test"></pre>
</body>
</window>