/* Any copyright is dedicated to the Public Domain. * http://creativecommons.org/publicdomain/zero/1.0/ */ /** * Test applying an update by staging an update and launching an application to * apply it. */ const STATE_AFTER_STAGE = IS_SERVICE_TEST ? STATE_APPLIED_SVC : STATE_APPLIED; function run_test() { if (!setupTestCommon()) { return; } gTestFiles = gTestFilesCompleteSuccess; gTestDirs = gTestDirsCompleteSuccess; setupUpdaterTest(FILE_COMPLETE_MAR, undefined); } /** * Called after the call to setupUpdaterTest finishes. */ function setupUpdaterTestFinished() { stageUpdate(true); } /** * Called after the call to stageUpdate finishes. */ function stageUpdateFinished() { checkPostUpdateRunningFile(false); checkFilesAfterUpdateSuccess(getStageDirFile, true, false); checkUpdateLogContents(LOG_COMPLETE_SUCCESS, true); lockDirectory(getAppBaseDir().path); // Switch the application to the staged application that was updated. runUpdateUsingApp(STATE_SUCCEEDED); } /** * Called after the call to runUpdateUsingApp finishes. */ function runUpdateFinished() { checkPostUpdateAppLog(); } /** * Called after the call to checkPostUpdateAppLog finishes. */ function checkPostUpdateAppLogFinished() { checkAppBundleModTime(); standardInit(); Assert.equal(readStatusState(), STATE_NONE, "the status file state" + MSG_SHOULD_EQUAL); Assert.ok(!gUpdateManager.activeUpdate, "the active update should not be defined"); Assert.equal(gUpdateManager.updateCount, 1, "the update manager updateCount attribute" + MSG_SHOULD_EQUAL); Assert.equal(gUpdateManager.getUpdateAt(0).state, STATE_SUCCEEDED, "the update state" + MSG_SHOULD_EQUAL); checkPostUpdateRunningFile(true); checkFilesAfterUpdateSuccess(getApplyDirFile); checkUpdateLogContents(LOG_COMPLETE_SUCCESS); let updatesDir = getUpdatesPatchDir(); Assert.ok(updatesDir.exists(), MSG_SHOULD_EXIST + getMsgPath(updatesDir.path)); let log = getUpdateLog(FILE_UPDATE_LOG); Assert.ok(!log.exists(), MSG_SHOULD_NOT_EXIST + getMsgPath(log.path)); log = getUpdateLog(FILE_LAST_UPDATE_LOG); Assert.ok(log.exists(), MSG_SHOULD_EXIST + getMsgPath(log.path)); log = getUpdateLog(FILE_BACKUP_UPDATE_LOG); Assert.ok(log.exists(), MSG_SHOULD_EXIST + getMsgPath(log.path)); waitForFilesInUse(); }