Skip to content

Commit

Permalink
Merge pull request #475 from MrMadClown/master
Browse files Browse the repository at this point in the history
This might be a solution for #474
  • Loading branch information
surma authored Feb 10, 2021
2 parents a44ed20 + 6370bef commit 4ba8162
Show file tree
Hide file tree
Showing 4 changed files with 64 additions and 10 deletions.
2 changes: 2 additions & 0 deletions src/comlink.ts
Original file line number Diff line number Diff line change
Expand Up @@ -330,6 +330,8 @@ export function expose(obj: any, ep: Endpoint = self as any) {
returnValue = undefined;
}
break;
default:
return;
}
} catch (value) {
returnValue = { value, [throwMarker]: 0 };
Expand Down
22 changes: 12 additions & 10 deletions src/protocol.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ export interface EventSource {
listener: EventListenerOrEventListenerObject,
options?: {}
): void;

removeEventListener(
type: string,
listener: EventListenerOrEventListenerObject,
Expand All @@ -34,14 +35,15 @@ export interface PostMessageWithOrigin {

export interface Endpoint extends EventSource {
postMessage(message: any, transfer?: Transferable[]): void;

start?: () => void;
}

export const enum WireValueType {
RAW,
PROXY,
THROW,
HANDLER,
RAW = "RAW",
PROXY = "PROXY",
THROW = "THROW",
HANDLER = "HANDLER",
}

export interface RawWireValue {
Expand All @@ -62,12 +64,12 @@ export type WireValue = RawWireValue | HandlerWireValue;
export type MessageID = string;

export const enum MessageType {
GET,
SET,
APPLY,
CONSTRUCT,
ENDPOINT,
RELEASE,
GET = "GET",
SET = "SET",
APPLY = "APPLY",
CONSTRUCT = "CONSTRUCT",
ENDPOINT = "ENDPOINT",
RELEASE = "RELEASE",
}

export interface GetMessage {
Expand Down
10 changes: 10 additions & 0 deletions tests/fixtures/two-way-iframe.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
<script type="module">
import * as Comlink from "/base/dist/esm/comlink.mjs";

const parentEndpoint = Comlink.windowEndpoint(self.parent);
const wrappedParent = Comlink.wrap(parentEndpoint);

Comlink.expose(async (a, b) => {
return a + (await wrappedParent(b));
}, parentEndpoint);
</script>
40 changes: 40 additions & 0 deletions tests/two-way-iframe.comlink.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
/**
* Copyright 2017 Google Inc. All Rights Reserved.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

import * as Comlink from "/base/dist/esm/comlink.mjs";

describe("Comlink across iframes", function () {
beforeEach(function () {
this.ifr = document.createElement("iframe");
this.ifr.sandbox.add("allow-scripts", "allow-same-origin");
this.ifr.src = "/base/tests/fixtures/two-way-iframe.html";
document.body.appendChild(this.ifr);
return new Promise((resolve) => (this.ifr.onload = resolve));
});

afterEach(function () {
this.ifr.remove();
});

it("can communicate both ways", async function () {
let called = false;
const iframe = Comlink.windowEndpoint(this.ifr.contentWindow);
Comlink.expose((a) => {
called = true;
return ++a;
}, iframe);
const proxy = Comlink.wrap(iframe);
expect(await proxy(1, 3)).to.equal(5);
expect(called).to.equal(true);
});
});

0 comments on commit 4ba8162

Please sign in to comment.