aboutsummaryrefslogtreecommitdiff
path: root/e2e/ambassador/src/content/ipc.js
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2018-02-14 18:43:28 +0900
committerGitHub <noreply@github.com>2018-02-14 18:43:28 +0900
commita48915d4e090378a672d780b2fbc93e1af6e082c (patch)
tree2e6a4295935577c5e0facbb3f5d569893bf28afe /e2e/ambassador/src/content/ipc.js
parent5412584a7c453d074dca6d58814e29590085ff73 (diff)
parentf63920e25e80ca0e472d3514fd56e27fbc505e6f (diff)
Merge pull request #329 from ueokande/e2e-test
End-to-End testing
Diffstat (limited to 'e2e/ambassador/src/content/ipc.js')
-rw-r--r--e2e/ambassador/src/content/ipc.js40
1 files changed, 40 insertions, 0 deletions
diff --git a/e2e/ambassador/src/content/ipc.js b/e2e/ambassador/src/content/ipc.js
new file mode 100644
index 0000000..917623c
--- /dev/null
+++ b/e2e/ambassador/src/content/ipc.js
@@ -0,0 +1,40 @@
+import { METHOD_REQUEST, METHOD_RESPONSE } from '../shared/messages';
+
+const sendToBackground = (message) => {
+ return browser.runtime.sendMessage(message);
+};
+
+const receiveBackgroundMesssage = (func) => {
+ return browser.runtime.onMessage.addListener((message) => {
+ return Promise.resolve(func(message));
+ });
+};
+
+const receivePageMessage = (func) => {
+ window.addEventListener('message', (e) => {
+ let packet = e.data;
+ if (e.origin !== window.origin || packet.method !== METHOD_REQUEST) {
+ return;
+ }
+
+ let resp = {
+ id: packet.id,
+ method: METHOD_RESPONSE,
+ };
+ let respMessage = func(packet.message);
+ if (respMessage instanceof Promise) {
+ return respMessage.then((data) => {
+ resp.message = data;
+ e.source.postMessage(resp, e.origin);
+ });
+ } else if (respMessage) {
+ resp.message = respMessage;
+ }
+ e.source.postMessage(resp, e.origin);
+ });
+};
+
+export {
+ sendToBackground, receiveBackgroundMesssage,
+ receivePageMessage,
+};