/* Any copyright is dedicated to the Public Domain. * http://creativecommons.org/publicdomain/zero/1.0/ */ /* File locked partial MAR file staged patch apply failure test */ const STATE_AFTER_STAGE = STATE_PENDING; function run_test() { if (!setupTestCommon()) { return; } gTestFiles = gTestFilesPartialSuccess; gTestDirs = gTestDirsPartialSuccess; setTestFilesAndDirsForFailure(); setupUpdaterTest(FILE_PARTIAL_MAR, false); } /** * Called after the call to setupUpdaterTest finishes. */ function setupUpdaterTestFinished() { runHelperLockFile(gTestFiles[2]); } /** * Called after the call to waitForHelperSleep finishes. */ function waitForHelperSleepFinished() { stageUpdate(true); } /** * Called after the call to stageUpdate finishes. */ function stageUpdateFinished() { checkPostUpdateRunningFile(false); // Files aren't checked after staging since this test locks a file which // prevents reading the file. checkUpdateLogContains(ERR_ENSURE_COPY); // Switch the application to the staged application that was updated. runUpdate(STATE_FAILED_READ_ERROR, false, 1, false); } /** * Called after the call to runUpdate finishes. */ function runUpdateFinished() { waitForHelperExit(); } /** * Called after the call to waitForHelperExit finishes. */ function waitForHelperExitFinished() { standardInit(); Assert.equal(readStatusFile(), STATE_NONE, "the status file failure code" + MSG_SHOULD_EQUAL); Assert.equal(gUpdateManager.updateCount, 2, "the update manager updateCount attribute" + MSG_SHOULD_EQUAL); Assert.equal(gUpdateManager.getUpdateAt(0).state, STATE_FAILED, "the update state" + MSG_SHOULD_EQUAL); Assert.equal(gUpdateManager.getUpdateAt(0).errorCode, READ_ERROR, "the update errorCode" + MSG_SHOULD_EQUAL); checkPostUpdateRunningFile(false); checkFilesAfterUpdateFailure(getApplyDirFile); checkUpdateLogContains(ERR_UNABLE_OPEN_DEST); checkUpdateLogContains(STATE_FAILED_READ_ERROR + "\n" + CALL_QUIT); checkCallbackLog(); }