mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
78 lines
2.8 KiB
JavaScript
78 lines
2.8 KiB
JavaScript
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
const observers = require("sdk/deprecated/observer-service");
|
|
const { Cc, Ci } = require("chrome");
|
|
const { LoaderWithHookedConsole2 } = require("sdk/test/loader");
|
|
|
|
exports.testUnloadAndErrorLogging = function(test) {
|
|
let { loader, messages } = LoaderWithHookedConsole2(module);
|
|
var sbobsvc = loader.require("sdk/deprecated/observer-service");
|
|
|
|
var timesCalled = 0;
|
|
var cb = function(subject, data) {
|
|
timesCalled++;
|
|
};
|
|
var badCb = function(subject, data) {
|
|
throw new Error("foo");
|
|
};
|
|
sbobsvc.add("blarg", cb);
|
|
observers.notify("blarg", "yo yo");
|
|
test.assertEqual(timesCalled, 1);
|
|
sbobsvc.add("narg", badCb);
|
|
observers.notify("narg", "yo yo");
|
|
|
|
test.assertEqual(messages[0], "console.error: " + require("sdk/self").name + ": \n");
|
|
var lines = messages[1].split("\n");
|
|
test.assertEqual(lines[0], " Message: Error: foo");
|
|
test.assertEqual(lines[1], " Stack:");
|
|
// Keep in mind to update "18" to the line of "throw new Error("foo")"
|
|
test.assert(lines[2].indexOf(module.uri + ":18") != -1);
|
|
|
|
loader.unload();
|
|
observers.notify("blarg", "yo yo");
|
|
test.assertEqual(timesCalled, 1);
|
|
};
|
|
|
|
exports.testObserverService = function(test) {
|
|
var ios = Cc['@mozilla.org/network/io-service;1']
|
|
.getService(Ci.nsIIOService);
|
|
var service = Cc["@mozilla.org/observer-service;1"].
|
|
getService(Ci.nsIObserverService);
|
|
var uri = ios.newURI("http://www.foo.com", null, null);
|
|
var timesCalled = 0;
|
|
var lastSubject = null;
|
|
var lastData = null;
|
|
|
|
var cb = function(subject, data) {
|
|
timesCalled++;
|
|
lastSubject = subject;
|
|
lastData = data;
|
|
};
|
|
|
|
observers.add("blarg", cb);
|
|
service.notifyObservers(uri, "blarg", "some data");
|
|
test.assertEqual(timesCalled, 1,
|
|
"observer-service.add() should call callback");
|
|
test.assertEqual(lastSubject, uri,
|
|
"observer-service.add() should pass subject");
|
|
test.assertEqual(lastData, "some data",
|
|
"observer-service.add() should pass data");
|
|
|
|
function customSubject() {}
|
|
function customData() {}
|
|
observers.notify("blarg", customSubject, customData);
|
|
test.assertEqual(timesCalled, 2,
|
|
"observer-service.notify() should work");
|
|
test.assertEqual(lastSubject, customSubject,
|
|
"observer-service.notify() should pass+wrap subject");
|
|
test.assertEqual(lastData, customData,
|
|
"observer-service.notify() should pass data");
|
|
|
|
observers.remove("blarg", cb);
|
|
service.notifyObservers(null, "blarg", "some data");
|
|
test.assertEqual(timesCalled, 2,
|
|
"observer-service.remove() should work");
|
|
};
|