1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/services/sync/tests/unit/test_password_tracker.js Wed Dec 31 06:09:35 2014 +0100 1.3 @@ -0,0 +1,101 @@ 1.4 +/* Any copyright is dedicated to the Public Domain. 1.5 + http://creativecommons.org/publicdomain/zero/1.0/ */ 1.6 + 1.7 +Cu.import("resource://services-sync/constants.js"); 1.8 +Cu.import("resource://services-sync/engines/passwords.js"); 1.9 +Cu.import("resource://services-sync/engines.js"); 1.10 +Cu.import("resource://services-sync/service.js"); 1.11 +Cu.import("resource://services-sync/util.js"); 1.12 + 1.13 +Service.engineManager.register(PasswordEngine); 1.14 +let engine = Service.engineManager.get("passwords"); 1.15 +let store = engine._store; 1.16 +let tracker = engine._tracker; 1.17 + 1.18 +// Don't do asynchronous writes. 1.19 +tracker.persistChangedIDs = false; 1.20 + 1.21 +function run_test() { 1.22 + initTestLogging("Trace"); 1.23 + run_next_test(); 1.24 +} 1.25 + 1.26 +add_test(function test_tracking() { 1.27 + let recordNum = 0; 1.28 + 1.29 + _("Verify we've got an empty tracker to work with."); 1.30 + do_check_empty(tracker.changedIDs); 1.31 + 1.32 + function createPassword() { 1.33 + _("RECORD NUM: " + recordNum); 1.34 + let record = {id: "GUID" + recordNum, 1.35 + hostname: "http://foo.bar.com", 1.36 + formSubmitURL: "http://foo.bar.com/baz", 1.37 + username: "john" + recordNum, 1.38 + password: "smith", 1.39 + usernameField: "username", 1.40 + passwordField: "password"}; 1.41 + recordNum++; 1.42 + let login = store._nsLoginInfoFromRecord(record); 1.43 + Services.logins.addLogin(login); 1.44 + } 1.45 + 1.46 + try { 1.47 + _("Create a password record. Won't show because we haven't started tracking yet"); 1.48 + createPassword(); 1.49 + do_check_empty(tracker.changedIDs); 1.50 + do_check_eq(tracker.score, 0); 1.51 + 1.52 + _("Tell the tracker to start tracking changes."); 1.53 + Svc.Obs.notify("weave:engine:start-tracking"); 1.54 + createPassword(); 1.55 + do_check_attribute_count(tracker.changedIDs, 1); 1.56 + do_check_eq(tracker.score, SCORE_INCREMENT_XLARGE); 1.57 + 1.58 + _("Notifying twice won't do any harm."); 1.59 + Svc.Obs.notify("weave:engine:start-tracking"); 1.60 + createPassword(); 1.61 + do_check_attribute_count(tracker.changedIDs, 2); 1.62 + do_check_eq(tracker.score, SCORE_INCREMENT_XLARGE * 2); 1.63 + 1.64 + _("Let's stop tracking again."); 1.65 + tracker.clearChangedIDs(); 1.66 + tracker.resetScore(); 1.67 + Svc.Obs.notify("weave:engine:stop-tracking"); 1.68 + createPassword(); 1.69 + do_check_empty(tracker.changedIDs); 1.70 + do_check_eq(tracker.score, 0); 1.71 + 1.72 + _("Notifying twice won't do any harm."); 1.73 + Svc.Obs.notify("weave:engine:stop-tracking"); 1.74 + createPassword(); 1.75 + do_check_empty(tracker.changedIDs); 1.76 + do_check_eq(tracker.score, 0); 1.77 + 1.78 + } finally { 1.79 + _("Clean up."); 1.80 + store.wipe(); 1.81 + tracker.clearChangedIDs(); 1.82 + tracker.resetScore(); 1.83 + Svc.Obs.notify("weave:engine:stop-tracking"); 1.84 + run_next_test(); 1.85 + } 1.86 +}); 1.87 + 1.88 +add_test(function test_onWipe() { 1.89 + _("Verify we've got an empty tracker to work with."); 1.90 + do_check_empty(tracker.changedIDs); 1.91 + do_check_eq(tracker.score, 0); 1.92 + 1.93 + try { 1.94 + _("A store wipe should increment the score"); 1.95 + Svc.Obs.notify("weave:engine:start-tracking"); 1.96 + store.wipe(); 1.97 + 1.98 + do_check_eq(tracker.score, SCORE_INCREMENT_XLARGE); 1.99 + } finally { 1.100 + tracker.resetScore(); 1.101 + Svc.Obs.notify("weave:engine:stop-tracking"); 1.102 + run_next_test(); 1.103 + } 1.104 +});