| Index: test/filterNotifier.js |
| =================================================================== |
| --- a/test/filterNotifier.js |
| +++ b/test/filterNotifier.js |
| @@ -28,80 +28,90 @@ |
| {FilterNotifier} = sandboxedRequire("../lib/filterNotifier") |
| ); |
| callback(); |
| }; |
| let triggeredListeners = []; |
| let listeners = [ |
| - (action, item) => triggeredListeners.push(["listener1", action, item]), |
| - (action, item) => triggeredListeners.push(["listener2", action, item]), |
| - (action, item) => triggeredListeners.push(["listener3", action, item]) |
| + (...args) => triggeredListeners.push(["listener1", ...args]), |
| + (...args) => triggeredListeners.push(["listener2", ...args]), |
| + (...args) => triggeredListeners.push(["listener3", ...args]) |
| ]; |
| +function addListener(listener) |
| +{ |
| + FilterNotifier.on("foo", listener); |
| +} |
| + |
| +function removeListener(listener) |
| +{ |
| + FilterNotifier.off("foo", listener); |
| +} |
| + |
| function compareListeners(test, testDescription, list) |
| { |
| let result1 = triggeredListeners = []; |
| - FilterNotifier.triggerListeners("foo", {bar: true}); |
| + FilterNotifier.emit("foo", {bar: true}); |
| let result2 = triggeredListeners = []; |
| for (let observer of list) |
| - observer("foo", {bar: true}); |
| + observer({bar: true}); |
| test.deepEqual(result1, result2, testDescription); |
| } |
| exports.testAddingRemovingListeners = function(test) |
| { |
| let [listener1, listener2, listener3] = listeners; |
| compareListeners(test, "No listeners", []); |
| - FilterNotifier.addListener(listener1); |
| + addListener(listener1); |
| compareListeners(test, "addListener(listener1)", [listener1]); |
| - FilterNotifier.addListener(listener1); |
| - compareListeners(test, "addListener(listener1) again", [listener1]); |
| + addListener(listener1); |
| + compareListeners(test, "addListener(listener1) again", [listener1, listener1]); |
|
Manish Jethani
2018/08/11 14:47:06
Note that there is a difference in behavior here b
|
| + |
| + addListener(listener2); |
| + compareListeners(test, "addListener(listener2)", [listener1, listener1, listener2]); |
| + |
| + removeListener(listener1); |
| + compareListeners(test, "removeListener(listener1)", [listener1, listener2]); |
| - FilterNotifier.addListener(listener2); |
| - compareListeners(test, "addListener(listener2)", [listener1, listener2]); |
| + removeListener(listener1); |
| + compareListeners(test, "removeListener(listener1) again", [listener2]); |
| + |
| + addListener(listener3); |
| + compareListeners(test, "addListener(listener3)", [listener2, listener3]); |
| - FilterNotifier.removeListener(listener1); |
| + addListener(listener1); |
| + compareListeners(test, "addListener(listener1)", [listener2, listener3, listener1]); |
| + |
| + removeListener(listener3); |
| + compareListeners(test, "removeListener(listener3)", [listener2, listener1]); |
| + |
| + removeListener(listener1); |
| compareListeners(test, "removeListener(listener1)", [listener2]); |
| - FilterNotifier.removeListener(listener1); |
| - compareListeners(test, "removeListener(listener1) again", [listener2]); |
| - |
| - FilterNotifier.addListener(listener3); |
| - compareListeners(test, "addListener(listener3)", [listener2, listener3]); |
| - |
| - FilterNotifier.addListener(listener1); |
| - compareListeners(test, "addListener(listener1)", [listener2, listener3, listener1]); |
| - |
| - FilterNotifier.removeListener(listener3); |
| - compareListeners(test, "removeListener(listener3)", [listener2, listener1]); |
| - |
| - FilterNotifier.removeListener(listener1); |
| - compareListeners(test, "removeListener(listener1)", [listener2]); |
| - |
| - FilterNotifier.removeListener(listener2); |
| + removeListener(listener2); |
| compareListeners(test, "removeListener(listener2)", []); |
| test.done(); |
| }; |
| exports.testRemovingListenersWhileBeingCalled = function(test) |
| { |
| let listener1 = function(...args) |
| { |
| listeners[0](...args); |
| - FilterNotifier.removeListener(listener1); |
| + removeListener(listener1); |
| }; |
| let listener2 = listeners[1]; |
| - FilterNotifier.addListener(listener1); |
| - FilterNotifier.addListener(listener2); |
| + addListener(listener1); |
| + addListener(listener2); |
| compareListeners(test, "Initial call", [listener1, listener2]); |
| compareListeners(test, "Subsequent calls", [listener2]); |
| test.done(); |
| }; |