toolkit/components/search/tests/xpcshell/test_notifications.js

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/toolkit/components/search/tests/xpcshell/test_notifications.js	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,84 @@
     1.4 +/* Any copyright is dedicated to the Public Domain.
     1.5 + *    http://creativecommons.org/publicdomain/zero/1.0/ */
     1.6 +
     1.7 +"use strict";
     1.8 +
     1.9 +const Ci = Components.interfaces;
    1.10 +
    1.11 +Components.utils.import("resource://testing-common/httpd.js");
    1.12 +
    1.13 +let gTestLog = [];
    1.14 +
    1.15 +/**
    1.16 + * The order of notifications expected for this test is:
    1.17 + *  - engine-changed (while we're installing the engine, we modify it, which notifies - bug 606886)
    1.18 + *  - engine-added (engine was added to the store by the search service)
    1.19 + *   -> our search observer is called, which sets:
    1.20 + *    - .defaultEngine, triggering engine-default
    1.21 + *    - .currentEngine, triggering engine-current (after bug 493051 - for now the search service sets this after engine-added)
    1.22 + *   ...and then schedules a removal
    1.23 + *  - engine-loaded (the search service's observer is garanteed to fire first, which is what causes engine-added to fire)
    1.24 + *  - engine-removed (due to the removal schedule above)
    1.25 + */
    1.26 +let expectedLog = [
    1.27 +  "engine-changed", // XXX bug 606886
    1.28 +  "engine-added",
    1.29 +  "engine-default",
    1.30 +  "engine-current",
    1.31 +  "engine-loaded",
    1.32 +  "engine-removed"
    1.33 +];
    1.34 +
    1.35 +function search_observer(subject, topic, data) {
    1.36 +  let engine = subject.QueryInterface(Ci.nsISearchEngine);
    1.37 +  gTestLog.push(data + " for " + engine.name);
    1.38 +
    1.39 +  do_print("Observer: " + data + " for " + engine.name);
    1.40 +
    1.41 +  switch (data) {
    1.42 +    case "engine-added":
    1.43 +      let retrievedEngine = Services.search.getEngineByName("Test search engine");
    1.44 +      do_check_eq(engine, retrievedEngine);
    1.45 +      Services.search.defaultEngine = engine;
    1.46 +      Services.search.currentEngine = engine;
    1.47 +      do_execute_soon(function () {
    1.48 +        Services.search.removeEngine(engine);
    1.49 +      });
    1.50 +      break;
    1.51 +    case "engine-removed":
    1.52 +      let engineNameOutput = " for Test search engine";
    1.53 +      expectedLog = expectedLog.map(logLine => logLine + engineNameOutput);
    1.54 +      do_print("expectedLog:\n" + expectedLog.join("\n"))
    1.55 +      do_print("gTestLog:\n" + gTestLog.join("\n"))
    1.56 +      for (let i = 0; i < expectedLog.length; i++) {
    1.57 +        do_check_eq(gTestLog[i], expectedLog[i]);
    1.58 +      }
    1.59 +      do_check_eq(gTestLog.length, expectedLog.length);
    1.60 +      do_test_finished();
    1.61 +      break;
    1.62 +  }
    1.63 +}
    1.64 +
    1.65 +function run_test() {
    1.66 +  removeMetadata();
    1.67 +  updateAppInfo();
    1.68 +
    1.69 +  let httpServer = new HttpServer();
    1.70 +  httpServer.start(-1);
    1.71 +  httpServer.registerDirectory("/", do_get_cwd());
    1.72 +
    1.73 +  do_register_cleanup(function cleanup() {
    1.74 +    httpServer.stop(function() {});
    1.75 +    Services.obs.removeObserver(search_observer, "browser-search-engine-modified");
    1.76 +  });
    1.77 +
    1.78 +  do_test_pending();
    1.79 +
    1.80 +  Services.obs.addObserver(search_observer, "browser-search-engine-modified", false);
    1.81 +
    1.82 +  Services.search.addEngine("http://localhost:" +
    1.83 +                            httpServer.identity.primaryPort +
    1.84 +                            "/data/engine.xml",
    1.85 +                            Ci.nsISearchEngine.DATA_XML,
    1.86 +                            null, false);
    1.87 +}

mercurial