services/sync/tests/unit/test_password_tracker.js

changeset 0
6474c204b198
     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 +});

mercurial