Add test cases for mark
This commit is contained in:
parent
9adf08bf95
commit
8d3b80af53
5 changed files with 86 additions and 4 deletions
|
@ -1,6 +1,6 @@
|
||||||
import {
|
import {
|
||||||
WINDOWS_CREATE, WINDOWS_REMOVE, WINDOWS_GET,
|
WINDOWS_CREATE, WINDOWS_REMOVE, WINDOWS_GET,
|
||||||
TABS_CREATE, TABS_SELECT_AT, TABS_GET, TABS_UPDATE,
|
TABS_CREATE, TABS_SELECT_AT, TABS_GET, TABS_UPDATE, TABS_REMOVE,
|
||||||
TABS_GET_ZOOM, TABS_SET_ZOOM,
|
TABS_GET_ZOOM, TABS_SET_ZOOM,
|
||||||
EVENT_KEYPRESS, EVENT_KEYDOWN, EVENT_KEYUP,
|
EVENT_KEYPRESS, EVENT_KEYDOWN, EVENT_KEYUP,
|
||||||
SCROLL_GET, SCROLL_SET,
|
SCROLL_GET, SCROLL_SET,
|
||||||
|
@ -30,6 +30,8 @@ receiveContentMessage((message) => {
|
||||||
return browser.tabs.get(message.tabId);
|
return browser.tabs.get(message.tabId);
|
||||||
case TABS_UPDATE:
|
case TABS_UPDATE:
|
||||||
return browser.tabs.update(message.tabId, message.properties);
|
return browser.tabs.update(message.tabId, message.properties);
|
||||||
|
case TABS_REMOVE:
|
||||||
|
return browser.tabs.remove(message.tabId);
|
||||||
case TABS_GET_ZOOM:
|
case TABS_GET_ZOOM:
|
||||||
return browser.tabs.getZoom(message.tabId);
|
return browser.tabs.getZoom(message.tabId);
|
||||||
case TABS_SET_ZOOM:
|
case TABS_SET_ZOOM:
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import {
|
import {
|
||||||
TABS_CREATE, TABS_SELECT_AT, TABS_GET, TABS_UPDATE,
|
TABS_CREATE, TABS_SELECT_AT, TABS_GET, TABS_UPDATE, TABS_REMOVE,
|
||||||
TABS_GET_ZOOM, TABS_SET_ZOOM,
|
TABS_GET_ZOOM, TABS_SET_ZOOM,
|
||||||
} from '../shared/messages';
|
} from '../shared/messages';
|
||||||
import * as ipc from './ipc';
|
import * as ipc from './ipc';
|
||||||
|
@ -35,6 +35,13 @@ const update = (tabId, properties) => {
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const remove = (tabId) => {
|
||||||
|
return ipc.send({
|
||||||
|
type: TABS_REMOVE,
|
||||||
|
tabId
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
const getZoom = (tabId) => {
|
const getZoom = (tabId) => {
|
||||||
return ipc.send({
|
return ipc.send({
|
||||||
tabId,
|
tabId,
|
||||||
|
@ -50,4 +57,4 @@ const setZoom = (tabId, factor) => {
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
export { create, selectAt, get, update, getZoom, setZoom };
|
export { create, selectAt, get, update, remove, getZoom, setZoom };
|
||||||
|
|
|
@ -7,6 +7,7 @@ const TABS_CREATE = 'tabs.create';
|
||||||
const TABS_SELECT_AT = 'tabs.selectAt';
|
const TABS_SELECT_AT = 'tabs.selectAt';
|
||||||
const TABS_GET = 'tabs.get';
|
const TABS_GET = 'tabs.get';
|
||||||
const TABS_UPDATE = 'tabs.update';
|
const TABS_UPDATE = 'tabs.update';
|
||||||
|
const TABS_REMOVE = 'tabs.remove';
|
||||||
const TABS_GET_ZOOM = 'tabs.get.zoom';
|
const TABS_GET_ZOOM = 'tabs.get.zoom';
|
||||||
const TABS_SET_ZOOM = 'tabs.set.zoom';
|
const TABS_SET_ZOOM = 'tabs.set.zoom';
|
||||||
const EVENT_KEYPRESS = 'event.keypress';
|
const EVENT_KEYPRESS = 'event.keypress';
|
||||||
|
@ -29,6 +30,7 @@ export {
|
||||||
TABS_SELECT_AT,
|
TABS_SELECT_AT,
|
||||||
TABS_GET_ZOOM,
|
TABS_GET_ZOOM,
|
||||||
TABS_SET_ZOOM,
|
TABS_SET_ZOOM,
|
||||||
|
TABS_REMOVE,
|
||||||
|
|
||||||
EVENT_KEYPRESS,
|
EVENT_KEYPRESS,
|
||||||
EVENT_KEYDOWN,
|
EVENT_KEYDOWN,
|
||||||
|
|
71
e2e/contents/mark.test.js
Normal file
71
e2e/contents/mark.test.js
Normal file
|
@ -0,0 +1,71 @@
|
||||||
|
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);
|
||||||
|
});
|
||||||
|
});
|
|
@ -72,7 +72,7 @@ http.createServer(function (req, res) {
|
||||||
}
|
}
|
||||||
|
|
||||||
let u = url.parse(req.url);
|
let u = url.parse(req.url);
|
||||||
if (u.pathname === '/scroll') {
|
if (u.pathname === '/scroll' || u.pathname === '/mark') {
|
||||||
handleScroll(req, res);
|
handleScroll(req, res);
|
||||||
} else if (u.pathname === '/a-pagenation') {
|
} else if (u.pathname === '/a-pagenation') {
|
||||||
handleAPagenation(req, res);
|
handleAPagenation(req, res);
|
||||||
|
|
Reference in a new issue