1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/toolkit/mozapps/update/tests/unit_base_updater/marFileLockedFailureComplete_win.js Wed Dec 31 06:09:35 2014 +0100 1.3 @@ -0,0 +1,46 @@ 1.4 +/* Any copyright is dedicated to the Public Domain. 1.5 + * http://creativecommons.org/publicdomain/zero/1.0/ 1.6 + */ 1.7 + 1.8 +/* File locked complete MAR file patch apply failure test */ 1.9 + 1.10 +function run_test() { 1.11 + setupTestCommon(); 1.12 + gTestFiles = gTestFilesCompleteSuccess; 1.13 + gTestDirs = gTestDirsCompleteSuccess; 1.14 + setTestFilesAndDirsForFailure(); 1.15 + setupUpdaterTest(FILE_COMPLETE_MAR, false, false); 1.16 + 1.17 + // Exclusively lock an existing file so it is in use during the update. 1.18 + let helperBin = getTestDirFile(FILE_HELPER_BIN); 1.19 + let helperDestDir = getApplyDirFile("a/b/"); 1.20 + helperBin.copyTo(helperDestDir, FILE_HELPER_BIN); 1.21 + helperBin = getApplyDirFile("a/b/" + FILE_HELPER_BIN); 1.22 + // Strip off the first two directories so the path has to be from the helper's 1.23 + // working directory. 1.24 + let lockFileRelPath = gTestFiles[3].relPathDir.split("/"); 1.25 + lockFileRelPath = lockFileRelPath.slice(2); 1.26 + lockFileRelPath = lockFileRelPath.join("/") + "/" + gTestFiles[3].fileName; 1.27 + let args = [getApplyDirPath() + "a/b/", "input", "output", "-s", 1.28 + HELPER_SLEEP_TIMEOUT, lockFileRelPath]; 1.29 + let lockFileProcess = AUS_Cc["@mozilla.org/process/util;1"]. 1.30 + createInstance(AUS_Ci.nsIProcess); 1.31 + lockFileProcess.init(helperBin); 1.32 + lockFileProcess.run(false, args, args.length); 1.33 + 1.34 + do_timeout(TEST_HELPER_TIMEOUT, waitForHelperSleep); 1.35 +} 1.36 + 1.37 +function doUpdate() { 1.38 + runUpdate(1, STATE_FAILED_WRITE_ERROR); 1.39 +} 1.40 + 1.41 +function checkUpdateApplied() { 1.42 + setupHelperFinish(); 1.43 +} 1.44 + 1.45 +function checkUpdate() { 1.46 + checkFilesAfterUpdateFailure(); 1.47 + checkUpdateLogContains(ERR_RENAME_FILE); 1.48 + checkCallbackAppLog(); 1.49 +}