2020-01-02 15:13:47 -05:00
|
|
|
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
2020-03-04 17:31:14 +01:00
|
|
|
import { unitTest, assertEquals } from "./test_util.ts";
|
2019-01-05 15:02:44 +00:00
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(function addEventListenerTest(): void {
|
2019-01-05 15:02:44 +00:00
|
|
|
const document = new EventTarget();
|
|
|
|
|
2020-02-19 21:36:18 +01:00
|
|
|
// @ts-ignore tests ignoring the type system for resilience
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(document.addEventListener("x", null, false), undefined);
|
2020-02-19 21:36:18 +01:00
|
|
|
// @ts-ignore
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(document.addEventListener("x", null, true), undefined);
|
2020-02-19 21:36:18 +01:00
|
|
|
// @ts-ignore
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(document.addEventListener("x", null), undefined);
|
2019-01-05 15:02:44 +00:00
|
|
|
});
|
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(function constructedEventTargetCanBeUsedAsExpected(): void {
|
2019-01-05 15:02:44 +00:00
|
|
|
const target = new EventTarget();
|
|
|
|
const event = new Event("foo", { bubbles: true, cancelable: false });
|
|
|
|
let callCount = 0;
|
|
|
|
|
2020-02-19 21:36:18 +01:00
|
|
|
const listener = (e: Event): void => {
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(e, event);
|
2019-01-05 15:02:44 +00:00
|
|
|
++callCount;
|
2019-05-27 13:20:34 +00:00
|
|
|
};
|
2019-01-05 15:02:44 +00:00
|
|
|
|
|
|
|
target.addEventListener("foo", listener);
|
|
|
|
|
|
|
|
target.dispatchEvent(event);
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(callCount, 1);
|
2019-01-05 15:02:44 +00:00
|
|
|
|
|
|
|
target.dispatchEvent(event);
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(callCount, 2);
|
2019-01-05 15:02:44 +00:00
|
|
|
|
|
|
|
target.removeEventListener("foo", listener);
|
|
|
|
target.dispatchEvent(event);
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(callCount, 2);
|
2019-01-05 15:02:44 +00:00
|
|
|
});
|
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(function anEventTargetCanBeSubclassed(): void {
|
2019-01-05 15:02:44 +00:00
|
|
|
class NicerEventTarget extends EventTarget {
|
2020-02-19 21:36:18 +01:00
|
|
|
on(
|
|
|
|
type: string,
|
2020-03-05 08:36:13 -05:00
|
|
|
callback: ((e: Event) => void) | null,
|
2020-02-19 21:36:18 +01:00
|
|
|
options?: __domTypes.AddEventListenerOptions
|
|
|
|
): void {
|
2019-01-23 12:20:53 +00:00
|
|
|
this.addEventListener(type, callback, options);
|
2019-01-05 15:02:44 +00:00
|
|
|
}
|
|
|
|
|
2020-02-19 21:36:18 +01:00
|
|
|
off(
|
|
|
|
type: string,
|
2020-03-05 08:36:13 -05:00
|
|
|
callback: ((e: Event) => void) | null,
|
2020-02-19 21:36:18 +01:00
|
|
|
options?: __domTypes.EventListenerOptions
|
|
|
|
): void {
|
2019-01-05 15:02:44 +00:00
|
|
|
this.removeEventListener(type, callback, options);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const target = new NicerEventTarget();
|
2019-03-10 04:30:38 +11:00
|
|
|
new Event("foo", { bubbles: true, cancelable: false });
|
2019-01-05 15:02:44 +00:00
|
|
|
let callCount = 0;
|
|
|
|
|
2019-05-27 13:20:34 +00:00
|
|
|
const listener = (): void => {
|
2019-01-05 15:02:44 +00:00
|
|
|
++callCount;
|
2019-05-27 13:20:34 +00:00
|
|
|
};
|
2019-01-05 15:02:44 +00:00
|
|
|
|
|
|
|
target.on("foo", listener);
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(callCount, 0);
|
2019-01-05 15:02:44 +00:00
|
|
|
|
|
|
|
target.off("foo", listener);
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(callCount, 0);
|
2019-01-05 15:02:44 +00:00
|
|
|
});
|
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(function removingNullEventListenerShouldSucceed(): void {
|
2019-01-05 15:02:44 +00:00
|
|
|
const document = new EventTarget();
|
2020-02-19 21:36:18 +01:00
|
|
|
// @ts-ignore
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(document.removeEventListener("x", null, false), undefined);
|
2020-02-19 21:36:18 +01:00
|
|
|
// @ts-ignore
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(document.removeEventListener("x", null, true), undefined);
|
2020-02-19 21:36:18 +01:00
|
|
|
// @ts-ignore
|
2019-03-06 20:48:46 -05:00
|
|
|
assertEquals(document.removeEventListener("x", null), undefined);
|
2019-01-05 15:02:44 +00:00
|
|
|
});
|
2019-03-30 20:18:19 +08:00
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(function constructedEventTargetUseObjectPrototype(): void {
|
2019-03-30 20:18:19 +08:00
|
|
|
const target = new EventTarget();
|
|
|
|
const event = new Event("toString", { bubbles: true, cancelable: false });
|
|
|
|
let callCount = 0;
|
|
|
|
|
2020-02-19 21:36:18 +01:00
|
|
|
const listener = (e: Event): void => {
|
2019-03-30 20:18:19 +08:00
|
|
|
assertEquals(e, event);
|
|
|
|
++callCount;
|
2019-05-27 13:20:34 +00:00
|
|
|
};
|
2019-03-30 20:18:19 +08:00
|
|
|
|
|
|
|
target.addEventListener("toString", listener);
|
|
|
|
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 1);
|
|
|
|
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 2);
|
|
|
|
|
|
|
|
target.removeEventListener("toString", listener);
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 2);
|
|
|
|
});
|
2019-04-03 20:41:05 +08:00
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(function toStringShouldBeWebCompatible(): void {
|
2019-04-03 20:41:05 +08:00
|
|
|
const target = new EventTarget();
|
|
|
|
assertEquals(target.toString(), "[object EventTarget]");
|
|
|
|
});
|
2019-04-19 09:56:33 +08:00
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(function dispatchEventShouldNotThrowError(): void {
|
2019-04-19 09:56:33 +08:00
|
|
|
let hasThrown = false;
|
|
|
|
|
|
|
|
try {
|
|
|
|
const target = new EventTarget();
|
|
|
|
const event = new Event("hasOwnProperty", {
|
|
|
|
bubbles: true,
|
2020-03-29 04:03:49 +11:00
|
|
|
cancelable: false,
|
2019-04-19 09:56:33 +08:00
|
|
|
});
|
2019-05-27 13:20:34 +00:00
|
|
|
const listener = (): void => {};
|
|
|
|
target.addEventListener("hasOwnProperty", listener);
|
2019-04-19 09:56:33 +08:00
|
|
|
target.dispatchEvent(event);
|
|
|
|
} catch {
|
|
|
|
hasThrown = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
assertEquals(hasThrown, false);
|
|
|
|
});
|
2019-09-11 17:53:01 +01:00
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(function eventTargetThisShouldDefaultToWindow(): void {
|
2019-09-11 17:53:01 +01:00
|
|
|
const {
|
|
|
|
addEventListener,
|
|
|
|
dispatchEvent,
|
2020-03-29 04:03:49 +11:00
|
|
|
removeEventListener,
|
2019-09-11 17:53:01 +01:00
|
|
|
} = EventTarget.prototype;
|
|
|
|
let n = 1;
|
|
|
|
const event = new Event("hello");
|
|
|
|
const listener = (): void => {
|
|
|
|
n = 2;
|
|
|
|
};
|
|
|
|
|
|
|
|
addEventListener("hello", listener);
|
|
|
|
window.dispatchEvent(event);
|
|
|
|
assertEquals(n, 2);
|
|
|
|
n = 1;
|
|
|
|
removeEventListener("hello", listener);
|
|
|
|
window.dispatchEvent(event);
|
|
|
|
assertEquals(n, 1);
|
|
|
|
|
|
|
|
window.addEventListener("hello", listener);
|
|
|
|
dispatchEvent(event);
|
|
|
|
assertEquals(n, 2);
|
|
|
|
n = 1;
|
|
|
|
window.removeEventListener("hello", listener);
|
|
|
|
dispatchEvent(event);
|
|
|
|
assertEquals(n, 1);
|
|
|
|
});
|
2020-03-05 08:36:13 -05:00
|
|
|
|
2020-03-05 14:55:11 +01:00
|
|
|
unitTest(function eventTargetShouldAcceptEventListenerObject(): void {
|
2020-03-05 08:36:13 -05:00
|
|
|
const target = new EventTarget();
|
|
|
|
const event = new Event("foo", { bubbles: true, cancelable: false });
|
|
|
|
let callCount = 0;
|
|
|
|
|
|
|
|
const listener = {
|
|
|
|
handleEvent(e: Event): void {
|
|
|
|
assertEquals(e, event);
|
|
|
|
++callCount;
|
2020-03-29 04:03:49 +11:00
|
|
|
},
|
2020-03-05 08:36:13 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
target.addEventListener("foo", listener);
|
|
|
|
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 1);
|
|
|
|
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 2);
|
|
|
|
|
|
|
|
target.removeEventListener("foo", listener);
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 2);
|
|
|
|
});
|
|
|
|
|
2020-03-05 14:55:11 +01:00
|
|
|
unitTest(function eventTargetShouldAcceptAsyncFunction(): void {
|
2020-03-05 08:36:13 -05:00
|
|
|
const target = new EventTarget();
|
|
|
|
const event = new Event("foo", { bubbles: true, cancelable: false });
|
|
|
|
let callCount = 0;
|
|
|
|
|
2020-03-20 14:38:34 +01:00
|
|
|
const listener = (e: Event): void => {
|
2020-03-05 08:36:13 -05:00
|
|
|
assertEquals(e, event);
|
|
|
|
++callCount;
|
|
|
|
};
|
|
|
|
|
|
|
|
target.addEventListener("foo", listener);
|
|
|
|
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 1);
|
|
|
|
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 2);
|
|
|
|
|
|
|
|
target.removeEventListener("foo", listener);
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 2);
|
|
|
|
});
|
|
|
|
|
2020-03-05 14:55:11 +01:00
|
|
|
unitTest(
|
2020-03-05 08:36:13 -05:00
|
|
|
function eventTargetShouldAcceptAsyncFunctionForEventListenerObject(): void {
|
|
|
|
const target = new EventTarget();
|
|
|
|
const event = new Event("foo", { bubbles: true, cancelable: false });
|
|
|
|
let callCount = 0;
|
|
|
|
|
|
|
|
const listener = {
|
2020-03-20 14:38:34 +01:00
|
|
|
handleEvent(e: Event): void {
|
2020-03-05 08:36:13 -05:00
|
|
|
assertEquals(e, event);
|
|
|
|
++callCount;
|
2020-03-29 04:03:49 +11:00
|
|
|
},
|
2020-03-05 08:36:13 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
target.addEventListener("foo", listener);
|
|
|
|
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 1);
|
|
|
|
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 2);
|
|
|
|
|
|
|
|
target.removeEventListener("foo", listener);
|
|
|
|
target.dispatchEvent(event);
|
|
|
|
assertEquals(callCount, 2);
|
|
|
|
}
|
|
|
|
);
|