0
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-03-03 09:31:22 -05:00

fix(cli/rt/main): Add global interface objects (#7875)

This commit is contained in:
Nayeem Rahman 2020-10-11 23:04:43 +01:00 committed by GitHub
parent 265a9fb932
commit 5f3028af13
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 95 additions and 16 deletions

View file

@ -7,7 +7,8 @@
/// <reference lib="deno.shared_globals" />
/// <reference lib="esnext" />
declare interface Window extends EventTarget {
declare class Window extends EventTarget {
new(): Window;
readonly window: Window & typeof globalThis;
readonly self: Window & typeof globalThis;
onload: ((this: Window, ev: Event) => any) | null;

View file

@ -7,48 +7,53 @@
/// <reference lib="deno.shared_globals" />
/// <reference lib="esnext" />
declare interface DedicatedWorkerGlobalScope {
self: DedicatedWorkerGlobalScope & typeof globalThis;
declare class WorkerGlobalScope {
new(): WorkerGlobalScope;
self: WorkerGlobalScope & typeof globalThis;
onmessage:
| ((
this: DedicatedWorkerGlobalScope & typeof globalThis,
this: WorkerGlobalScope & typeof globalThis,
ev: MessageEvent,
) => any)
| null;
onmessageerror:
| ((
this: DedicatedWorkerGlobalScope & typeof globalThis,
this: WorkerGlobalScope & typeof globalThis,
ev: MessageEvent,
) => any)
| null;
onerror:
| ((
this: DedicatedWorkerGlobalScope & typeof globalThis,
this: WorkerGlobalScope & typeof globalThis,
ev: ErrorEvent,
) => any)
| null;
name: string;
close: () => void;
postMessage: (message: any) => void;
Deno: typeof Deno;
}
declare var self: DedicatedWorkerGlobalScope & typeof globalThis;
declare class DedicatedWorkerGlobalScope extends WorkerGlobalScope {
new(): DedicatedWorkerGlobalScope;
name: string;
}
declare var self: WorkerGlobalScope & typeof globalThis;
declare var onmessage:
| ((
this: DedicatedWorkerGlobalScope & typeof globalThis,
this: WorkerGlobalScope & typeof globalThis,
ev: MessageEvent,
) => any)
| null;
declare var onmessageerror:
| ((
this: DedicatedWorkerGlobalScope & typeof globalThis,
this: WorkerGlobalScope & typeof globalThis,
ev: MessageEvent,
) => any)
| null;
declare var onerror:
| ((
this: DedicatedWorkerGlobalScope & typeof globalThis,
this: WorkerGlobalScope & typeof globalThis,
ev: ErrorEvent,
) => any)
| null;

View file

@ -7,6 +7,7 @@ delete Object.prototype.__proto__;
((window) => {
const core = Deno.core;
const util = window.__bootstrap.util;
const { illegalConstructorKey } = window.__bootstrap.webUtil;
const eventTarget = window.__bootstrap.eventTarget;
const dispatchMinimal = window.__bootstrap.dispatchMinimal;
const build = window.__bootstrap.build;
@ -190,6 +191,42 @@ delete Object.prototype.__proto__;
core.registerErrorClass("URIError", URIError);
}
class Window extends EventTarget {
constructor(key) {
if (key !== illegalConstructorKey) {
throw new TypeError("Illegal constructor.");
}
}
get [Symbol.toStringTag]() {
return "Window";
}
}
class WorkerGlobalScope extends EventTarget {
constructor(key) {
if (key != illegalConstructorKey) {
throw new TypeError("Illegal constructor.");
}
}
get [Symbol.toStringTag]() {
return "WorkerGlobalScope";
}
}
class DedicatedWorkerGlobalScope extends WorkerGlobalScope {
constructor(key) {
if (key != illegalConstructorKey) {
throw new TypeError("Illegal constructor.");
}
}
get [Symbol.toStringTag]() {
return "DedicatedWorkerGlobalScope";
}
}
// https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope
const windowOrWorkerGlobalScope = {
Blob: util.nonEnumerable(fetch.Blob),
@ -226,24 +263,20 @@ delete Object.prototype.__proto__;
WebSocket: util.nonEnumerable(webSocket.WebSocket),
Worker: util.nonEnumerable(worker.Worker),
WritableStream: util.nonEnumerable(streams.WritableStream),
addEventListener: util.readOnly(EventTarget.prototype.addEventListener),
atob: util.writable(atob),
btoa: util.writable(btoa),
clearInterval: util.writable(timers.clearInterval),
clearTimeout: util.writable(timers.clearTimeout),
console: util.writable(new Console(core.print)),
crypto: util.readOnly(crypto),
dispatchEvent: util.readOnly(EventTarget.prototype.dispatchEvent),
fetch: util.writable(fetch.fetch),
performance: util.writable(performance.performance),
removeEventListener: util.readOnly(
EventTarget.prototype.removeEventListener,
),
setInterval: util.writable(timers.setInterval),
setTimeout: util.writable(timers.setTimeout),
};
const mainRuntimeGlobalProperties = {
Window: util.nonEnumerable(Window),
window: util.readOnly(globalThis),
self: util.readOnly(globalThis),
// TODO(bartlomieju): from MDN docs (https://developer.mozilla.org/en-US/docs/Web/API/WorkerGlobalScope)
@ -255,6 +288,8 @@ delete Object.prototype.__proto__;
};
const workerRuntimeGlobalProperties = {
WorkerGlobalScope: util.nonEnumerable(WorkerGlobalScope),
DedicatedWorkerGlobalScope: util.nonEnumerable(DedicatedWorkerGlobalScope),
self: util.readOnly(globalThis),
onmessage: util.writable(onmessage),
onerror: util.writable(onerror),
@ -277,6 +312,7 @@ delete Object.prototype.__proto__;
hasBootstrapped = true;
Object.defineProperties(globalThis, windowOrWorkerGlobalScope);
Object.defineProperties(globalThis, mainRuntimeGlobalProperties);
Object.setPrototypeOf(globalThis, Window.prototype);
eventTarget.setEventTargetData(globalThis);
// Registers the handler for window.onload function.
globalThis.addEventListener("load", (e) => {
@ -341,6 +377,7 @@ delete Object.prototype.__proto__;
Object.defineProperties(globalThis, windowOrWorkerGlobalScope);
Object.defineProperties(globalThis, workerRuntimeGlobalProperties);
Object.defineProperties(globalThis, { name: util.readOnly(name) });
Object.setPrototypeOf(globalThis, DedicatedWorkerGlobalScope.prototype);
eventTarget.setEventTargetData(globalThis);
const { unstableFlag, pid, noColor, args } = runtimeStart(
internalName ?? name,

View file

@ -0,0 +1,10 @@
onmessage = function (): void {
postMessage(
[
self instanceof DedicatedWorkerGlobalScope,
self instanceof WorkerGlobalScope,
self instanceof EventTarget,
].join(", "),
);
close();
};

View file

@ -36,6 +36,14 @@ unitTest(function globalThisEqualsSelf(): void {
assert(globalThis === self);
});
unitTest(function globalThisInstanceofWindow(): void {
assert(globalThis instanceof Window);
});
unitTest(function globalThisInstanceofEventTarget(): void {
assert(globalThis instanceof EventTarget);
});
unitTest(function DenoNamespaceExists(): void {
assert(Deno != null);
});

View file

@ -105,6 +105,24 @@ Deno.test({
},
});
Deno.test({
name: "worker globals",
fn: async function (): Promise<void> {
const promise = createResolvable();
const w = new Worker(
new URL("subdir/worker_globals.ts", import.meta.url).href,
{ type: "module" },
);
w.onmessage = (e): void => {
assertEquals(e.data, "true, true, true");
promise.resolve();
};
w.postMessage("Hello, world!");
await promise;
w.terminate();
},
});
Deno.test({
name: "worker fetch API",
fn: async function (): Promise<void> {