From b26d027ce8326d5c233a3295c98b2147bda49727 Mon Sep 17 00:00:00 2001 From: Shin'ya Ueoka Date: Sun, 4 Feb 2018 17:50:48 +0900 Subject: add test:e2e --- e2e/karma.conf.js | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 e2e/karma.conf.js (limited to 'e2e/karma.conf.js') diff --git a/e2e/karma.conf.js b/e2e/karma.conf.js new file mode 100644 index 0000000..259eb17 --- /dev/null +++ b/e2e/karma.conf.js @@ -0,0 +1,41 @@ +module.exports = function (config) { + + config.set({ + basePath: '', + frameworks: ['mocha'], + files: [ + '**/*.test.js' + ], + + preprocessors: { + '**/*.test.js': ['webpack'] + }, + + port: 9876, + colors: true, + logLevel: config.LOG_INFO, + + customLaunchers: { + FirefoxWebExtRunner: { + base: 'FirefoxWebExt', + sourceDirs: [ '.', 'e2e/ambassador'], + }, + }, + browsers: ['FirefoxWebExtRunner'], + sauceLabs: { + username: 'michael_jackson' + }, + + singleRun: true, + + webpackMiddleware: { + noInfo: true + }, + + plugins: [ + require('./karma-webext-launcher'), + 'karma-mocha', + 'karma-webpack', + ], + }) +} -- cgit v1.2.3 From f6f64297aa030cd3fbad4bbb9e322e469bc762e8 Mon Sep 17 00:00:00 2001 From: Shin'ya Ueoka Date: Sun, 4 Feb 2018 19:27:22 +0900 Subject: first webextension test --- e2e/ambassador/src/background/index.js | 12 ++++++++++++ e2e/ambassador/src/background/ipc.js | 7 +++++++ e2e/ambassador/src/client/ipc.js | 29 +++++++++++++++++++++++++++++ e2e/ambassador/src/client/windows.js | 17 +++++++++++++++++ e2e/ambassador/src/content/index.js | 11 +++++++++++ e2e/ambassador/src/content/ipc.js | 31 +++++++++++++++++++++++++++++++ e2e/ambassador/src/shared/messages.js | 12 ++++++++++++ e2e/contents/scroll.test.js | 19 +++++++++++++++++++ e2e/karma-delay.js | 10 ++++++++++ e2e/karma.conf.js | 1 + 10 files changed, 149 insertions(+) create mode 100644 e2e/ambassador/src/background/ipc.js create mode 100644 e2e/ambassador/src/client/ipc.js create mode 100644 e2e/ambassador/src/client/windows.js create mode 100644 e2e/ambassador/src/content/ipc.js create mode 100644 e2e/ambassador/src/shared/messages.js create mode 100644 e2e/contents/scroll.test.js create mode 100644 e2e/karma-delay.js (limited to 'e2e/karma.conf.js') diff --git a/e2e/ambassador/src/background/index.js b/e2e/ambassador/src/background/index.js index e69de29..027c953 100644 --- a/e2e/ambassador/src/background/index.js +++ b/e2e/ambassador/src/background/index.js @@ -0,0 +1,12 @@ +import { WINDOWS_CREATE, WINDOWS_REMOVE } from '../shared/messages'; +import { receiveContentMessage } from './ipc'; + +receiveContentMessage((message) => { + switch (message.type) { + case WINDOWS_CREATE: + return browser.windows.create(); + case WINDOWS_REMOVE: + return browser.windows.remove(message.windowId); + } +}); + diff --git a/e2e/ambassador/src/background/ipc.js b/e2e/ambassador/src/background/ipc.js new file mode 100644 index 0000000..95d2164 --- /dev/null +++ b/e2e/ambassador/src/background/ipc.js @@ -0,0 +1,7 @@ +const receiveContentMessage = (func) => { + browser.runtime.onMessage.addListener((message) => { + return func(message); + }); +}; + +export { receiveContentMessage }; diff --git a/e2e/ambassador/src/client/ipc.js b/e2e/ambassador/src/client/ipc.js new file mode 100644 index 0000000..9f232ea --- /dev/null +++ b/e2e/ambassador/src/client/ipc.js @@ -0,0 +1,29 @@ +import { METHOD_REQUEST, METHOD_RESPONSE } from '../shared/messages'; + +const generateId = () => { + return Math.random().toString(); +}; + +const send = (message) => { + return new Promise((resolve) => { + let id = generateId(); + let callback = (e) => { + let packet = e.data; + if (e.source !== window || packet.method !== METHOD_RESPONSE || + packet.id !== id) { + return; + } + window.removeEventListener('message', callback); + resolve(packet.message); + }; + window.addEventListener('message', callback); + + window.postMessage({ + id, + method: METHOD_REQUEST, + message + }, window.origin); + }); +}; + +export { send }; diff --git a/e2e/ambassador/src/client/windows.js b/e2e/ambassador/src/client/windows.js new file mode 100644 index 0000000..69b8905 --- /dev/null +++ b/e2e/ambassador/src/client/windows.js @@ -0,0 +1,17 @@ +import { WINDOWS_CREATE, WINDOWS_REMOVE } from '../shared/messages'; +import * as ipc from './ipc'; + +const create = () => { + return ipc.send({ + type: WINDOWS_CREATE + }); +}; + +const remove = (windowId) => { + return ipc.send({ + type: WINDOWS_REMOVE, + windowId, + }); +}; + +export { create, remove }; diff --git a/e2e/ambassador/src/content/index.js b/e2e/ambassador/src/content/index.js index e69de29..dd46688 100644 --- a/e2e/ambassador/src/content/index.js +++ b/e2e/ambassador/src/content/index.js @@ -0,0 +1,11 @@ +import { WINDOWS_CREATE, WINDOWS_REMOVE } from '../shared/messages'; +import * as ipc from './ipc'; + +ipc.receivePageMessage((message) => { + switch (message.type) { + case WINDOWS_CREATE: + return ipc.send(message); + case WINDOWS_REMOVE: + return ipc.send(message); + } +}); diff --git a/e2e/ambassador/src/content/ipc.js b/e2e/ambassador/src/content/ipc.js new file mode 100644 index 0000000..62fcac1 --- /dev/null +++ b/e2e/ambassador/src/content/ipc.js @@ -0,0 +1,31 @@ +import { METHOD_REQUEST, METHOD_RESPONSE } from '../shared/messages'; + +const send = (message) => { + return browser.runtime.sendMessage(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 { send, receivePageMessage }; diff --git a/e2e/ambassador/src/shared/messages.js b/e2e/ambassador/src/shared/messages.js new file mode 100644 index 0000000..e8a0438 --- /dev/null +++ b/e2e/ambassador/src/shared/messages.js @@ -0,0 +1,12 @@ +const METHOD_REQUEST = 'request'; +const METHOD_RESPONSE = 'response'; +const WINDOWS_CREATE = 'windows.create'; +const WINDOWS_REMOVE = 'windows.remove'; + +export { + METHOD_REQUEST, + METHOD_RESPONSE, + + WINDOWS_CREATE, + WINDOWS_REMOVE, +}; diff --git a/e2e/contents/scroll.test.js b/e2e/contents/scroll.test.js new file mode 100644 index 0000000..6cf0042 --- /dev/null +++ b/e2e/contents/scroll.test.js @@ -0,0 +1,19 @@ +import { expect } from "chai"; +import * as windows from "../ambassador/src/client/windows"; + +describe("scroll test", () => { + let targetWindow; + before(() => { + return windows.create().then((win) => { + targetWindow = win; + }); + }); + + after(() => { + return windows.remove(targetWindow.id); + }); + + it('runs test', () => { + expect(targetWindow.id).be.a('number'); + }); +}); diff --git a/e2e/karma-delay.js b/e2e/karma-delay.js new file mode 100644 index 0000000..be7b448 --- /dev/null +++ b/e2e/karma-delay.js @@ -0,0 +1,10 @@ +'use strict'; + +window.__karma__.start = (function(start){ +return function(){ + var args = arguments + setTimeout(() => { + start(args) + }, 1000); +}; +}(window.__karma__.start)); diff --git a/e2e/karma.conf.js b/e2e/karma.conf.js index 259eb17..a6c115e 100644 --- a/e2e/karma.conf.js +++ b/e2e/karma.conf.js @@ -4,6 +4,7 @@ module.exports = function (config) { basePath: '', frameworks: ['mocha'], files: [ + 'karma-delay.js', '**/*.test.js' ], -- cgit v1.2.3 From 5737c5b5c075f391b532b22a55715d0a344fe8e0 Mon Sep 17 00:00:00 2001 From: Shin'ya Ueoka Date: Tue, 13 Feb 2018 20:39:47 +0900 Subject: change e2e:test reporter --- e2e/karma.conf.js | 3 +++ 1 file changed, 3 insertions(+) (limited to 'e2e/karma.conf.js') diff --git a/e2e/karma.conf.js b/e2e/karma.conf.js index a6c115e..2b60ca9 100644 --- a/e2e/karma.conf.js +++ b/e2e/karma.conf.js @@ -33,10 +33,13 @@ module.exports = function (config) { noInfo: true }, + reporters: ['mocha'], + plugins: [ require('./karma-webext-launcher'), 'karma-mocha', 'karma-webpack', + 'karma-mocha-reporter', ], }) } -- cgit v1.2.3 From 5cd8c81fda2f07bc6ca5b1ee9264a02fae16c5c0 Mon Sep 17 00:00:00 2001 From: Shin'ya Ueoka Date: Sun, 4 Mar 2018 21:32:50 +0900 Subject: increase timeout --- e2e/karma.conf.js | 1 + 1 file changed, 1 insertion(+) (limited to 'e2e/karma.conf.js') diff --git a/e2e/karma.conf.js b/e2e/karma.conf.js index 2b60ca9..6140ff3 100644 --- a/e2e/karma.conf.js +++ b/e2e/karma.conf.js @@ -34,6 +34,7 @@ module.exports = function (config) { }, reporters: ['mocha'], + browserDisconnectTimeout: 5000, plugins: [ require('./karma-webext-launcher'), -- cgit v1.2.3 From 861f2a80a0f1fb0577d8c55fa1402b848979beb3 Mon Sep 17 00:00:00 2001 From: Shin'ya Ueoka Date: Sun, 11 Mar 2018 10:07:37 +0900 Subject: set mocha timeout --- e2e/karma.conf.js | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'e2e/karma.conf.js') diff --git a/e2e/karma.conf.js b/e2e/karma.conf.js index 6140ff3..5ef4646 100644 --- a/e2e/karma.conf.js +++ b/e2e/karma.conf.js @@ -34,7 +34,6 @@ module.exports = function (config) { }, reporters: ['mocha'], - browserDisconnectTimeout: 5000, plugins: [ require('./karma-webext-launcher'), @@ -42,5 +41,11 @@ module.exports = function (config) { 'karma-webpack', 'karma-mocha-reporter', ], + + client: { + mocha: { + timeout: 5000 + } + } }) } -- cgit v1.2.3