Replace e2e with lanthan
This commit is contained in:
parent
c9a0bf87d0
commit
b04eecce7f
35 changed files with 0 additions and 1354 deletions
|
@ -1,58 +0,0 @@
|
||||||
var http = require('http');
|
|
||||||
var url = require('url');
|
|
||||||
var handlers = require('./handlers');
|
|
||||||
|
|
||||||
class MockServer {
|
|
||||||
constructor() {
|
|
||||||
this.handlers = [];
|
|
||||||
this.server = undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
start() {
|
|
||||||
if (this.server) {
|
|
||||||
throw new Error('Server is already started');
|
|
||||||
}
|
|
||||||
|
|
||||||
let listener = (req, res) => {
|
|
||||||
if (req.method !== 'GET') {
|
|
||||||
res.writeHead(404, {'Content-Type': 'text/plain'});
|
|
||||||
res.end('not found')
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
let u = url.parse(req.url);
|
|
||||||
let handler = this.handlers.find(h => u.pathname == h.pathname);
|
|
||||||
if (!handler) {
|
|
||||||
res.writeHead(404, {'Content-Type': 'text/plain'});
|
|
||||||
res.end('not found')
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
handler.handler(req, res);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.server = http.createServer(listener);
|
|
||||||
this.server.listen();
|
|
||||||
}
|
|
||||||
|
|
||||||
stop() {
|
|
||||||
if (!this.server) {
|
|
||||||
throw new Error('Server is not started');
|
|
||||||
}
|
|
||||||
this.server.close();
|
|
||||||
this.server = undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
port() {
|
|
||||||
if (!this.server) {
|
|
||||||
throw new Error('Server is not started');
|
|
||||||
}
|
|
||||||
return this.server.address().port
|
|
||||||
}
|
|
||||||
|
|
||||||
on(pathname, handler) {
|
|
||||||
this.handlers.push({ pathname, handler });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = MockServer
|
|
|
@ -1,17 +0,0 @@
|
||||||
const handleText = (body) => {
|
|
||||||
return (req, res) => {
|
|
||||||
res.writeHead(200, {'Content-Type': 'text/plane'});
|
|
||||||
res.end(body);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const handleHtml = (body) => {
|
|
||||||
return (req, res) => {
|
|
||||||
res.writeHead(200, {'Content-Type': 'text/html'});
|
|
||||||
res.end(body);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
handleText, handleHtml
|
|
||||||
}
|
|
|
@ -1,28 +0,0 @@
|
||||||
{
|
|
||||||
"manifest_version": 2,
|
|
||||||
"name": "ambassador",
|
|
||||||
"description": "WebExtension test helper",
|
|
||||||
"version": "0.1",
|
|
||||||
"content_scripts": [
|
|
||||||
{
|
|
||||||
"all_frames": true,
|
|
||||||
"matches": [ "<all_urls>" ],
|
|
||||||
"js": [ "build/content.js" ],
|
|
||||||
"run_at": "document_start",
|
|
||||||
"match_about_blank": true
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"background": {
|
|
||||||
"scripts": [
|
|
||||||
"build/background.js"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"permissions": [
|
|
||||||
"history",
|
|
||||||
"sessions",
|
|
||||||
"storage",
|
|
||||||
"tabs",
|
|
||||||
"clipboardRead",
|
|
||||||
"activeTab"
|
|
||||||
]
|
|
||||||
}
|
|
|
@ -1,49 +0,0 @@
|
||||||
import {
|
|
||||||
WINDOWS_CREATE, WINDOWS_REMOVE, WINDOWS_GET,
|
|
||||||
TABS_CREATE, TABS_SELECT_AT, TABS_GET, TABS_UPDATE, TABS_REMOVE,
|
|
||||||
TABS_GET_ZOOM, TABS_SET_ZOOM,
|
|
||||||
EVENT_KEYPRESS, EVENT_KEYDOWN, EVENT_KEYUP,
|
|
||||||
SCROLL_GET, SCROLL_SET,
|
|
||||||
} from '../shared/messages';
|
|
||||||
import * as tabs from './tabs';
|
|
||||||
import { receiveContentMessage } from './ipc';
|
|
||||||
|
|
||||||
receiveContentMessage((message) => {
|
|
||||||
switch (message.type) {
|
|
||||||
case WINDOWS_CREATE:
|
|
||||||
return browser.windows.create({ url: message.url });
|
|
||||||
case WINDOWS_REMOVE:
|
|
||||||
return browser.windows.remove(message.windowId);
|
|
||||||
case WINDOWS_GET:
|
|
||||||
return browser.windows.get(message.windowId, { populate: true });
|
|
||||||
case TABS_CREATE:
|
|
||||||
return tabs.create({
|
|
||||||
url: message.url,
|
|
||||||
windowId: message.windowId,
|
|
||||||
});
|
|
||||||
case TABS_SELECT_AT:
|
|
||||||
return tabs.selectAt({
|
|
||||||
windowId: message.windowId,
|
|
||||||
index: message.index,
|
|
||||||
});
|
|
||||||
case TABS_GET:
|
|
||||||
return browser.tabs.get(message.tabId);
|
|
||||||
case TABS_UPDATE:
|
|
||||||
return browser.tabs.update(message.tabId, message.properties);
|
|
||||||
case TABS_REMOVE:
|
|
||||||
return browser.tabs.remove(message.tabId);
|
|
||||||
case TABS_GET_ZOOM:
|
|
||||||
return browser.tabs.getZoom(message.tabId);
|
|
||||||
case TABS_SET_ZOOM:
|
|
||||||
return browser.tabs.setZoom(message.tabId, message.factor);
|
|
||||||
case EVENT_KEYPRESS:
|
|
||||||
case EVENT_KEYDOWN:
|
|
||||||
case EVENT_KEYUP:
|
|
||||||
case SCROLL_GET:
|
|
||||||
case SCROLL_SET:
|
|
||||||
return browser.tabs.sendMessage(
|
|
||||||
message.tabId,
|
|
||||||
message
|
|
||||||
);
|
|
||||||
}
|
|
||||||
});
|
|
|
@ -1,7 +0,0 @@
|
||||||
const receiveContentMessage = (func) => {
|
|
||||||
browser.runtime.onMessage.addListener((message) => {
|
|
||||||
return func(message);
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
export { receiveContentMessage };
|
|
|
@ -1,28 +0,0 @@
|
||||||
const create = (props = {}) => {
|
|
||||||
return new Promise((resolve) => {
|
|
||||||
browser.tabs.create(props).then((createdTab) => {
|
|
||||||
let callback = (tabId, changeInfo, tab) => {
|
|
||||||
if (tab.url !== 'about:blank' && tabId === createdTab.id &&
|
|
||||||
changeInfo.status === 'complete') {
|
|
||||||
browser.tabs.onUpdated.removeListener(callback);
|
|
||||||
|
|
||||||
// wait for 50 milliseconds to ensure plugin loaded;
|
|
||||||
setTimeout(() => resolve(tab), 50);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
browser.tabs.onUpdated.addListener(callback);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const selectAt = (props = {}) => {
|
|
||||||
return browser.tabs.query({ windowId: props.windowId }).then((tabs) => {
|
|
||||||
let target = tabs[props.index];
|
|
||||||
return browser.tabs.update(target.id, { active: true });
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
export {
|
|
||||||
create, selectAt
|
|
||||||
};
|
|
|
@ -1,29 +0,0 @@
|
||||||
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 };
|
|
|
@ -1,28 +0,0 @@
|
||||||
import { EVENT_KEYPRESS, EVENT_KEYDOWN, EVENT_KEYUP } from '../shared/messages';
|
|
||||||
import * as ipc from './ipc';
|
|
||||||
|
|
||||||
const NEUTRAL_MODIFIERS = { shiftKey: false, altKey: false, ctrlKey: false };
|
|
||||||
|
|
||||||
const press = (tabId, key, modifiers = NEUTRAL_MODIFIERS) => {
|
|
||||||
return ipc.send({ ...modifiers,
|
|
||||||
type: EVENT_KEYPRESS,
|
|
||||||
tabId,
|
|
||||||
key, });
|
|
||||||
};
|
|
||||||
|
|
||||||
const down = (tabId, key, modifiers = NEUTRAL_MODIFIERS) => {
|
|
||||||
return ipc.send({ modifiers,
|
|
||||||
type: EVENT_KEYDOWN,
|
|
||||||
tabId,
|
|
||||||
key, });
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
const up = (tabId, key, modifiers = NEUTRAL_MODIFIERS) => {
|
|
||||||
return ipc.send({ modifiers,
|
|
||||||
type: EVENT_KEYUP,
|
|
||||||
tabId,
|
|
||||||
key, });
|
|
||||||
};
|
|
||||||
|
|
||||||
export { press, down, up };
|
|
|
@ -1,20 +0,0 @@
|
||||||
import { SCROLL_GET, SCROLL_SET } from '../shared/messages';
|
|
||||||
import * as ipc from './ipc';
|
|
||||||
|
|
||||||
const get = (tabId) => {
|
|
||||||
return ipc.send({
|
|
||||||
type: SCROLL_GET,
|
|
||||||
tabId,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const set = (tabId, x, y) => {
|
|
||||||
return ipc.send({
|
|
||||||
type: SCROLL_SET,
|
|
||||||
tabId,
|
|
||||||
x,
|
|
||||||
y,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
export { get, set };
|
|
|
@ -1,60 +0,0 @@
|
||||||
import {
|
|
||||||
TABS_CREATE, TABS_SELECT_AT, TABS_GET, TABS_UPDATE, TABS_REMOVE,
|
|
||||||
TABS_GET_ZOOM, TABS_SET_ZOOM,
|
|
||||||
} from '../shared/messages';
|
|
||||||
import * as ipc from './ipc';
|
|
||||||
|
|
||||||
const create = (windowId, url) => {
|
|
||||||
return ipc.send({
|
|
||||||
type: TABS_CREATE,
|
|
||||||
windowId,
|
|
||||||
url,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const selectAt = (windowId, index) => {
|
|
||||||
return ipc.send({
|
|
||||||
type: TABS_SELECT_AT,
|
|
||||||
windowId,
|
|
||||||
index,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const get = (tabId) => {
|
|
||||||
return ipc.send({
|
|
||||||
type: TABS_GET,
|
|
||||||
tabId,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const update = (tabId, properties) => {
|
|
||||||
return ipc.send({
|
|
||||||
type: TABS_UPDATE,
|
|
||||||
tabId,
|
|
||||||
properties,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const remove = (tabId) => {
|
|
||||||
return ipc.send({
|
|
||||||
type: TABS_REMOVE,
|
|
||||||
tabId
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const getZoom = (tabId) => {
|
|
||||||
return ipc.send({
|
|
||||||
tabId,
|
|
||||||
type: TABS_GET_ZOOM,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const setZoom = (tabId, factor) => {
|
|
||||||
return ipc.send({
|
|
||||||
type: TABS_SET_ZOOM,
|
|
||||||
tabId,
|
|
||||||
factor,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
export { create, selectAt, get, update, remove, getZoom, setZoom };
|
|
|
@ -1,27 +0,0 @@
|
||||||
import {
|
|
||||||
WINDOWS_CREATE, WINDOWS_REMOVE, WINDOWS_GET
|
|
||||||
} from '../shared/messages';
|
|
||||||
import * as ipc from './ipc';
|
|
||||||
|
|
||||||
const create = (url) => {
|
|
||||||
return ipc.send({
|
|
||||||
type: WINDOWS_CREATE,
|
|
||||||
url,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const remove = (windowId) => {
|
|
||||||
return ipc.send({
|
|
||||||
type: WINDOWS_REMOVE,
|
|
||||||
windowId,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
const get = (windowId) => {
|
|
||||||
return ipc.send({
|
|
||||||
type: WINDOWS_GET,
|
|
||||||
windowId,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
export { create, remove, get };
|
|
|
@ -1,31 +0,0 @@
|
||||||
const keypress = (opts) => {
|
|
||||||
let event = new KeyboardEvent('keypress', {
|
|
||||||
key: opts.key,
|
|
||||||
altKey: opts.altKey,
|
|
||||||
shiftKey: opts.shiftKey,
|
|
||||||
ctrlKey: opts.ctrlKey
|
|
||||||
});
|
|
||||||
document.body.dispatchEvent(event);
|
|
||||||
};
|
|
||||||
|
|
||||||
const keydown = (opts) => {
|
|
||||||
let event = new KeyboardEvent('keydown', {
|
|
||||||
key: opts.key,
|
|
||||||
altKey: opts.altKey,
|
|
||||||
shiftKey: opts.shiftKey,
|
|
||||||
ctrlKey: opts.ctrlKey
|
|
||||||
});
|
|
||||||
document.body.dispatchEvent(event);
|
|
||||||
};
|
|
||||||
|
|
||||||
const keyup = (opts) => {
|
|
||||||
let event = new KeyboardEvent('keyup', {
|
|
||||||
key: opts.key,
|
|
||||||
altKey: opts.altKey,
|
|
||||||
shiftKey: opts.shiftKey,
|
|
||||||
ctrlKey: opts.ctrlKey
|
|
||||||
});
|
|
||||||
document.body.dispatchEvent(event);
|
|
||||||
};
|
|
||||||
|
|
||||||
export { keypress, keydown, keyup };
|
|
|
@ -1,30 +0,0 @@
|
||||||
import {
|
|
||||||
EVENT_KEYPRESS, EVENT_KEYDOWN, EVENT_KEYUP,
|
|
||||||
SCROLL_GET, SCROLL_SET,
|
|
||||||
} from '../shared/messages';
|
|
||||||
import * as ipc from './ipc';
|
|
||||||
import * as events from './events';
|
|
||||||
import * as scrolls from './scrolls';
|
|
||||||
|
|
||||||
ipc.receivePageMessage((message) => {
|
|
||||||
return ipc.sendToBackground(message);
|
|
||||||
});
|
|
||||||
|
|
||||||
ipc.receiveBackgroundMesssage((message) => {
|
|
||||||
switch (message.type) {
|
|
||||||
case EVENT_KEYPRESS:
|
|
||||||
events.keypress(message);
|
|
||||||
break;
|
|
||||||
case EVENT_KEYDOWN:
|
|
||||||
events.keydown(message);
|
|
||||||
break;
|
|
||||||
case EVENT_KEYUP:
|
|
||||||
events.keyup(message);
|
|
||||||
break;
|
|
||||||
case SCROLL_GET:
|
|
||||||
return Promise.resolve(scrolls.get());
|
|
||||||
case SCROLL_SET:
|
|
||||||
return Promise.resolve(scrolls.set(message.x, message.y));
|
|
||||||
}
|
|
||||||
return Promise.resolve({});
|
|
||||||
});
|
|
|
@ -1,40 +0,0 @@
|
||||||
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,
|
|
||||||
};
|
|
|
@ -1,20 +0,0 @@
|
||||||
const get = () => {
|
|
||||||
let element = document.documentElement;
|
|
||||||
return {
|
|
||||||
xMax: element.scrollWidth - element.clientWidth,
|
|
||||||
yMax: element.scrollHeight - element.clientHeight,
|
|
||||||
x: element.scrollLeft,
|
|
||||||
y: element.scrollTop,
|
|
||||||
frameWidth: element.clientWidth,
|
|
||||||
frameHeight: element.clientHeight,
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
const set = (x, y) => {
|
|
||||||
let element = document.documentElement;
|
|
||||||
element.scrollLeft = x;
|
|
||||||
element.scrollTop = y;
|
|
||||||
return get();
|
|
||||||
};
|
|
||||||
|
|
||||||
export { get, set };
|
|
|
@ -1,40 +0,0 @@
|
||||||
const METHOD_REQUEST = 'request';
|
|
||||||
const METHOD_RESPONSE = 'response';
|
|
||||||
const WINDOWS_CREATE = 'windows.create';
|
|
||||||
const WINDOWS_REMOVE = 'windows.remove';
|
|
||||||
const WINDOWS_GET = 'windows.get';
|
|
||||||
const TABS_CREATE = 'tabs.create';
|
|
||||||
const TABS_SELECT_AT = 'tabs.selectAt';
|
|
||||||
const TABS_GET = 'tabs.get';
|
|
||||||
const TABS_UPDATE = 'tabs.update';
|
|
||||||
const TABS_REMOVE = 'tabs.remove';
|
|
||||||
const TABS_GET_ZOOM = 'tabs.get.zoom';
|
|
||||||
const TABS_SET_ZOOM = 'tabs.set.zoom';
|
|
||||||
const EVENT_KEYPRESS = 'event.keypress';
|
|
||||||
const EVENT_KEYDOWN = 'event.keydown';
|
|
||||||
const EVENT_KEYUP = 'event.keyup';
|
|
||||||
const SCROLL_GET = 'scroll.get';
|
|
||||||
const SCROLL_SET = 'scroll.set';
|
|
||||||
|
|
||||||
export {
|
|
||||||
METHOD_REQUEST,
|
|
||||||
METHOD_RESPONSE,
|
|
||||||
|
|
||||||
WINDOWS_CREATE,
|
|
||||||
WINDOWS_REMOVE,
|
|
||||||
WINDOWS_GET,
|
|
||||||
|
|
||||||
TABS_GET,
|
|
||||||
TABS_UPDATE,
|
|
||||||
TABS_CREATE,
|
|
||||||
TABS_SELECT_AT,
|
|
||||||
TABS_GET_ZOOM,
|
|
||||||
TABS_SET_ZOOM,
|
|
||||||
TABS_REMOVE,
|
|
||||||
|
|
||||||
EVENT_KEYPRESS,
|
|
||||||
EVENT_KEYDOWN,
|
|
||||||
EVENT_KEYUP,
|
|
||||||
SCROLL_GET,
|
|
||||||
SCROLL_SET,
|
|
||||||
};
|
|
|
@ -1,24 +0,0 @@
|
||||||
const path = require('path');
|
|
||||||
|
|
||||||
const src = path.resolve(__dirname, 'src');
|
|
||||||
const dist = path.resolve(__dirname, 'build');
|
|
||||||
|
|
||||||
config = {
|
|
||||||
entry: {
|
|
||||||
content: path.join(src, 'content'),
|
|
||||||
background: path.join(src, 'background')
|
|
||||||
},
|
|
||||||
|
|
||||||
output: {
|
|
||||||
path: dist,
|
|
||||||
filename: '[name].js'
|
|
||||||
},
|
|
||||||
|
|
||||||
resolve: {
|
|
||||||
extensions: [ '.js' ],
|
|
||||||
modules: [path.join(__dirname, 'src'), 'node_modules']
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
module.exports = config
|
|
||||||
|
|
|
@ -1,83 +0,0 @@
|
||||||
import * as windows from "../ambassador/src/client/windows";
|
|
||||||
import * as tabs from "../ambassador/src/client/tabs";
|
|
||||||
import * as keys from "../ambassador/src/client/keys";
|
|
||||||
import { CLIENT_URL } from '../web-server/url';
|
|
||||||
|
|
||||||
describe("tab test", () => {
|
|
||||||
let targetWindow;
|
|
||||||
|
|
||||||
beforeEach(async () => {
|
|
||||||
targetWindow = await windows.create(CLIENT_URL);
|
|
||||||
});
|
|
||||||
|
|
||||||
afterEach(async () => {
|
|
||||||
await windows.remove(targetWindow.id);
|
|
||||||
});return
|
|
||||||
|
|
||||||
it('follows link by `f`', async() => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/follow');
|
|
||||||
await keys.press(tab.id, 'f');
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 10) });
|
|
||||||
await keys.press(tab.id, 'a');
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 10) });
|
|
||||||
|
|
||||||
tab = tabs.get(tab.id);
|
|
||||||
expect(tab.url).to.be.equal(CLIENT_URL + '/follow#a');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('follows link into new tab by `F`', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/follow');
|
|
||||||
await keys.press(tab.id, 'F', { shiftKey: true });
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 10) });
|
|
||||||
await keys.press(tab.id, 'a');
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 500) });
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
let urls = win.tabs.map(t => t.url);
|
|
||||||
expect(urls).to.have.lengthOf(3);
|
|
||||||
expect(urls).to.include(CLIENT_URL + '/');
|
|
||||||
expect(urls).to.include(CLIENT_URL + '/follow');
|
|
||||||
expect(urls).to.include(CLIENT_URL + '/follow#a');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('follows link with target=_blank into new tab by `f`', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/follow');
|
|
||||||
await keys.press(tab.id, 'f');
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 10) });
|
|
||||||
await keys.press(tab.id, 'b');
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 500) });
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
let urls = win.tabs.map(t => t.url);
|
|
||||||
expect(urls).to.have.lengthOf(3);
|
|
||||||
expect(urls).to.include(CLIENT_URL + '/');
|
|
||||||
expect(urls).to.include(CLIENT_URL + '/follow');
|
|
||||||
expect(urls).to.include(CLIENT_URL + '/follow#external');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('follows link with target=_blank into new tab by `F`', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/follow');
|
|
||||||
await keys.press(tab.id, 'F', { shiftKey: true });
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 10) });
|
|
||||||
await keys.press(tab.id, 'b');
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 500) });
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
let urls = win.tabs.map(t => t.url);
|
|
||||||
expect(urls).to.have.lengthOf(3);
|
|
||||||
expect(urls).to.include(CLIENT_URL + '/');
|
|
||||||
expect(urls).to.include(CLIENT_URL + '/follow');
|
|
||||||
expect(urls).to.include(CLIENT_URL + '/follow#external');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('follows area by `F`', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/follow');
|
|
||||||
await keys.press(tab.id, 'f');
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 10) });
|
|
||||||
await keys.press(tab.id, 'c');
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 10) });
|
|
||||||
|
|
||||||
tab = await tabs.get(tab.id);
|
|
||||||
expect(tab.url).to.be.equal(CLIENT_URL + '/follow#area');
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,71 +0,0 @@
|
||||||
import * as windows from "../ambassador/src/client/windows";
|
|
||||||
import * as tabs from "../ambassador/src/client/tabs";
|
|
||||||
import * as keys from "../ambassador/src/client/keys";
|
|
||||||
import * as scrolls from "../ambassador/src/client/scrolls";
|
|
||||||
import { CLIENT_URL } from '../web-server/url';
|
|
||||||
|
|
||||||
describe("mark test", () => {
|
|
||||||
let targetWindow;
|
|
||||||
|
|
||||||
before(async () => {
|
|
||||||
targetWindow = await windows.create();
|
|
||||||
});
|
|
||||||
|
|
||||||
after(async () => {
|
|
||||||
await windows.remove(targetWindow.id);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('set a local mark and jump to it', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/mark#local');
|
|
||||||
await scrolls.set(tab.id, 100, 100);
|
|
||||||
await keys.press(tab.id, 'm');
|
|
||||||
await keys.press(tab.id, 'a');
|
|
||||||
|
|
||||||
await scrolls.set(tab.id, 200, 200);
|
|
||||||
await keys.press(tab.id, "'");
|
|
||||||
await keys.press(tab.id, 'a');
|
|
||||||
|
|
||||||
let scroll = await scrolls.get(tab.id);
|
|
||||||
expect(scroll.x).to.be.equals(100);
|
|
||||||
expect(scroll.y).to.be.equals(100);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('set a global mark and jump to it', async () => {
|
|
||||||
let tab1 = await tabs.create(targetWindow.id, CLIENT_URL + '/mark#global1');
|
|
||||||
await scrolls.set(tab1.id, 100, 100);
|
|
||||||
await keys.press(tab1.id, 'm');
|
|
||||||
await keys.press(tab1.id, 'A');
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 100) });
|
|
||||||
await scrolls.set(tab1.id, 200, 200);
|
|
||||||
|
|
||||||
let tab2 = await tabs.create(targetWindow.id, CLIENT_URL + '/mark#global2');
|
|
||||||
await keys.press(tab2.id, "'");
|
|
||||||
await keys.press(tab2.id, 'A');
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 100) });
|
|
||||||
|
|
||||||
tab1 = await tabs.get(tab1.id);
|
|
||||||
expect(tab1.active).to.be.true;
|
|
||||||
let scroll = await scrolls.get(tab1.id);
|
|
||||||
expect(scroll.x).to.be.equals(100);
|
|
||||||
expect(scroll.y).to.be.equals(100);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('set a global mark and creates new tab from gone', async () => {
|
|
||||||
let tab1 = await tabs.create(targetWindow.id, CLIENT_URL + '/mark#gone');
|
|
||||||
await scrolls.set(tab1.id, 100, 100);
|
|
||||||
await keys.press(tab1.id, 'm');
|
|
||||||
await keys.press(tab1.id, 'A');
|
|
||||||
await tabs.remove(tab1.id);
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 100) });
|
|
||||||
|
|
||||||
let tab2 = await tabs.create(targetWindow.id, CLIENT_URL + '/mark#newtab');
|
|
||||||
await keys.press(tab2.id, "'");
|
|
||||||
await keys.press(tab2.id, 'A');
|
|
||||||
await new Promise(resolve => { setTimeout(() => resolve(), 100) });
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
let found = win.tabs.find(tab => tab.url === CLIENT_URL + '/mark#gone')
|
|
||||||
expect(found).to.be.an('object');
|
|
||||||
expect(found.id).to.not.equal(tab1.id);
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,102 +0,0 @@
|
||||||
import * as windows from "../ambassador/src/client/windows";
|
|
||||||
import * as tabs from "../ambassador/src/client/tabs";
|
|
||||||
import * as keys from "../ambassador/src/client/keys";
|
|
||||||
import * as scrolls from "../ambassador/src/client/scrolls";
|
|
||||||
import { CLIENT_URL } from '../web-server/url';
|
|
||||||
|
|
||||||
describe("navigate test", () => {
|
|
||||||
let targetWindow;
|
|
||||||
|
|
||||||
before(async () => {
|
|
||||||
targetWindow = await windows.create();
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL);
|
|
||||||
});
|
|
||||||
|
|
||||||
after(async () => {
|
|
||||||
await windows.remove(targetWindow.id);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('goes to parent', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/a/b/c');
|
|
||||||
await keys.press(tab.id, 'g');
|
|
||||||
await keys.press(tab.id, 'u');
|
|
||||||
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
||||||
|
|
||||||
tab = await tabs.get(tab.id);
|
|
||||||
expect(tab.url).to.be.equal(CLIENT_URL + '/a/b/');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('removes hash', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/a/b/c#navigate');
|
|
||||||
await keys.press(tab.id, 'g');
|
|
||||||
await keys.press(tab.id, 'u');
|
|
||||||
tab = await tabs.get(tab.id);
|
|
||||||
expect(tab.url).to.be.equal(CLIENT_URL + '/a/b/c#');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('goes to root', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/a/b/c');
|
|
||||||
await keys.press(tab.id, 'g');
|
|
||||||
await keys.press(tab.id, 'U', { shiftKey: true });
|
|
||||||
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
||||||
|
|
||||||
tab = await tabs.get(tab.id);
|
|
||||||
expect(tab.url).to.be.equal(CLIENT_URL + '/');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('goes back and forward in history', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/#navigate');
|
|
||||||
await keys.press(tab.id, 'g');
|
|
||||||
await keys.press(tab.id, 'u');
|
|
||||||
await keys.press(tab.id, 'H', { shiftKey: true });
|
|
||||||
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
||||||
|
|
||||||
tab = await tabs.get(tab.id);
|
|
||||||
expect(tab.url, 'go back in history').to.be.equal(CLIENT_URL + '/#navigate');
|
|
||||||
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
||||||
await keys.press(tab.id, 'L', { shiftKey: true });
|
|
||||||
|
|
||||||
tab = await tabs.get(tab.id);
|
|
||||||
expect(tab.url, 'go next in history').to.be.equal(CLIENT_URL + '/#');
|
|
||||||
});
|
|
||||||
|
|
||||||
it('goes previous page by <a>', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/a-pagenation?page=10');
|
|
||||||
await keys.press(tab.id, '[');
|
|
||||||
await keys.press(tab.id, '[');
|
|
||||||
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
||||||
|
|
||||||
tab = await tabs.get(tab.id);
|
|
||||||
expect(tab.url).to.be.equal(CLIENT_URL + '/a-pagenation?page=9');
|
|
||||||
})
|
|
||||||
|
|
||||||
it('goes next page by <a>', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/a-pagenation?page=10');
|
|
||||||
await keys.press(tab.id, ']');
|
|
||||||
await keys.press(tab.id, ']');
|
|
||||||
await new Promise((resolve) => setTimeout(resolve, 100));
|
|
||||||
|
|
||||||
tab = await tabs.get(tab.id);
|
|
||||||
expect(tab.url).to.be.equal(CLIENT_URL + '/a-pagenation?page=11');
|
|
||||||
})
|
|
||||||
|
|
||||||
it('goes previous page by <link>', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/link-pagenation?page=10');
|
|
||||||
await keys.press(tab.id, '[');
|
|
||||||
await keys.press(tab.id, '[');
|
|
||||||
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
||||||
|
|
||||||
tab = await tabs.get(tab.id);
|
|
||||||
expect(tab.url).to.be.equal(CLIENT_URL + '/link-pagenation?page=9');
|
|
||||||
})
|
|
||||||
|
|
||||||
it('goes next page by <link>', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '/link-pagenation?page=10');
|
|
||||||
await keys.press(tab.id, ']');
|
|
||||||
await keys.press(tab.id, ']');
|
|
||||||
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
||||||
|
|
||||||
tab = await tabs.get(tab.id);
|
|
||||||
expect(tab.url).to.be.equal(CLIENT_URL + '/link-pagenation?page=11');
|
|
||||||
})
|
|
||||||
});
|
|
|
@ -1,106 +0,0 @@
|
||||||
import * as windows from "../ambassador/src/client/windows";
|
|
||||||
import * as tabs from "../ambassador/src/client/tabs";
|
|
||||||
import * as keys from "../ambassador/src/client/keys";
|
|
||||||
import * as scrolls from "../ambassador/src/client/scrolls";
|
|
||||||
import { CLIENT_URL } from '../web-server/url';
|
|
||||||
|
|
||||||
describe("scroll test", () => {
|
|
||||||
let targetWindow;
|
|
||||||
let targetTab;
|
|
||||||
|
|
||||||
before(async () => {
|
|
||||||
targetWindow = await windows.create();
|
|
||||||
targetTab = await tabs.create(targetWindow.id, CLIENT_URL + '/scroll');
|
|
||||||
});
|
|
||||||
|
|
||||||
after(async () => {
|
|
||||||
await windows.remove(targetWindow.id);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('scrolls up by k', async () => {
|
|
||||||
let before = await scrolls.set(targetTab.id, 100, 100);
|
|
||||||
await keys.press(targetTab.id, 'k');
|
|
||||||
|
|
||||||
let actual = await scrolls.get(targetTab.id);
|
|
||||||
expect(actual.y).to.be.lessThan(before.y);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('scrolls down by j', async () => {
|
|
||||||
let before = await scrolls.set(targetTab.id, 100, 100);
|
|
||||||
await keys.press(targetTab.id, 'j');
|
|
||||||
|
|
||||||
let actual = await scrolls.get(targetTab.id);
|
|
||||||
expect(actual.y).to.be.greaterThan(before.y);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('scrolls left by h', async () => {
|
|
||||||
let before = await scrolls.set(targetTab.id, 100, 100)
|
|
||||||
await keys.press(targetTab.id, 'h');
|
|
||||||
|
|
||||||
let actual = await scrolls.get(targetTab.id);
|
|
||||||
expect(actual.x).to.be.lessThan(before.x);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('scrolls top by gg', async () => {
|
|
||||||
await scrolls.set(targetTab.id, 100, 100);
|
|
||||||
await keys.press(targetTab.id, 'g');
|
|
||||||
await keys.press(targetTab.id, 'g');
|
|
||||||
let actual = await scrolls.get(targetTab.id);
|
|
||||||
expect(actual.y).to.be.equals(0);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('scrolls bottom by G', async () => {
|
|
||||||
await scrolls.set(targetTab.id, 100, 100);
|
|
||||||
await keys.press(targetTab.id, 'G', { shiftKey: true });
|
|
||||||
|
|
||||||
let actual = await scrolls.get(targetTab.id);
|
|
||||||
expect(actual.y).to.be.equals(actual.yMax);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('scrolls bottom by 0', async () => {
|
|
||||||
await scrolls.set(targetTab.id, 100, 100);
|
|
||||||
await keys.press(targetTab.id, '0');
|
|
||||||
|
|
||||||
let actual = await scrolls.get(targetTab.id);
|
|
||||||
expect(actual.x).to.be.equals(0);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('scrolls bottom by $', async () => {
|
|
||||||
await scrolls.set(targetTab.id, 100, 100);
|
|
||||||
await keys.press(targetTab.id, '$');
|
|
||||||
|
|
||||||
let actual = await scrolls.get(targetTab.id);
|
|
||||||
expect(actual.x).to.be.equals(actual.xMax);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('scrolls bottom by <C-U>', async () => {
|
|
||||||
let before = await scrolls.set(targetTab.id, 5000, 5000);
|
|
||||||
await keys.press(targetTab.id, 'u', { ctrlKey: true });
|
|
||||||
|
|
||||||
let actual = await scrolls.get(targetTab.id);
|
|
||||||
expect(actual.y).to.closeTo(before.y - before.frameHeight / 2, 1);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('scrolls bottom by <C-D>', async () => {
|
|
||||||
let before = await scrolls.set(targetTab.id, 5000, 5000);
|
|
||||||
await keys.press(targetTab.id, 'd', { ctrlKey: true });
|
|
||||||
|
|
||||||
let actual = await scrolls.get(targetTab.id);
|
|
||||||
expect(actual.y).to.closeTo(before.y + before.frameHeight / 2, 1);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('scrolls bottom by <C-B>', async () => {
|
|
||||||
let before = await scrolls.set(targetTab.id, 5000, 5000);
|
|
||||||
await keys.press(targetTab.id, 'b', { ctrlKey: true });
|
|
||||||
|
|
||||||
let actual = await await scrolls.get(targetTab.id);
|
|
||||||
expect(actual.y).to.equals(before.y - before.frameHeight);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('scrolls bottom by <C-F>', async () => {
|
|
||||||
let before = await scrolls.set(targetTab.id, 5000, 5000);
|
|
||||||
await keys.press(targetTab.id, 'f', { ctrlKey: true });
|
|
||||||
let actual = await scrolls.get(targetTab.id);
|
|
||||||
expect(actual.y).to.equals(before.y + before.frameHeight);
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,192 +0,0 @@
|
||||||
import * as windows from "../ambassador/src/client/windows";
|
|
||||||
import * as tabs from "../ambassador/src/client/tabs";
|
|
||||||
import * as keys from "../ambassador/src/client/keys";
|
|
||||||
import { CLIENT_URL } from '../web-server/url';
|
|
||||||
|
|
||||||
describe("tab test", () => {
|
|
||||||
let targetWindow;
|
|
||||||
|
|
||||||
beforeEach(async () => {
|
|
||||||
targetWindow = await windows.create(CLIENT_URL);
|
|
||||||
});
|
|
||||||
|
|
||||||
afterEach(async () => {
|
|
||||||
await windows.remove(targetWindow.id);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('deletes tab by d', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL);
|
|
||||||
let before = await windows.get(targetWindow.id);
|
|
||||||
await keys.press(tab.id, 'd');
|
|
||||||
|
|
||||||
let actual = await windows.get(targetWindow.id);
|
|
||||||
expect(actual.tabs).to.have.lengthOf(before.tabs.length - 1);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('deletes tabs to the right by D', async () => {
|
|
||||||
let tab1 = await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#2');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#3');
|
|
||||||
|
|
||||||
let before = await windows.get(targetWindow.id)
|
|
||||||
let tab = await tabs.selectAt(targetWindow.id, tab1.index)
|
|
||||||
await keys.press(tab.id, 'D', { shiftKey: true });
|
|
||||||
|
|
||||||
let actual = await windows.get(targetWindow.id);
|
|
||||||
expect(actual.tabs).to.have.lengthOf(before.tabs.length - 2);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('duplicates tab by zd', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL);
|
|
||||||
let before = await windows.get(targetWindow.id)
|
|
||||||
await keys.press(tab.id, 'z');
|
|
||||||
await keys.press(tab.id, 'd');
|
|
||||||
|
|
||||||
let actual = await windows.get(targetWindow.id);
|
|
||||||
expect(actual.tabs).to.have.lengthOf(before.tabs.length + 1);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('makes pinned by zp', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL);
|
|
||||||
let before = await windows.get(targetWindow.id);
|
|
||||||
await keys.press(tab.id, 'z');
|
|
||||||
await keys.press(tab.id, 'p');
|
|
||||||
|
|
||||||
let actual = await windows.get(targetWindow.id);
|
|
||||||
expect(actual.tabs[0].pinned).to.be.true;
|
|
||||||
});
|
|
||||||
|
|
||||||
it('selects previous tab by K', async () => {
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#2');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#3');
|
|
||||||
let tab = await tabs.selectAt(targetWindow.id, 2);
|
|
||||||
await keys.press(tab.id, 'K', { shiftKey: true });
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs[1].active).to.be.true;
|
|
||||||
});
|
|
||||||
|
|
||||||
it('selects previous tab by K rotatory', async () => {
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#2');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#3');
|
|
||||||
let tab = await tabs.selectAt(targetWindow.id, 0);
|
|
||||||
await keys.press(tab.id, 'K', { shiftKey: true });
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs[3].active).to.be.true;
|
|
||||||
});
|
|
||||||
|
|
||||||
it('selects next tab by J', async () => {
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#2');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#3');
|
|
||||||
let tab = await tabs.selectAt(targetWindow.id, 2);
|
|
||||||
await keys.press(tab.id, 'J', { shiftKey: true });
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs[3].active).to.be.true;
|
|
||||||
});
|
|
||||||
|
|
||||||
it('selects previous tab by J rotatory', async () => {
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#2');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#3');
|
|
||||||
let tab = await tabs.selectAt(targetWindow.id, 3);
|
|
||||||
await keys.press(tab.id, 'J', { shiftKey: true });
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs[0].active).to.be.true;
|
|
||||||
});
|
|
||||||
|
|
||||||
it('selects first tab by g0', async () => {
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#2');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#3');
|
|
||||||
let tab = await tabs.selectAt(targetWindow.id, 2);
|
|
||||||
await keys.press(tab.id, 'g');
|
|
||||||
await keys.press(tab.id, '0');
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs[0].active).to.be.true;
|
|
||||||
});
|
|
||||||
|
|
||||||
it('selects last tab by g$', async () => {
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#2');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#3');
|
|
||||||
let tab = await tabs.selectAt(targetWindow.id, 2);
|
|
||||||
await keys.press(tab.id, 'g');
|
|
||||||
await keys.press(tab.id, '$');
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs[3].active).to.be.true;
|
|
||||||
});
|
|
||||||
|
|
||||||
it('selects last selected tab by <C-6>', async () => {
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#2');
|
|
||||||
await tabs.create(targetWindow.id, CLIENT_URL + '#3');
|
|
||||||
await tabs.selectAt(targetWindow.id, 1);
|
|
||||||
let tab = await tabs.selectAt(targetWindow.id, 3);
|
|
||||||
await keys.press(tab.id, '6', { ctrlKey: true });
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs[1].active).to.be.true;
|
|
||||||
});
|
|
||||||
|
|
||||||
it('deletes tab by d', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
await keys.press(tab.id, 'd');
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs).to.have.lengthOf(1);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('reopen tab by u', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
await keys.press(tab.id, 'd');
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs).to.have.lengthOf(1);
|
|
||||||
|
|
||||||
await keys.press(win.tabs[0].id, 'u');
|
|
||||||
await new Promise(resolve => setTimeout(resolve, 100));
|
|
||||||
|
|
||||||
win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs).to.have.lengthOf(2);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('does not delete pinned tab by d', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
tab = await tabs.update(tab.id, { pinned: true });
|
|
||||||
await keys.press(tab.id, 'd');
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs).to.have.lengthOf(2);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('deletes pinned tab by !d', async () => {
|
|
||||||
let tab = await tabs.create(targetWindow.id, CLIENT_URL + '#1');
|
|
||||||
tab = await tabs.update(tab.id, { pinned: true });
|
|
||||||
await keys.press(tab.id, '!');
|
|
||||||
await keys.press(tab.id, 'd');
|
|
||||||
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
expect(win.tabs).to.have.lengthOf(1);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('opens view-source by gf', async () => {
|
|
||||||
await new Promise(resolve => setTimeout(resolve, 100));
|
|
||||||
let win = await windows.get(targetWindow.id);
|
|
||||||
let tab = win.tabs[0];
|
|
||||||
await keys.press(tab.id, 'g');
|
|
||||||
await keys.press(tab.id, 'f');
|
|
||||||
await new Promise(resolve => setTimeout(resolve, 500));
|
|
||||||
|
|
||||||
win = await windows.get(targetWindow.id);
|
|
||||||
let urls = win.tabs.map((t) => t.url)
|
|
||||||
expect(urls).to.include.members([CLIENT_URL + '/', 'view-source:' + CLIENT_URL + '/']);
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,53 +0,0 @@
|
||||||
import * as windows from "../ambassador/src/client/windows";
|
|
||||||
import * as tabs from "../ambassador/src/client/tabs";
|
|
||||||
import * as keys from "../ambassador/src/client/keys";
|
|
||||||
import { CLIENT_URL } from '../web-server/url';
|
|
||||||
|
|
||||||
describe("zoom test", () => {
|
|
||||||
let targetWindow;
|
|
||||||
let targetTab;
|
|
||||||
|
|
||||||
before(async () => {
|
|
||||||
targetWindow = await windows.create(CLIENT_URL);
|
|
||||||
});
|
|
||||||
|
|
||||||
after(async () => {
|
|
||||||
await windows.remove(targetWindow.id);
|
|
||||||
});
|
|
||||||
|
|
||||||
beforeEach(async () => {
|
|
||||||
targetTab = await tabs.create(targetWindow.id, CLIENT_URL);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('zooms-in by zi', async () => {
|
|
||||||
let before = await tabs.getZoom(targetTab.id);
|
|
||||||
await keys.press(targetTab.id, 'z');
|
|
||||||
await keys.press(targetTab.id, 'i');
|
|
||||||
await new Promise(resolve => setTimeout(resolve, 100));
|
|
||||||
|
|
||||||
let actual = await tabs.getZoom(targetTab.id);
|
|
||||||
expect(actual).to.be.greaterThan(before);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('zooms-in by zo', async () => {
|
|
||||||
let before = await tabs.getZoom(targetTab.id);
|
|
||||||
await keys.press(targetTab.id, 'z');
|
|
||||||
await keys.press(targetTab.id, 'o');
|
|
||||||
await new Promise(resolve => setTimeout(resolve, 100));
|
|
||||||
|
|
||||||
let actual = await tabs.getZoom(targetTab.id);
|
|
||||||
expect(actual).to.be.lessThan(before);
|
|
||||||
});
|
|
||||||
|
|
||||||
it('zooms-in by zz', async () => {
|
|
||||||
await tabs.setZoom(targetTab.id, 1.5);
|
|
||||||
let before = await tabs.getZoom(targetTab.id);
|
|
||||||
await keys.press(targetTab.id, 'z');
|
|
||||||
await keys.press(targetTab.id, 'z');
|
|
||||||
await new Promise(resolve => setTimeout(resolve, 100));
|
|
||||||
|
|
||||||
let actual = await tabs.getZoom(targetTab.id);
|
|
||||||
expect(actual).to.be.lessThan(before);
|
|
||||||
expect(actual).to.equal(1);
|
|
||||||
});
|
|
||||||
});
|
|
|
@ -1,10 +0,0 @@
|
||||||
'use strict';
|
|
||||||
|
|
||||||
window.__karma__.start = (function(start){
|
|
||||||
return function(){
|
|
||||||
var args = arguments
|
|
||||||
setTimeout(() => {
|
|
||||||
start(args)
|
|
||||||
}, 3000);
|
|
||||||
};
|
|
||||||
}(window.__karma__.start));
|
|
|
@ -1,53 +0,0 @@
|
||||||
'use strict'
|
|
||||||
|
|
||||||
var fs = require('fs')
|
|
||||||
var path = require('path')
|
|
||||||
|
|
||||||
var PREFS = {
|
|
||||||
'browser.shell.checkDefaultBrowser': 'false',
|
|
||||||
'browser.bookmarks.restore_default_bookmarks': 'false',
|
|
||||||
'dom.disable_open_during_load': 'false',
|
|
||||||
'dom.max_script_run_time': '0',
|
|
||||||
'dom.min_background_timeout_value': '10',
|
|
||||||
'extensions.autoDisableScopes': '0',
|
|
||||||
'extensions.enabledScopes': '15',
|
|
||||||
}
|
|
||||||
|
|
||||||
var FirefoxWebExt = function (id, baseBrowserDecorator, args) {
|
|
||||||
baseBrowserDecorator(this)
|
|
||||||
|
|
||||||
this._start = function (url) {
|
|
||||||
var self = this
|
|
||||||
var command = this._getCommand()
|
|
||||||
|
|
||||||
let prefArgs = [].concat(...Object.keys(PREFS).map((key) => {
|
|
||||||
return ['--pref', key + '=' + PREFS[key]];
|
|
||||||
}));
|
|
||||||
let sourceDirArgs = [].concat(...args.sourceDirs.map((dir) => {
|
|
||||||
return ['--source-dir', dir];
|
|
||||||
}));
|
|
||||||
|
|
||||||
self._execCommand(
|
|
||||||
command,
|
|
||||||
['run', '--start-url', url, '--no-input'].concat(sourceDirArgs, prefArgs)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
FirefoxWebExt.prototype = {
|
|
||||||
name: 'FirefoxWebExt',
|
|
||||||
|
|
||||||
DEFAULT_CMD: {
|
|
||||||
linux: 'node_modules/web-ext/bin/web-ext',
|
|
||||||
darwin: 'node_modules/web-ext/bin/web-ext',
|
|
||||||
win32: 'node_modules/web-ext/bin/web-ext',
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
FirefoxWebExt.$inject = ['id', 'baseBrowserDecorator', 'args']
|
|
||||||
|
|
||||||
// PUBLISH DI MODULE
|
|
||||||
module.exports = {
|
|
||||||
'launcher:FirefoxWebExt': ['type', FirefoxWebExt],
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,53 +0,0 @@
|
||||||
module.exports = function (config) {
|
|
||||||
|
|
||||||
config.set({
|
|
||||||
basePath: '',
|
|
||||||
frameworks: ['mocha'],
|
|
||||||
files: [
|
|
||||||
'main.js',
|
|
||||||
'karma-delay.js',
|
|
||||||
'**/*.test.js'
|
|
||||||
],
|
|
||||||
|
|
||||||
preprocessors: {
|
|
||||||
'**/main.js': ['webpack'],
|
|
||||||
'**/*.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
|
|
||||||
},
|
|
||||||
|
|
||||||
reporters: ['mocha'],
|
|
||||||
|
|
||||||
plugins: [
|
|
||||||
require('./karma-webext-launcher'),
|
|
||||||
'karma-mocha',
|
|
||||||
'karma-webpack',
|
|
||||||
'karma-mocha-reporter',
|
|
||||||
],
|
|
||||||
|
|
||||||
client: {
|
|
||||||
mocha: {
|
|
||||||
timeout: 5000
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
|
@ -1,2 +0,0 @@
|
||||||
import chai from 'chai';
|
|
||||||
global.expect = chai.expect;
|
|
|
@ -1,88 +0,0 @@
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var serverUrl = require('./url');
|
|
||||||
var http = require('http');
|
|
||||||
var url = require('url');
|
|
||||||
|
|
||||||
const handleScroll = (req, res) => {
|
|
||||||
res.writeHead(200, {'Content-Type': 'text/html'});
|
|
||||||
res.end('<!DOCTYPEhtml><html lang="en"><body style="width:10000px; height:10000px"></body></html">');
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleAPagenation = (req, res) => {
|
|
||||||
let u = url.parse(req.url);
|
|
||||||
let params = new url.URLSearchParams(u.search);
|
|
||||||
let page = params.get('page') === null ? null : Number(params.get('page'));
|
|
||||||
if (page === null || isNaN(page)) {
|
|
||||||
return handle404(req, res);
|
|
||||||
}
|
|
||||||
|
|
||||||
let body = '';
|
|
||||||
let nextLink = u.pathname + '?page=' + (page + 1);
|
|
||||||
let prevLink = u.pathname + '?page=' + (page - 1);
|
|
||||||
|
|
||||||
if (page > 1) {
|
|
||||||
body += '<a href="' + prevLink + '">prev</a> | ';
|
|
||||||
}
|
|
||||||
body += '<a href="' + nextLink + '">next</a>';
|
|
||||||
|
|
||||||
res.writeHead(200, {'Content-Type': 'text/html'});
|
|
||||||
res.end('<!DOCTYPEhtml><html lang="en"><body">' + body + '</body></html">');
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleLinkPagenation = (req, res) => {
|
|
||||||
let u = url.parse(req.url);
|
|
||||||
let params = new url.URLSearchParams(u.search);
|
|
||||||
let page = params.get('page') === null ? null : Number(params.get('page'));
|
|
||||||
if (page === null || isNaN(page)) {
|
|
||||||
return handle404(req, res);
|
|
||||||
}
|
|
||||||
|
|
||||||
let head = '';
|
|
||||||
let nextLink = u.pathname + '?page=' + (page + 1);
|
|
||||||
let prevLink = u.pathname + '?page=' + (page - 1);
|
|
||||||
|
|
||||||
if (page > 1) {
|
|
||||||
head += '<link rel="prev" href="' + prevLink + '"></link>';
|
|
||||||
}
|
|
||||||
head += '<link rel="next" href="' + nextLink + '"></link>';
|
|
||||||
|
|
||||||
res.writeHead(200, {'Content-Type': 'text/html'});
|
|
||||||
res.end('<!DOCTYPEhtml><html lang="en"><head>' + head + '</head><body"></body></html">');
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleFollow = (req, res) => {
|
|
||||||
let body = '';
|
|
||||||
body += '<a href="#a">a</a>';
|
|
||||||
body += '<a href="#external" target="_blank">external</a>';
|
|
||||||
body += '<img width="320" height="240" src="" usemap="#map"><map name="map"><area href="#area" shape="rect" coords="15,19,126,104"></map>'
|
|
||||||
|
|
||||||
res.writeHead(200, {'Content-Type': 'text/html'});
|
|
||||||
res.end('<!DOCTYPEhtml><html lang="en"><body">' + body + '</body></html">');
|
|
||||||
}
|
|
||||||
|
|
||||||
const handle404 = (req, res) => {
|
|
||||||
res.writeHead(404, {'Content-Type': 'text/plain'});
|
|
||||||
res.end('not found')
|
|
||||||
};
|
|
||||||
|
|
||||||
http.createServer(function (req, res) {
|
|
||||||
if (req.method !== 'GET') {
|
|
||||||
handle404(req, res);
|
|
||||||
}
|
|
||||||
|
|
||||||
let u = url.parse(req.url);
|
|
||||||
if (u.pathname === '/scroll' || u.pathname === '/mark') {
|
|
||||||
handleScroll(req, res);
|
|
||||||
} else if (u.pathname === '/a-pagenation') {
|
|
||||||
handleAPagenation(req, res);
|
|
||||||
} else if (u.pathname === '/link-pagenation') {
|
|
||||||
handleLinkPagenation(req, res);
|
|
||||||
} else if (u.pathname === '/follow') {
|
|
||||||
handleFollow(req, res);
|
|
||||||
} else {
|
|
||||||
handle404(req, res);
|
|
||||||
}
|
|
||||||
|
|
||||||
console.log(`"${req.method} ${req.url}"`, res.statusCode)
|
|
||||||
}).listen(serverUrl.PORT, serverUrl.HOST);
|
|
|
@ -1,5 +0,0 @@
|
||||||
module.exports = {
|
|
||||||
PORT: 11111,
|
|
||||||
HOST: '127.0.0.1',
|
|
||||||
CLIENT_URL: 'http://127.0.0.1:11111',
|
|
||||||
}
|
|
Reference in a new issue