toolkit/components/downloads/test/unit/test_history_expiration.js

Fri, 16 Jan 2015 18:13:44 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Fri, 16 Jan 2015 18:13:44 +0100
branch
TOR_BUG_9701
changeset 14
925c144e1f1f
permissions
-rw-r--r--

Integrate suggestion from review to improve consistency with existing code.

     1 /* This Source Code Form is subject to the terms of the Mozilla Public
     2  * License, v. 2.0. If a copy of the MPL was not distributed with this
     3  * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
     5 /**
     6  * Test bug 251337 to make sure old downloads are expired and removed.
     7  * Make sure bug 431346 and bug 431597 don't cause crashes when batching.
     8  */
    10 /**
    11  * Returns a PRTime in the past usable to add expirable visits.
    12  *
    13  * @note Expiration ignores any visit added in the last 7 days, but it's
    14  *       better be safe against DST issues, by going back one day more.
    15  */
    16 function getExpirablePRTime() {
    17   let dateObj = new Date();
    18   // Normalize to midnight
    19   dateObj.setHours(0);
    20   dateObj.setMinutes(0);
    21   dateObj.setSeconds(0);
    22   dateObj.setMilliseconds(0);
    23   dateObj = new Date(dateObj.getTime() - 8 * 86400000);
    24   return dateObj.getTime() * 1000;
    25 }
    27 function run_test()
    28 {
    29   if (oldDownloadManagerDisabled()) {
    30     return;
    31   }
    33   run_next_test();
    34 }
    36 add_task(function test_execute()
    37 {
    38   // Like the code, we check to see if nav-history-service exists
    39   // (i.e MOZ_PLACES is enabled), so that we don't run this test if it doesn't.
    40   if (!("@mozilla.org/browser/nav-history-service;1" in Cc))
    41     return;
    43   let dm = Cc["@mozilla.org/download-manager;1"].
    44            getService(Ci.nsIDownloadManager);
    45   let db = dm.DBConnection;
    47   // Empty any old downloads
    48   db.executeSimpleSQL("DELETE FROM moz_downloads");
    50   let stmt = db.createStatement(
    51     "INSERT INTO moz_downloads (id, source, target, state, guid) " +
    52     "VALUES (?1, ?2, ?3, ?4, ?5)");
    54   let iosvc = Cc["@mozilla.org/network/io-service;1"].
    55               getService(Ci.nsIIOService);
    56   let theId = 1337;
    57   let theURI = iosvc.newURI("http://expireme/please", null, null);
    58   let theGUID = "a1bcD23eF4g5";
    60   try {
    61     // Add a download from the URI
    62     stmt.bindByIndex(0, theId);
    63     stmt.bindByIndex(1, theURI.spec);
    65     // Give a dummy file name
    66     let file = Cc["@mozilla.org/file/directory_service;1"].
    67                getService(Ci.nsIProperties).get("TmpD", Ci.nsIFile);
    68     file.append("expireTest");
    69     stmt.bindByIndex(2, Cc["@mozilla.org/network/io-service;1"].
    70       getService(Ci.nsIIOService).newFileURI(file).spec);
    72     // Give it some state
    73     stmt.bindByIndex(3, dm.DOWNLOAD_FINISHED);
    75     stmt.bindByIndex(4, theGUID);
    77     // Add it!
    78     stmt.execute();
    79   }
    80   finally {
    81     stmt.reset();
    82     stmt.finalize();
    83   }
    85   // Add an expirable visit to this download.
    86   let histsvc = Cc["@mozilla.org/browser/nav-history-service;1"].
    87                 getService(Ci.nsINavHistoryService);
    88   yield promiseAddVisits({uri: theURI, visitDate: getExpirablePRTime(),
    89                           transition: histsvc.TRANSITION_DOWNLOAD});
    91   // Get the download manager as history observer and batch expirations
    92   let histobs = dm.QueryInterface(Ci.nsINavHistoryObserver);
    93   histobs.onBeginUpdateBatch();
    95   // Look for the removed download notification
    96   let obs = Cc["@mozilla.org/observer-service;1"].
    97             getService(Ci.nsIObserverService);
    98   const kRemoveTopic = "download-manager-remove-download-guid";
    99   let testObs = {
   100     observe: function(aSubject, aTopic, aData) {
   101       if (aTopic != kRemoveTopic)
   102         return;
   104       // Make sure the removed/expired download was the one we added
   105       let id = aSubject.QueryInterface(Ci.nsISupportsCString);
   106       do_check_eq(id.data, theGUID);
   108       // We're done!
   109       histobs.onEndUpdateBatch();
   110       obs.removeObserver(testObs, kRemoveTopic);
   111       do_test_finished();
   112     }
   113   };
   114   obs.addObserver(testObs, kRemoveTopic, false);
   116   // Set expiration stuff to 0 to make the download expire
   117   Services.prefs.setIntPref("places.history.expiration.max_pages", 0);
   119   // Force a history expiration.
   120   let expire = Cc["@mozilla.org/places/expiration;1"].getService(Ci.nsIObserver);
   121   expire.observe(null, "places-debug-start-expiration", -1);
   123   // Expiration happens on a timeout, about 3.5s after we set the pref
   124   do_test_pending();
   125 });

mercurial