summaryrefslogtreecommitdiffstats
path: root/browser/components/sessionstore/test/unit/test_backup_once.js
diff options
context:
space:
mode:
Diffstat (limited to 'browser/components/sessionstore/test/unit/test_backup_once.js')
-rw-r--r--browser/components/sessionstore/test/unit/test_backup_once.js130
1 files changed, 130 insertions, 0 deletions
diff --git a/browser/components/sessionstore/test/unit/test_backup_once.js b/browser/components/sessionstore/test/unit/test_backup_once.js
new file mode 100644
index 000000000..fff34ad58
--- /dev/null
+++ b/browser/components/sessionstore/test/unit/test_backup_once.js
@@ -0,0 +1,130 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+"use strict";
+
+var {OS} = Cu.import("resource://gre/modules/osfile.jsm", {});
+var {XPCOMUtils} = Cu.import("resource://gre/modules/XPCOMUtils.jsm", {});
+var {Task} = Cu.import("resource://gre/modules/Task.jsm", {});
+var {SessionWorker} = Cu.import("resource:///modules/sessionstore/SessionWorker.jsm", {});
+
+var File = OS.File;
+var Paths;
+var SessionFile;
+
+// We need a XULAppInfo to initialize SessionFile
+Cu.import("resource://testing-common/AppInfo.jsm", this);
+updateAppInfo({
+ name: "SessionRestoreTest",
+ ID: "{230de50e-4cd1-11dc-8314-0800200c9a66}",
+ version: "1",
+ platformVersion: "",
+});
+
+function run_test() {
+ run_next_test();
+}
+
+add_task(function* init() {
+ // Make sure that we have a profile before initializing SessionFile
+ let profd = do_get_profile();
+ SessionFile = Cu.import("resource:///modules/sessionstore/SessionFile.jsm", {}).SessionFile;
+ Paths = SessionFile.Paths;
+
+
+ let source = do_get_file("data/sessionstore_valid.js");
+ source.copyTo(profd, "sessionstore.js");
+
+ // Finish initialization of SessionFile
+ yield SessionFile.read();
+});
+
+var pathStore;
+var pathBackup;
+var decoder;
+
+function promise_check_exist(path, shouldExist) {
+ return Task.spawn(function*() {
+ do_print("Ensuring that " + path + (shouldExist?" exists":" does not exist"));
+ if ((yield OS.File.exists(path)) != shouldExist) {
+ throw new Error("File " + path + " should " + (shouldExist?"exist":"not exist"));
+ }
+ });
+}
+
+function promise_check_contents(path, expect) {
+ return Task.spawn(function*() {
+ do_print("Checking whether " + path + " has the right contents");
+ let actual = yield OS.File.read(path, { encoding: "utf-8"});
+ Assert.deepEqual(JSON.parse(actual), expect, `File ${path} contains the expected data.`);
+ });
+}
+
+function generateFileContents(id) {
+ let url = `http://example.com/test_backup_once#${id}_${Math.random()}`;
+ return {windows: [{tabs: [{entries: [{url}], index: 1}]}]}
+}
+
+// Write to the store, and check that it creates:
+// - $Path.recovery with the new data
+// - $Path.nextUpgradeBackup with the old data
+add_task(function* test_first_write_backup() {
+ let initial_content = generateFileContents("initial");
+ let new_content = generateFileContents("test_1");
+
+ do_print("Before the first write, none of the files should exist");
+ yield promise_check_exist(Paths.backups, false);
+
+ yield File.makeDir(Paths.backups);
+ yield File.writeAtomic(Paths.clean, JSON.stringify(initial_content), { encoding: "utf-8" });
+ yield SessionFile.write(new_content);
+
+ do_print("After first write, a few files should have been created");
+ yield promise_check_exist(Paths.backups, true);
+ yield promise_check_exist(Paths.clean, false);
+ yield promise_check_exist(Paths.cleanBackup, true);
+ yield promise_check_exist(Paths.recovery, true);
+ yield promise_check_exist(Paths.recoveryBackup, false);
+ yield promise_check_exist(Paths.nextUpgradeBackup, true);
+
+ yield promise_check_contents(Paths.recovery, new_content);
+ yield promise_check_contents(Paths.nextUpgradeBackup, initial_content);
+});
+
+// Write to the store again, and check that
+// - $Path.clean is not written
+// - $Path.recovery contains the new data
+// - $Path.recoveryBackup contains the previous data
+add_task(function* test_second_write_no_backup() {
+ let new_content = generateFileContents("test_2");
+ let previous_backup_content = yield File.read(Paths.recovery, { encoding: "utf-8" });
+ previous_backup_content = JSON.parse(previous_backup_content);
+
+ yield OS.File.remove(Paths.cleanBackup);
+
+ yield SessionFile.write(new_content);
+
+ yield promise_check_exist(Paths.backups, true);
+ yield promise_check_exist(Paths.clean, false);
+ yield promise_check_exist(Paths.cleanBackup, false);
+ yield promise_check_exist(Paths.recovery, true);
+ yield promise_check_exist(Paths.nextUpgradeBackup, true);
+
+ yield promise_check_contents(Paths.recovery, new_content);
+ yield promise_check_contents(Paths.recoveryBackup, previous_backup_content);
+});
+
+// Make sure that we create $Paths.clean and remove $Paths.recovery*
+// upon shutdown
+add_task(function* test_shutdown() {
+ let output = generateFileContents("test_3");
+
+ yield File.writeAtomic(Paths.recovery, "I should disappear");
+ yield File.writeAtomic(Paths.recoveryBackup, "I should also disappear");
+
+ yield SessionWorker.post("write", [output, { isFinalWrite: true, performShutdownCleanup: true}]);
+
+ do_check_false((yield File.exists(Paths.recovery)));
+ do_check_false((yield File.exists(Paths.recoveryBackup)));
+ yield promise_check_contents(Paths.clean, output);
+});