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 +}