Use TestServer on e2e
This commit is contained in:
parent
4a4b5e1303
commit
1b92be6360
21 changed files with 346 additions and 634 deletions
|
@ -1,49 +1,29 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import * as http from 'http';
|
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
describe("blacklist test", () => {
|
||||||
let app = express();
|
let server = new TestServer().receiveContent('/*',
|
||||||
app.get('/*', (_req, res) => {
|
`<!DOCTYPE html><html lang="en"><body style="width:10000px; height:10000px"></body></html">`,
|
||||||
res.status(200).send(`<!DOCTYPEhtml>
|
);
|
||||||
<html lang="en">
|
|
||||||
<body style="width:10000px; height:10000px"></body>
|
|
||||||
</html>`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("navigate test", () => {
|
|
||||||
const port = 12321;
|
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
});
|
await server.start();
|
||||||
|
|
||||||
after(async() => {
|
let url = server.url('/a').replace('http://', '');
|
||||||
if (lanthan) {
|
|
||||||
await lanthan.quit();
|
|
||||||
}
|
|
||||||
http.close();
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should disable add-on if the URL is in the blacklist', async () => {
|
|
||||||
await browser.storage.local.set({
|
await browser.storage.local.set({
|
||||||
settings: {
|
settings: {
|
||||||
source: 'json',
|
source: 'json',
|
||||||
|
@ -51,24 +31,32 @@ describe("navigate test", () => {
|
||||||
"keymaps": {
|
"keymaps": {
|
||||||
"j": { "type": "scroll.vertically", "count": 1 }
|
"j": { "type": "scroll.vertically", "count": 1 }
|
||||||
},
|
},
|
||||||
"blacklist": [ "127.0.0.1:${port}/a" ]
|
"blacklist": [ "${url}" ]
|
||||||
}`,
|
}`,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
});
|
||||||
|
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/a`);
|
after(async() => {
|
||||||
|
await server.stop();
|
||||||
|
if (lanthan) {
|
||||||
|
await lanthan.quit();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should disable add-on if the URL is in the blacklist', async () => {
|
||||||
|
let page = await Page.navigateTo(webdriver, server.url('/a'));
|
||||||
await page.sendKeys('j')
|
await page.sendKeys('j')
|
||||||
|
|
||||||
// not works
|
|
||||||
let pageYOffset = await webdriver.executeScript(() => window.pageYOffset);
|
|
||||||
let scrollY = await page.getScrollY();
|
let scrollY = await page.getScrollY();
|
||||||
assert.equal(pageYOffset, 0);
|
assert.equal(scrollY, 0);
|
||||||
|
});
|
||||||
|
|
||||||
page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/ab`);
|
it('should enabled add-on if the URL is not in the blacklist', async () => {
|
||||||
|
let page = await Page.navigateTo(webdriver, server.url('/ab'));
|
||||||
await page.sendKeys('j');
|
await page.sendKeys('j');
|
||||||
|
|
||||||
// works
|
let scrollY = await page.getScrollY();
|
||||||
scrollY = await page.getScrollY();
|
|
||||||
assert.equal(scrollY, 64);
|
assert.equal(scrollY, 64);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,8 +1,7 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
import * as path from 'path';
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import * as clipboard from './lib/clipboard';
|
import * as clipboard from './lib/clipboard';
|
||||||
import settings from './settings';
|
import settings from './settings';
|
||||||
|
@ -10,24 +9,13 @@ import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver, Key } from 'selenium-webdriver';
|
import { WebDriver, Key } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
let app = express();
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.status(200).send(`<html lang="en"></html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("clipboard test", () => {
|
describe("clipboard test", () => {
|
||||||
const port = 12321;
|
let server = new TestServer(12321).receiveContent('/happy', 'ok');
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
|
@ -38,13 +26,15 @@ describe("clipboard test", () => {
|
||||||
await browser.storage.local.set({
|
await browser.storage.local.set({
|
||||||
settings,
|
settings,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
http.close();
|
|
||||||
});
|
});
|
||||||
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
|
@ -55,38 +45,38 @@ describe("clipboard test", () => {
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should copy current URL by y', async () => {
|
it('should copy current URL by y', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/#should_copy_url`);
|
let page = await Page.navigateTo(webdriver, server.url('/#should_copy_url'));
|
||||||
await page.sendKeys('y');
|
await page.sendKeys('y');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let data = await clipboard.read();
|
let data = await clipboard.read();
|
||||||
assert.equal(data, `http://127.0.0.1:${port}/#should_copy_url`);
|
assert.equal(data, server.url('/#should_copy_url'));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should open an URL from clipboard by p', async () => {
|
it('should open an URL from clipboard by p', async () => {
|
||||||
await clipboard.write(`http://127.0.0.1:${port}/#open_from_clipboard`);
|
await clipboard.write(server.url('/#open_from_clipboard'));
|
||||||
|
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/`);
|
let page = await Page.navigateTo(webdriver, server.url());
|
||||||
await page.sendKeys('p');
|
await page.sendKeys('p');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({ active: true });
|
let tabs = await browser.tabs.query({ active: true });
|
||||||
assert.equal(tabs[0].url, `http://127.0.0.1:${port}/#open_from_clipboard`);
|
assert.equal(tabs[0].url, server.url('/#open_from_clipboard'));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should open an URL from clipboard to new tab by P', async () => {
|
it('should open an URL from clipboard to new tab by P', async () => {
|
||||||
await clipboard.write(`http://127.0.0.1:${port}/#open_to_new_tab`);
|
await clipboard.write(server.url('/#open_to_new_tab'));
|
||||||
|
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/`);
|
let page = await Page.navigateTo(webdriver, server.url());
|
||||||
await page.sendKeys(Key.SHIFT, 'p');
|
await page.sendKeys(Key.SHIFT, 'p');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({});
|
let tabs = await browser.tabs.query({});
|
||||||
assert.deepEqual(tabs.map((t: any) => t.url), [
|
assert.deepEqual(tabs.map((t: any) => t.url), [
|
||||||
`http://127.0.0.1:${port}/`,
|
server.url(),
|
||||||
`http://127.0.0.1:${port}/#open_to_new_tab`,
|
server.url('/#open_to_new_tab'),
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -94,26 +84,26 @@ describe("clipboard test", () => {
|
||||||
it('should open search result with keywords in clipboard by p', async () => {
|
it('should open search result with keywords in clipboard by p', async () => {
|
||||||
await clipboard.write(`an apple`);
|
await clipboard.write(`an apple`);
|
||||||
|
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/`);
|
let page = await Page.navigateTo(webdriver, server.url());
|
||||||
await page.sendKeys(Key.SHIFT, 'p');
|
await page.sendKeys(Key.SHIFT, 'p');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({ active: true });
|
let tabs = await browser.tabs.query({ active: true });
|
||||||
assert.equal(tabs[0].url, `http://127.0.0.1:${port}/google?q=an%20apple`);
|
assert.equal(tabs[0].url, server.url('/google?q=an%20apple'));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should open search result with keywords in clipboard to new tabby P', async () => {
|
it('should open search result with keywords in clipboard to new tabby P', async () => {
|
||||||
await clipboard.write(`an apple`);
|
await clipboard.write(`an apple`);
|
||||||
|
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/`);
|
let page = await Page.navigateTo(webdriver, server.url());
|
||||||
await page.sendKeys(Key.SHIFT, 'p');
|
await page.sendKeys(Key.SHIFT, 'p');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({});
|
let tabs = await browser.tabs.query({});
|
||||||
assert.deepEqual(tabs.map((t: any) => t.url), [
|
assert.deepEqual(tabs.map((t: any) => t.url), [
|
||||||
`http://127.0.0.1:${port}/`,
|
server.url(),
|
||||||
`http://127.0.0.1:${port}/google?q=an%20apple`,
|
server.url('/google?q=an%20apple'),
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,53 +1,40 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
let app = express();
|
|
||||||
app.get('/happy', (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<title>how to be happy</title>
|
|
||||||
</head>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe('addbookmark command test', () => {
|
describe('addbookmark command test', () => {
|
||||||
const port = 12321;
|
let server = new TestServer().receiveContent('/happy', `
|
||||||
let http: http.Server;
|
<!DOCTYPE html>
|
||||||
|
<html lang="en"><head><title>how to be happy</title></head></html">`,
|
||||||
|
);
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
http.close();
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
await webdriver.navigate().to(`http://127.0.0.1:${port}/happy`);
|
await webdriver.navigate().to(server.url('/happy'));
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should add a bookmark from the current page', async() => {
|
it('should add a bookmark from the current page', async() => {
|
||||||
|
@ -58,7 +45,7 @@ describe('addbookmark command test', () => {
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
var bookmarks = await browser.bookmarks.search({ title: 'how to be happy' });
|
var bookmarks = await browser.bookmarks.search({ title: 'how to be happy' });
|
||||||
assert.equal(bookmarks.length, 1);
|
assert.equal(bookmarks.length, 1);
|
||||||
assert.equal(bookmarks[0].url, `http://127.0.0.1:${port}/happy`);
|
assert.equal(bookmarks[0].url, server.url('/happy'));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,46 +1,30 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
let app = express();
|
|
||||||
app.get('/*', (req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<title>my_${req.path.slice(1)}</title>
|
|
||||||
</head>
|
|
||||||
<body><h1>${req.path}</h1></body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe('bdelete/bdeletes command test', () => {
|
describe('bdelete/bdeletes command test', () => {
|
||||||
const port = 12321;
|
let server = new TestServer().receiveContent('/*', 'ok');
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
http.close();
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
|
@ -51,11 +35,11 @@ describe('bdelete/bdeletes command test', () => {
|
||||||
for (let tab of tabs.slice(1)) {
|
for (let tab of tabs.slice(1)) {
|
||||||
await browser.tabs.remove(tab.id);
|
await browser.tabs.remove(tab.id);
|
||||||
}
|
}
|
||||||
await browser.tabs.update(tabs[0].id, { url: `http://127.0.0.1:${port}/site1`, pinned: true });
|
await browser.tabs.update(tabs[0].id, { url: server.url('/site1'), pinned: true });
|
||||||
await browser.tabs.create({ url: `http://127.0.0.1:${port}/site2`, pinned: true })
|
await browser.tabs.create({ url: server.url('/site2'), pinned: true })
|
||||||
await browser.tabs.create({ url: `http://127.0.0.1:${port}/site3`, pinned: true })
|
await browser.tabs.create({ url: server.url('/site3'), pinned: true })
|
||||||
await browser.tabs.create({ url: `http://127.0.0.1:${port}/site4` })
|
await browser.tabs.create({ url: server.url('/site4'), })
|
||||||
await browser.tabs.create({ url: `http://127.0.0.1:${port}/site5` })
|
await browser.tabs.create({ url: server.url('/site5'), })
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let handles = await webdriver.getAllWindowHandles();
|
let handles = await webdriver.getAllWindowHandles();
|
||||||
|
@ -72,10 +56,10 @@ describe('bdelete/bdeletes command test', () => {
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({});
|
let tabs = await browser.tabs.query({});
|
||||||
assert.deepEqual(tabs.map((t: any) => t.url), [
|
assert.deepEqual(tabs.map((t: any) => t.url), [
|
||||||
`http://127.0.0.1:${port}/site1`,
|
server.url('/site1'),
|
||||||
`http://127.0.0.1:${port}/site2`,
|
server.url('/site2'),
|
||||||
`http://127.0.0.1:${port}/site3`,
|
server.url('/site3'),
|
||||||
`http://127.0.0.1:${port}/site4`,
|
server.url('/site4'),
|
||||||
])
|
])
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -121,10 +105,10 @@ describe('bdelete/bdeletes command test', () => {
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({});
|
let tabs = await browser.tabs.query({});
|
||||||
assert.deepEqual(tabs.map((t: any) => t.url), [
|
assert.deepEqual(tabs.map((t: any) => t.url), [
|
||||||
`http://127.0.0.1:${port}/site1`,
|
server.url('/site1'),
|
||||||
`http://127.0.0.1:${port}/site2`,
|
server.url('/site2'),
|
||||||
`http://127.0.0.1:${port}/site3`,
|
server.url('/site3'),
|
||||||
`http://127.0.0.1:${port}/site4`,
|
server.url('/site4'),
|
||||||
])
|
])
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -137,10 +121,10 @@ describe('bdelete/bdeletes command test', () => {
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({});
|
let tabs = await browser.tabs.query({});
|
||||||
assert.deepEqual(tabs.map((t: any) => t.url), [
|
assert.deepEqual(tabs.map((t: any) => t.url), [
|
||||||
`http://127.0.0.1:${port}/site2`,
|
server.url('/site2'),
|
||||||
`http://127.0.0.1:${port}/site3`,
|
server.url('/site3'),
|
||||||
`http://127.0.0.1:${port}/site4`,
|
server.url('/site4'),
|
||||||
`http://127.0.0.1:${port}/site5`,
|
server.url('/site5'),
|
||||||
])
|
])
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -153,9 +137,9 @@ describe('bdelete/bdeletes command test', () => {
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({});
|
let tabs = await browser.tabs.query({});
|
||||||
assert.deepEqual(tabs.map((t: any) => t.url), [
|
assert.deepEqual(tabs.map((t: any) => t.url), [
|
||||||
`http://127.0.0.1:${port}/site1`,
|
server.url('/site1'),
|
||||||
`http://127.0.0.1:${port}/site2`,
|
server.url('/site2'),
|
||||||
`http://127.0.0.1:${port}/site3`,
|
server.url('/site3'),
|
||||||
])
|
])
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,46 +1,39 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
import { Request, Response } from 'express';
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
describe('buffer command test', () => {
|
||||||
let app = express();
|
let server = new TestServer().handle('/*', (req: Request, res: Response) => {
|
||||||
app.get('/*', (req, res) => {
|
res.send(`
|
||||||
res.send(`<!DOCTYPEhtml>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<title>my_${req.path.slice(1)}</title>
|
<title>my_${req.path.slice(1)}</title>
|
||||||
</head>
|
</head>
|
||||||
<body><h1>${req.path}</h1></body>
|
|
||||||
</html">`);
|
</html">`);
|
||||||
});
|
});
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe('buffer command test', () => {
|
|
||||||
const port = 12321;
|
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
http.close();
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
|
@ -51,9 +44,9 @@ describe('buffer command test', () => {
|
||||||
for (let tab of tabs.slice(1)) {
|
for (let tab of tabs.slice(1)) {
|
||||||
await browser.tabs.remove(tab.id);
|
await browser.tabs.remove(tab.id);
|
||||||
}
|
}
|
||||||
await browser.tabs.update(tabs[0].id, { url: `http://127.0.0.1:${port}/site1` });
|
await browser.tabs.update(tabs[0].id, { url: server.url('/site1') });
|
||||||
for (let i = 2; i <= 5; ++i) {
|
for (let i = 2; i <= 5; ++i) {
|
||||||
await browser.tabs.create({ url: `http://127.0.0.1:${port}/site${i}`})
|
await browser.tabs.create({ url: server.url('/site' + i) });
|
||||||
}
|
}
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
|
|
@ -1,37 +1,17 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import settings from './settings';
|
import settings from './settings';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
|
|
||||||
let app = express();
|
|
||||||
for (let name of ['google', 'yahoo', 'bing', 'duckduckgo', 'twitter', 'wikipedia']) {
|
|
||||||
app.get('/' + name, (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body><h1>${name.charAt(0).toUpperCase() + name.slice(1)}</h1></body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body><h1>home</h1></body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("open command test", () => {
|
describe("open command test", () => {
|
||||||
const port = 12321;
|
let server = new TestServer(12321)
|
||||||
let http: http.Server;
|
.receiveContent('/google', 'google')
|
||||||
|
.receiveContent('/yahoo', 'yahoo');
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
@ -44,15 +24,16 @@ describe("open command test", () => {
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
http = newApp().listen(port);
|
|
||||||
|
|
||||||
await browser.storage.local.set({
|
await browser.storage.local.set({
|
||||||
settings,
|
settings,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
http.close();
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
|
@ -60,7 +41,7 @@ describe("open command test", () => {
|
||||||
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
await webdriver.switchTo().defaultContent();
|
await webdriver.switchTo().defaultContent();
|
||||||
page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}`);
|
page = await Page.navigateTo(webdriver, server.url());
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should open default search for keywords by open command ', async() => {
|
it('should open default search for keywords by open command ', async() => {
|
||||||
|
@ -70,7 +51,7 @@ describe("open command test", () => {
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({ active: true });
|
let tabs = await browser.tabs.query({ active: true });
|
||||||
let url = new URL(tabs[0].url);
|
let url = new URL(tabs[0].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/google?q=an%20apple`)
|
assert.equal(url.href, server.url('/google?q=an%20apple'))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -81,7 +62,7 @@ describe("open command test", () => {
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({ active: true })
|
let tabs = await browser.tabs.query({ active: true })
|
||||||
let url = new URL(tabs[0].url);
|
let url = new URL(tabs[0].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=an%20apple`)
|
assert.equal(url.href, server.url('/yahoo?q=an%20apple'))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -92,7 +73,7 @@ describe("open command test", () => {
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({ active: true })
|
let tabs = await browser.tabs.query({ active: true })
|
||||||
let url = new URL(tabs[0].url);
|
let url = new URL(tabs[0].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/google?q=`)
|
assert.equal(url.href, server.url('/google?q='))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -103,7 +84,7 @@ describe("open command test", () => {
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let tabs = await browser.tabs.query({ active: true })
|
let tabs = await browser.tabs.query({ active: true })
|
||||||
let url = new URL(tabs[0].url);
|
let url = new URL(tabs[0].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=`)
|
assert.equal(url.href, server.url('/yahoo?q='))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -1,46 +1,30 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
let app = express();
|
|
||||||
app.get('/*', (req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<title>my_${req.path.slice(1)}</title>
|
|
||||||
</head>
|
|
||||||
<body><h1>${req.path}</h1></body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe('quit/quitall command test', () => {
|
describe('quit/quitall command test', () => {
|
||||||
const port = 12321;
|
let server = new TestServer().receiveContent('/*', 'ok');
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
http.close();
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
|
@ -51,9 +35,9 @@ describe('quit/quitall command test', () => {
|
||||||
for (let tab of tabs.slice(1)) {
|
for (let tab of tabs.slice(1)) {
|
||||||
await browser.tabs.remove(tab.id);
|
await browser.tabs.remove(tab.id);
|
||||||
}
|
}
|
||||||
await browser.tabs.update(tabs[0].id, { url: `http://127.0.0.1:${port}/site1` });
|
await browser.tabs.update(tabs[0].id, { url: server.url('/site1') });
|
||||||
for (let i = 2; i <= 5; ++i) {
|
for (let i = 2; i <= 5; ++i) {
|
||||||
await browser.tabs.create({ url: `http://127.0.0.1:${port}/site${i}`})
|
await browser.tabs.create({ url: server.url('/site' + i) })
|
||||||
}
|
}
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
|
|
@ -1,44 +1,23 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import settings from './settings';
|
import settings from './settings';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
|
|
||||||
let app = express();
|
|
||||||
for (let name of ['google', 'yahoo', 'bing', 'duckduckgo', 'twitter', 'wikipedia']) {
|
|
||||||
app.get('/' + name, (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body><h1>${name.charAt(0).toUpperCase() + name.slice(1)}</h1></body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body><h1>home</h1></body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("tabopen command test", () => {
|
describe("tabopen command test", () => {
|
||||||
const port = 12321;
|
let server = new TestServer(12321)
|
||||||
let http: http.Server;
|
.receiveContent('/google', 'google')
|
||||||
|
.receiveContent('/yahoo', 'yahoo');
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
let page: Page;
|
let page: Page;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
|
@ -49,10 +28,12 @@ describe("tabopen command test", () => {
|
||||||
await browser.storage.local.set({
|
await browser.storage.local.set({
|
||||||
settings,
|
settings,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
http.close();
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
|
@ -64,7 +45,7 @@ describe("tabopen command test", () => {
|
||||||
await browser.tabs.remove(tab.id);
|
await browser.tabs.remove(tab.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}`);
|
page = await Page.navigateTo(webdriver, server.url());
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should open default search for keywords by tabopen command ', async() => {
|
it('should open default search for keywords by tabopen command ', async() => {
|
||||||
|
@ -75,7 +56,7 @@ describe("tabopen command test", () => {
|
||||||
let tabs = await browser.tabs.query({});
|
let tabs = await browser.tabs.query({});
|
||||||
assert.equal(tabs.length, 2);
|
assert.equal(tabs.length, 2);
|
||||||
let url = new URL(tabs[1].url);
|
let url = new URL(tabs[1].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/google?q=an%20apple`)
|
assert.equal(url.href, server.url('/google?q=an%20apple') )
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -87,7 +68,7 @@ describe("tabopen command test", () => {
|
||||||
let tabs = await browser.tabs.query({});
|
let tabs = await browser.tabs.query({});
|
||||||
assert.equal(tabs.length, 2);
|
assert.equal(tabs.length, 2);
|
||||||
let url = new URL(tabs[1].url);
|
let url = new URL(tabs[1].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=an%20apple`)
|
assert.equal(url.href, server.url('/yahoo?q=an%20apple'))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -99,7 +80,7 @@ describe("tabopen command test", () => {
|
||||||
let tabs = await browser.tabs.query({});
|
let tabs = await browser.tabs.query({});
|
||||||
assert.equal(tabs.length, 2);
|
assert.equal(tabs.length, 2);
|
||||||
let url = new URL(tabs[1].url);
|
let url = new URL(tabs[1].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/google?q=`)
|
assert.equal(url.href, server.url('/google?q='))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -111,7 +92,7 @@ describe("tabopen command test", () => {
|
||||||
let tabs = await browser.tabs.query({});
|
let tabs = await browser.tabs.query({});
|
||||||
assert.equal(tabs.length, 2);
|
assert.equal(tabs.length, 2);
|
||||||
let url = new URL(tabs[1].url);
|
let url = new URL(tabs[1].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=`)
|
assert.equal(url.href, server.url('/yahoo?q='))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -1,44 +1,23 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import settings from './settings';
|
import settings from './settings';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
|
|
||||||
let app = express();
|
|
||||||
for (let name of ['google', 'yahoo', 'bing', 'duckduckgo', 'twitter', 'wikipedia']) {
|
|
||||||
app.get('/' + name, (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body><h1>${name.charAt(0).toUpperCase() + name.slice(1)}</h1></body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body><h1>home</h1></body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("winopen command test", () => {
|
describe("winopen command test", () => {
|
||||||
const port = 12321;
|
let server = new TestServer(12321)
|
||||||
let http: http.Server;
|
.receiveContent('/google', 'google')
|
||||||
|
.receiveContent('/yahoo', 'yahoo');
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
let page: Page;
|
let page: Page;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
|
@ -48,10 +27,12 @@ describe("winopen command test", () => {
|
||||||
await browser.storage.local.set({
|
await browser.storage.local.set({
|
||||||
settings,
|
settings,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
http.close();
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
|
@ -63,7 +44,7 @@ describe("winopen command test", () => {
|
||||||
await browser.windows.remove(win.id);
|
await browser.windows.remove(win.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/area`);
|
page = await Page.navigateTo(webdriver, server.url());
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should open default search for keywords by winopen command ', async() => {
|
it('should open default search for keywords by winopen command ', async() => {
|
||||||
|
@ -76,7 +57,7 @@ describe("winopen command test", () => {
|
||||||
|
|
||||||
let tabs = await browser.tabs.query({ windowId: wins[1].id });
|
let tabs = await browser.tabs.query({ windowId: wins[1].id });
|
||||||
let url = new URL(tabs[0].url);
|
let url = new URL(tabs[0].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/google?q=an%20apple`)
|
assert.equal(url.href, server.url('/google?q=an%20apple'))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -90,7 +71,7 @@ describe("winopen command test", () => {
|
||||||
|
|
||||||
let tabs = await browser.tabs.query({ windowId: wins[1].id });
|
let tabs = await browser.tabs.query({ windowId: wins[1].id });
|
||||||
let url = new URL(tabs[0].url);
|
let url = new URL(tabs[0].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=an%20apple`)
|
assert.equal(url.href, server.url('/yahoo?q=an%20apple'))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -104,7 +85,7 @@ describe("winopen command test", () => {
|
||||||
|
|
||||||
let tabs = await browser.tabs.query({ windowId: wins[1].id });
|
let tabs = await browser.tabs.query({ windowId: wins[1].id });
|
||||||
let url = new URL(tabs[0].url);
|
let url = new URL(tabs[0].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/google?q=`)
|
assert.equal(url.href, server.url('/google?q='))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -118,7 +99,7 @@ describe("winopen command test", () => {
|
||||||
|
|
||||||
let tabs = await browser.tabs.query({ windowId: wins[1].id });
|
let tabs = await browser.tabs.query({ windowId: wins[1].id });
|
||||||
let url = new URL(tabs[0].url);
|
let url = new URL(tabs[0].url);
|
||||||
assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=`)
|
assert.equal(url.href, server.url('/yahoo?q='))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,5 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import settings from './settings';
|
import settings from './settings';
|
||||||
|
@ -9,20 +7,7 @@ import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver, Key } from 'selenium-webdriver';
|
import { WebDriver, Key } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
let app = express();
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body>ok</body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("general completion test", () => {
|
describe("general completion test", () => {
|
||||||
const port = 12321;
|
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
@ -35,7 +20,6 @@ describe("general completion test", () => {
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
http = newApp().listen(port);
|
|
||||||
|
|
||||||
await browser.storage.local.set({
|
await browser.storage.local.set({
|
||||||
settings,
|
settings,
|
||||||
|
@ -43,14 +27,13 @@ describe("general completion test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
http.close();
|
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}`);
|
page = await Page.navigateTo(webdriver, 'about:blank');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should all commands on empty line', async() => {
|
it('should all commands on empty line', async() => {
|
||||||
|
|
|
@ -1,32 +1,24 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
import * as path from 'path';
|
||||||
|
|
||||||
|
import { Request, Response } from 'express'
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import settings from './settings';
|
import settings from './settings';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
describe("completion on buffer/bdelete/bdeletes", () => {
|
||||||
|
let server = new TestServer().handle('/*', (req: Request, res: Response) => {
|
||||||
let app = express();
|
res.send(`
|
||||||
app.get('/*', (req, res) => {
|
<!DOCTYPE html>
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<title>title_${req.path.slice(1)}</title>
|
<title>title_${req.path.slice(1)}</title>
|
||||||
</head>
|
</head>
|
||||||
<body><h1>home</h1></body>
|
|
||||||
</html">`);
|
</html">`);
|
||||||
});
|
});
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("completion on buffer/bdelete/bdeletes", () => {
|
|
||||||
const port = 12321;
|
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
@ -39,15 +31,16 @@ describe("completion on buffer/bdelete/bdeletes", () => {
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
http = newApp().listen(port);
|
|
||||||
|
|
||||||
await browser.storage.local.set({
|
await browser.storage.local.set({
|
||||||
settings,
|
settings,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
http.close();
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
|
@ -59,10 +52,10 @@ describe("completion on buffer/bdelete/bdeletes", () => {
|
||||||
await browser.tabs.remove(tab.id);
|
await browser.tabs.remove(tab.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
await browser.tabs.update(tabs[0].id, { url: `http://127.0.0.1:${port}/site1`, pinned: true });
|
await browser.tabs.update(tabs[0].id, { url: server.url('/site1'), pinned: true });
|
||||||
await browser.tabs.create({ url: `http://127.0.0.1:${port}/site2`, pinned: true })
|
await browser.tabs.create({ url:server.url('/site2'), pinned: true })
|
||||||
for (let i = 3; i <= 5; ++i) {
|
for (let i = 3; i <= 5; ++i) {
|
||||||
await browser.tabs.create({ url: `http://127.0.0.1:${port}/site${i}` })
|
await browser.tabs.create({ url: server.url('/site' + i) });
|
||||||
}
|
}
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
@ -102,7 +95,7 @@ describe("completion on buffer/bdelete/bdeletes", () => {
|
||||||
assert.deepEqual(items[0], { type: 'title', text: 'Buffers' });
|
assert.deepEqual(items[0], { type: 'title', text: 'Buffers' });
|
||||||
assert.ok(items[1].text.startsWith('2:'));
|
assert.ok(items[1].text.startsWith('2:'));
|
||||||
assert.ok(items[1].text.includes('title_site2'));
|
assert.ok(items[1].text.includes('title_site2'));
|
||||||
assert.ok(items[1].text.includes(`http://127.0.0.1:${port}/site2`));
|
assert.ok(items[1].text.includes(server.url('/site2')));
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
|
@ -1,60 +1,47 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import settings from './settings';
|
import settings from './settings';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
|
|
||||||
let app = express();
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body>ok</body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("completion on open/tabopen/winopen commands", () => {
|
describe("completion on open/tabopen/winopen commands", () => {
|
||||||
const port = 12321;
|
let server = new TestServer().receiveContent('/*', 'ok');
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
let page: Page;
|
let page: Page;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
|
await server.start();
|
||||||
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
http = newApp().listen(port);
|
|
||||||
|
|
||||||
await browser.storage.local.set({
|
await browser.storage.local.set({
|
||||||
settings,
|
settings,
|
||||||
});
|
});
|
||||||
|
|
||||||
// Add item into hitories
|
// Add item into hitories
|
||||||
await webdriver.navigate().to(`https://i-beam.org/404`);
|
await webdriver.navigate().to(('https://i-beam.org/404'));
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
http.close();
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}`);
|
page = await Page.navigateTo(webdriver, server.url());
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should show completions from search engines, bookmarks, and histories by "open" command', async() => {
|
it('should show completions from search engines, bookmarks, and histories by "open" command', async() => {
|
||||||
|
|
|
@ -1,53 +1,37 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver, Key } from 'selenium-webdriver';
|
import { WebDriver, Key } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
let app = express();
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<title>Hello, world!</title>
|
|
||||||
</head>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
describe("console test", () => {
|
describe("console test", () => {
|
||||||
const port = 12321;
|
let server = new TestServer().receiveContent('/',
|
||||||
let http: http.Server;
|
`<!DOCTYPE html><html lang="en"><head><title>Hello, world!</title></head></html">`,
|
||||||
|
);
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let page: Page;
|
let page: Page;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
if (http) {
|
|
||||||
http.close();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}`);
|
page = await Page.navigateTo(webdriver, server.url());
|
||||||
});
|
});
|
||||||
|
|
||||||
it('open console with :', async() => {
|
it('open console with :', async() => {
|
||||||
|
@ -65,7 +49,7 @@ describe("console test", () => {
|
||||||
it('open console with open command and current URL by O', async() => {
|
it('open console with open command and current URL by O', async() => {
|
||||||
await page.sendKeys(Key.SHIFT, 'o');
|
await page.sendKeys(Key.SHIFT, 'o');
|
||||||
let console = await page.getConsole();
|
let console = await page.getConsole();
|
||||||
assert.equal(await console.currentValue(), `open http://127.0.0.1:${port}/`);
|
assert.equal(await console.currentValue(), `open ${server.url()}`);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('open console with tabopen command by t', async() => {
|
it('open console with tabopen command by t', async() => {
|
||||||
|
@ -77,7 +61,7 @@ describe("console test", () => {
|
||||||
it('open console with tabopen command and current URL by T', async() => {
|
it('open console with tabopen command and current URL by T', async() => {
|
||||||
await page.sendKeys(Key.SHIFT, 't');
|
await page.sendKeys(Key.SHIFT, 't');
|
||||||
let console = await page.getConsole();
|
let console = await page.getConsole();
|
||||||
assert.equal(await console.currentValue(), `tabopen http://127.0.0.1:${port}/`);
|
assert.equal(await console.currentValue(), `tabopen ${server.url()}`);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('open console with winopen command by w', async() => {
|
it('open console with winopen command by w', async() => {
|
||||||
|
@ -89,7 +73,7 @@ describe("console test", () => {
|
||||||
it('open console with winopen command and current URL by W', async() => {
|
it('open console with winopen command and current URL by W', async() => {
|
||||||
await page.sendKeys(Key.SHIFT, 'W');
|
await page.sendKeys(Key.SHIFT, 'W');
|
||||||
let console = await page.getConsole();
|
let console = await page.getConsole();
|
||||||
assert.equal(await console.currentValue(), `winopen http://127.0.0.1:${port}/`);
|
assert.equal(await console.currentValue(), `winopen ${server.url()}`);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('open console with buffer command by b', async() => {
|
it('open console with buffer command by b', async() => {
|
||||||
|
|
|
@ -1,34 +1,30 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver, Key } from 'selenium-webdriver';
|
import { WebDriver, Key } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
const newApp = () => {
|
||||||
let app = express();
|
let server = new TestServer();
|
||||||
|
|
||||||
app.get('/', (_req, res) => {
|
server.receiveContent('/', `
|
||||||
res.send(`<!DOCTYPEhtml>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en"><body>
|
||||||
<body><a href="hello">hello</a></body>
|
<a href="hello">hello</a>
|
||||||
</html">`);
|
</body></html">`);
|
||||||
});
|
|
||||||
|
|
||||||
app.get('/follow-input', (_req, res) => {
|
server.receiveContent('/follow-input', `
|
||||||
res.send(`<!DOCTYPEhtml>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en"><body>
|
||||||
<body><input></body>
|
<input>
|
||||||
</html">`);
|
</body></html">`);
|
||||||
});
|
|
||||||
|
|
||||||
app.get('/area', (_req, res) => {
|
server.receiveContent('/area', `
|
||||||
res.send(`<!DOCTYPEhtml>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en"><body>
|
||||||
<body>
|
|
||||||
<img
|
<img
|
||||||
width="256" height="256" usemap="#map"
|
width="256" height="256" usemap="#map"
|
||||||
src=""
|
src=""
|
||||||
|
@ -38,9 +34,7 @@ const newApp = () => {
|
||||||
<area shape="rect" coords="64,64,64,64" href="/">
|
<area shape="rect" coords="64,64,64,64" href="/">
|
||||||
<area shape="rect" coords="128,128,64,64" href="/">
|
<area shape="rect" coords="128,128,64,64" href="/">
|
||||||
</map>
|
</map>
|
||||||
</body>
|
</body></html">`);
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* test case: link2 is out of the viewport
|
* test case: link2 is out of the viewport
|
||||||
|
@ -52,16 +46,13 @@ const newApp = () => {
|
||||||
* | |
|
* | |
|
||||||
* +-----------------+
|
* +-----------------+
|
||||||
*/
|
*/
|
||||||
app.get('/test1', (_req, res) => {
|
server.receiveContent('/test1', `
|
||||||
res.send(`<!DOCTYPEhtml>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en"><body>
|
||||||
<body>
|
|
||||||
<div><a href="link1">link1</a></div>
|
<div><a href="link1">link1</a></div>
|
||||||
<div style="min-height:3000px"></div>
|
<div style="min-height:3000px"></div>
|
||||||
<div><a href="link2">link2</a></div>
|
<div><a href="link2">link2</a></div>
|
||||||
</body>
|
</body></html">`);
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* test case 2: link2 and link3 are out of window of the frame
|
* test case 2: link2 and link3 are out of window of the frame
|
||||||
|
@ -74,22 +65,18 @@ const newApp = () => {
|
||||||
* | |
|
* | |
|
||||||
* +-----------------+
|
* +-----------------+
|
||||||
*/
|
*/
|
||||||
app.get('/test2', (_req, res) => {
|
server.receiveContent('/test2', `
|
||||||
res.send(`<!DOCTYPEhtml>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en"><body>
|
||||||
<body><iframe height="5000" src='/test2-frame'></body>
|
<iframe height="5000" src='/test2-frame'>
|
||||||
</html">`);
|
</body></html">`);
|
||||||
});
|
server.receiveContent('/test2-frame', `
|
||||||
app.get('/test2-frame', (_req, res) => {
|
<!DOCTYPE html>
|
||||||
res.send(`<!DOCTYPEhtml>
|
<html lang="en"><body>
|
||||||
<html lang="en">
|
|
||||||
<body>
|
|
||||||
<div><a href="link1">link1</a></div>
|
<div><a href="link1">link1</a></div>
|
||||||
<div style="min-height:3000px"></div>
|
<div style="min-height:3000px"></div>
|
||||||
<div><a href="link2">link2</a></div>
|
<div><a href="link2">link2</a></div>
|
||||||
</body>
|
</body></html">`);
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
|
|
||||||
/* test case 3: link2 is out of window of the frame
|
/* test case 3: link2 is out of window of the frame
|
||||||
* +-----------------+
|
* +-----------------+
|
||||||
|
@ -101,51 +88,43 @@ const newApp = () => {
|
||||||
* | |
|
* | |
|
||||||
* +-----------------+
|
* +-----------------+
|
||||||
*/
|
*/
|
||||||
app.get('/test3', (_req, res) => {
|
server.receiveContent('/test3', `
|
||||||
res.send(`<!DOCTYPEhtml>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en"><body>
|
||||||
<body><iframe src='/test3-frame'></body>
|
<iframe src='/test3-frame'>
|
||||||
</html">`);
|
</body></html">`);
|
||||||
});
|
server.receiveContent('/test3-frame', `
|
||||||
app.get('/test3-frame', (_req, res) => {
|
<!DOCTYPE html>
|
||||||
res.send(`<!DOCTYPEhtml>
|
<html lang="en"><body>
|
||||||
<html lang="en">
|
|
||||||
<body>
|
|
||||||
<div><a href="link1">link1</a></div>
|
<div><a href="link1">link1</a></div>
|
||||||
<div style="min-height:3000px"></div>
|
<div style="min-height:3000px"></div>
|
||||||
<div><a href="link2">link2</a></div>
|
<div><a href="link2">link2</a></div>
|
||||||
</body>
|
</body></html">`);
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
|
|
||||||
return app;
|
return server;
|
||||||
};
|
};
|
||||||
|
|
||||||
describe('follow test', () => {
|
describe('follow test', () => {
|
||||||
|
let server = newApp();
|
||||||
const port = 12321;
|
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
if (http) {
|
|
||||||
http.close();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
afterEach(async() => {
|
afterEach(async() => {
|
||||||
|
@ -156,7 +135,7 @@ describe('follow test', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should focus an input by f', async () => {
|
it('should focus an input by f', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/follow-input`);
|
let page = await Page.navigateTo(webdriver, server.url('/follow-input'));
|
||||||
await page.sendKeys('f');
|
await page.sendKeys('f');
|
||||||
await page.waitAndGetHints();
|
await page.waitAndGetHints();
|
||||||
await page.sendKeys('a');
|
await page.sendKeys('a');
|
||||||
|
@ -166,7 +145,7 @@ describe('follow test', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should open a link by f', async () => {
|
it('should open a link by f', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/`);
|
let page = await Page.navigateTo(webdriver, server.url());
|
||||||
await page.sendKeys('f');
|
await page.sendKeys('f');
|
||||||
await page.waitAndGetHints();
|
await page.waitAndGetHints();
|
||||||
await page.sendKeys('a');
|
await page.sendKeys('a');
|
||||||
|
@ -178,7 +157,7 @@ describe('follow test', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should focus an input by F', async () => {
|
it('should focus an input by F', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/follow-input`);
|
let page = await Page.navigateTo(webdriver, server.url('/follow-input'));
|
||||||
await page.sendKeys(Key.SHIFT, 'f');
|
await page.sendKeys(Key.SHIFT, 'f');
|
||||||
await page.waitAndGetHints();
|
await page.waitAndGetHints();
|
||||||
await page.sendKeys('a');
|
await page.sendKeys('a');
|
||||||
|
@ -188,7 +167,7 @@ describe('follow test', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should open a link to new tab by F', async () => {
|
it('should open a link to new tab by F', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/`);
|
let page = await Page.navigateTo(webdriver, server.url());
|
||||||
await page.sendKeys(Key.SHIFT, 'f');
|
await page.sendKeys(Key.SHIFT, 'f');
|
||||||
await page.waitAndGetHints();
|
await page.waitAndGetHints();
|
||||||
await page.sendKeys('a');
|
await page.sendKeys('a');
|
||||||
|
@ -202,7 +181,7 @@ describe('follow test', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should show hints of links in area', async () => {
|
it('should show hints of links in area', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/area`);
|
let page = await Page.navigateTo(webdriver, server.url('/area'));
|
||||||
await page.sendKeys(Key.SHIFT, 'f');
|
await page.sendKeys(Key.SHIFT, 'f');
|
||||||
|
|
||||||
let hints = await page.waitAndGetHints();
|
let hints = await page.waitAndGetHints();
|
||||||
|
@ -210,7 +189,7 @@ describe('follow test', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should shows hints only in viewport', async () => {
|
it('should shows hints only in viewport', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/test1`);
|
let page = await Page.navigateTo(webdriver, server.url('/test1'));
|
||||||
await page.sendKeys(Key.SHIFT, 'f');
|
await page.sendKeys(Key.SHIFT, 'f');
|
||||||
|
|
||||||
let hints = await page.waitAndGetHints();
|
let hints = await page.waitAndGetHints();
|
||||||
|
@ -218,7 +197,7 @@ describe('follow test', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should shows hints only in window of the frame', async () => {
|
it('should shows hints only in window of the frame', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/test2`);
|
let page = await Page.navigateTo(webdriver, server.url('/test2'));
|
||||||
await page.sendKeys(Key.SHIFT, 'f');
|
await page.sendKeys(Key.SHIFT, 'f');
|
||||||
|
|
||||||
await webdriver.switchTo().frame(0);
|
await webdriver.switchTo().frame(0);
|
||||||
|
@ -227,7 +206,7 @@ describe('follow test', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should shows hints only in the frame', async () => {
|
it('should shows hints only in the frame', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/test3`);
|
let page = await Page.navigateTo(webdriver, server.url('/test3'));
|
||||||
await page.sendKeys(Key.SHIFT, 'f');
|
await page.sendKeys(Key.SHIFT, 'f');
|
||||||
|
|
||||||
await webdriver.switchTo().frame(0);
|
await webdriver.switchTo().frame(0);
|
||||||
|
|
|
@ -1,42 +1,29 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver, Key } from 'selenium-webdriver';
|
import { WebDriver, Key } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
describe('follow properties test', () => {
|
||||||
let app = express();
|
let server = new TestServer().receiveContent('/', `
|
||||||
|
<!DOCTYPE html>
|
||||||
app.get('/', (_req, res) => {
|
<html lang="en"><body>
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body>
|
|
||||||
<a href="/">link1</a>
|
<a href="/">link1</a>
|
||||||
<a href="/">link2</a>
|
<a href="/">link2</a>
|
||||||
<a href="/">link3</a>
|
<a href="/">link3</a>
|
||||||
<a href="/">link4</a>
|
<a href="/">link4</a>
|
||||||
<a href="/">link5</a>
|
<a href="/">link5</a>
|
||||||
</body>
|
</body></html">`);
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe('follow properties test', () => {
|
|
||||||
const port = 12321;
|
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
let page: Page;
|
let page: Page;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
|
@ -62,17 +49,19 @@ describe('follow properties test', () => {
|
||||||
}
|
}
|
||||||
}`,
|
}`,
|
||||||
}});
|
}});
|
||||||
|
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
http.close();
|
|
||||||
});
|
});
|
||||||
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}`);
|
page = await Page.navigateTo(webdriver, server.url());
|
||||||
});
|
});
|
||||||
|
|
||||||
afterEach(async() => {
|
afterEach(async() => {
|
||||||
|
|
|
@ -1,53 +1,40 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
let app = express();
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body style="width:10000px; height:10000px"></body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("mark test", () => {
|
describe("mark test", () => {
|
||||||
const port = 12321;
|
let server = new TestServer().receiveContent('/',
|
||||||
let http: http.Server;
|
`<!DOCTYPE html><html lang="en"><body style="width:10000px; height:10000px"></body></html">`,
|
||||||
|
);
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
|
|
||||||
|
await server.start()
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
if (http) {
|
|
||||||
http.close();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should set a local mark and jump to it', async () => {
|
it('should set a local mark and jump to it', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}`);
|
let page = await Page.navigateTo(webdriver, server.url());
|
||||||
await page.scrollTo(200, 200);
|
await page.scrollTo(200, 200);
|
||||||
await page.sendKeys('m', 'a');
|
await page.sendKeys('m', 'a');
|
||||||
await page.scrollTo(500, 500);
|
await page.scrollTo(500, 500);
|
||||||
|
@ -60,7 +47,7 @@ describe("mark test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should set a global mark and jump to it', async () => {
|
it('should set a global mark and jump to it', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}#first`);
|
let page = await Page.navigateTo(webdriver, server.url('/#first'));
|
||||||
await page.scrollTo(200, 200);
|
await page.scrollTo(200, 200);
|
||||||
await page.sendKeys('m', 'A');
|
await page.sendKeys('m', 'A');
|
||||||
await page.scrollTo(500, 500);
|
await page.scrollTo(500, 500);
|
||||||
|
@ -71,7 +58,7 @@ describe("mark test", () => {
|
||||||
assert.equal(await page.getScrollY(), 200);
|
assert.equal(await page.getScrollY(), 200);
|
||||||
});
|
});
|
||||||
|
|
||||||
await browser.tabs.create({ url: `http://127.0.0.1:${port}#second` });
|
await browser.tabs.create({ url: server.url('/#second') });
|
||||||
page = await Page.currentContext(webdriver);
|
page = await Page.currentContext(webdriver);
|
||||||
await page.sendKeys('\'', 'A');
|
await page.sendKeys('\'', 'A');
|
||||||
|
|
||||||
|
@ -86,12 +73,12 @@ describe("mark test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('set a global mark and creates new tab from gone', async () => {
|
it('set a global mark and creates new tab from gone', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}#first`);
|
let page = await Page.navigateTo(webdriver, server.url('/#first'));
|
||||||
await page.scrollTo(500, 500);
|
await page.scrollTo(500, 500);
|
||||||
await page.sendKeys('m', 'A');
|
await page.sendKeys('m', 'A');
|
||||||
|
|
||||||
let tab = (await browser.tabs.query({ active: true }))[0];
|
let tab = (await browser.tabs.query({ active: true }))[0];
|
||||||
await browser.tabs.create({ url: `http://127.0.0.1:${port}#second` });
|
await browser.tabs.create({ url: server.url('/#second') });
|
||||||
await browser.tabs.remove(tab.id);
|
await browser.tabs.remove(tab.id);
|
||||||
|
|
||||||
let handles: string[];
|
let handles: string[];
|
||||||
|
@ -101,7 +88,7 @@ describe("mark test", () => {
|
||||||
});
|
});
|
||||||
await webdriver.switchTo().window(handles!![0]);
|
await webdriver.switchTo().window(handles!![0]);
|
||||||
|
|
||||||
page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}#second`);
|
page = await Page.navigateTo(webdriver, server.url('/#second'));
|
||||||
await page.sendKeys('\'', 'A');
|
await page.sendKeys('\'', 'A');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
|
|
@ -1,8 +1,7 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver, Key } from 'selenium-webdriver';
|
import { WebDriver, Key } from 'selenium-webdriver';
|
||||||
|
@ -10,16 +9,19 @@ import { Options as FirefoxOptions } from 'selenium-webdriver/firefox';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
const newApp = () => {
|
||||||
let app = express();
|
let server = new TestServer();
|
||||||
app.get('/pagenation-a/:page', (req, res) => {
|
server.handle('/pagenation-a/:page', (req, res) => {
|
||||||
res.status(200).send(`
|
res.status(200).send(`
|
||||||
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<a href="/pagenation-a/${Number(req.params.page) - 1}">prev</a>
|
<a href="/pagenation-a/${Number(req.params.page) - 1}">prev</a>
|
||||||
<a href="/pagenation-a/${Number(req.params.page) + 1}">next</a>
|
<a href="/pagenation-a/${Number(req.params.page) + 1}">next</a>
|
||||||
</html">`);
|
</html">`);
|
||||||
});
|
});
|
||||||
app.get('/pagenation-link/:page', (req, res) => {
|
|
||||||
|
server.handle('/pagenation-link/:page', (req, res) => {
|
||||||
res.status(200).send(`
|
res.status(200).send(`
|
||||||
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<link rel="prev" href="/pagenation-link/${Number(req.params.page) - 1}"></link>
|
<link rel="prev" href="/pagenation-link/${Number(req.params.page) - 1}"></link>
|
||||||
|
@ -27,37 +29,31 @@ const newApp = () => {
|
||||||
</head>
|
</head>
|
||||||
</html">`);
|
</html">`);
|
||||||
});
|
});
|
||||||
app.get('/reload', (_req, res) => {
|
server.receiveContent('/reload', `
|
||||||
res.status(200).send(`
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<script>window.location.hash = Date.now()</script>
|
<script>window.location.hash = Date.now()</script>
|
||||||
</head>
|
</head>
|
||||||
<body style="width:10000px; height:10000px"></body>
|
<body style="width:10000px; height:10000px"></body>
|
||||||
</html">`);
|
</html">`);
|
||||||
});
|
|
||||||
|
|
||||||
app.get('/*', (req, res) => {
|
server.receiveContent('/*', `ok`);
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
return server;
|
||||||
${req.path}
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
describe("navigate test", () => {
|
describe("navigate test", () => {
|
||||||
|
let server = newApp();
|
||||||
const port = 12321;
|
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
|
await server.start();
|
||||||
|
|
||||||
let opts = (new FirefoxOptions() as any)
|
let opts = (new FirefoxOptions() as any)
|
||||||
.setPreference('browser.startup.homepage', `http://127.0.0.1:${port}#home`);
|
.setPreference('browser.startup.homepage', server.url('/#home'));
|
||||||
http = newApp().listen(port);
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.setOptions(opts)
|
.setOptions(opts)
|
||||||
|
@ -68,10 +64,10 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
http.close();
|
|
||||||
});
|
});
|
||||||
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
|
@ -82,7 +78,7 @@ describe("navigate test", () => {
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should go to parent path without hash by gu', async () => {
|
it('should go to parent path without hash by gu', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/a/b/c`);
|
let page = await Page.navigateTo(webdriver, server.url('/a/b/c'));
|
||||||
await page.sendKeys('g', 'u');
|
await page.sendKeys('g', 'u');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
@ -93,7 +89,7 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should remove hash by gu', async () => {
|
it('should remove hash by gu', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/a/b/c#hash`);
|
let page = await Page.navigateTo(webdriver, server.url('/a/b/c#hash'));
|
||||||
await page.sendKeys('g', 'u');
|
await page.sendKeys('g', 'u');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
@ -105,7 +101,7 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should go to root path by gU', async () => {
|
it('should go to root path by gU', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/a/b/c#hash`);
|
let page = await Page.navigateTo(webdriver, server.url('/a/b/c#hash'));
|
||||||
await page.sendKeys('g', Key.SHIFT, 'u');
|
await page.sendKeys('g', Key.SHIFT, 'u');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
@ -116,8 +112,8 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should go back and forward in history by H and L', async () => {
|
it('should go back and forward in history by H and L', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/first`);
|
let page = await Page.navigateTo(webdriver, server.url('/first'));
|
||||||
await page.navigateTo(`http://127.0.0.1:${port}/second`);
|
await page.navigateTo(server.url('/second'));
|
||||||
await page.sendKeys(Key.SHIFT, 'h');
|
await page.sendKeys(Key.SHIFT, 'h');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
@ -137,7 +133,7 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should go previous and next page in <a> by [[ and ]]', async () => {
|
it('should go previous and next page in <a> by [[ and ]]', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/pagenation-a/10`);
|
let page = await Page.navigateTo(webdriver, server.url('/pagenation-a/10'));
|
||||||
await page.sendKeys('[', '[');
|
await page.sendKeys('[', '[');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
@ -148,7 +144,7 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should go next page in <a> by ]]', async () => {
|
it('should go next page in <a> by ]]', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/pagenation-a/10`);
|
let page = await Page.navigateTo(webdriver, server.url('/pagenation-a/10'));
|
||||||
await page.sendKeys(']', ']');
|
await page.sendKeys(']', ']');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
@ -159,7 +155,7 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should go previous page in <link> by ]]', async () => {
|
it('should go previous page in <link> by ]]', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/pagenation-link/10`);
|
let page = await Page.navigateTo(webdriver, server.url('/pagenation-link/10'));
|
||||||
await page.sendKeys('[', '[');
|
await page.sendKeys('[', '[');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
@ -170,7 +166,7 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should go next page by in <link> by [[', async () => {
|
it('should go next page by in <link> by [[', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/pagenation-link/10`);
|
let page = await Page.navigateTo(webdriver, server.url('/pagenation-link/10'));
|
||||||
await page.sendKeys(']', ']');
|
await page.sendKeys(']', ']');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
@ -181,7 +177,7 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should go to home page into current tab by gh', async () => {
|
it('should go to home page into current tab by gh', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}`);
|
let page = await Page.navigateTo(webdriver, server.url());
|
||||||
await page.sendKeys('g', 'h');
|
await page.sendKeys('g', 'h');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
@ -192,7 +188,7 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should go to home page into current tab by gH', async () => {
|
it('should go to home page into current tab by gH', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}`);
|
let page = await Page.navigateTo(webdriver, server.url());
|
||||||
await page.sendKeys('g', Key.SHIFT, 'H');
|
await page.sendKeys('g', Key.SHIFT, 'H');
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
|
@ -205,7 +201,7 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should reload current tab by r', async () => {
|
it('should reload current tab by r', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/reload`);
|
let page = await Page.navigateTo(webdriver, server.url('/reload'));
|
||||||
await page.scrollTo(500, 500);
|
await page.scrollTo(500, 500);
|
||||||
|
|
||||||
let before: number;
|
let before: number;
|
||||||
|
@ -231,7 +227,7 @@ describe("navigate test", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should reload current tab without cache by R', async () => {
|
it('should reload current tab without cache by R', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/reload`);
|
let page = await Page.navigateTo(webdriver, server.url('/reload'));
|
||||||
await page.scrollTo(500, 500);
|
await page.scrollTo(500, 500);
|
||||||
|
|
||||||
let before: number;
|
let before: number;
|
||||||
|
|
|
@ -1,50 +1,37 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
import eventually from './eventually';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
import OptionPage from './lib/OptionPage';
|
import OptionPage from './lib/OptionPage';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
let app = express();
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body style="width:10000px; height:10000px"></body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("options page", () => {
|
describe("options page", () => {
|
||||||
const port = 12321;
|
let server = new TestServer().receiveContent('/',
|
||||||
let http: http.Server;
|
`<!DOCTYPE html><html lang="en"><body style="width:10000px; height:10000px"></body></html">`,
|
||||||
|
);
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
|
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
if (http) {
|
await server.stop();
|
||||||
http.close();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
|
@ -78,7 +65,7 @@ describe("options page", () => {
|
||||||
let jsonPage = await optionPage.asJSONOptionPage();
|
let jsonPage = await optionPage.asJSONOptionPage();
|
||||||
await jsonPage.updateSettings(`{ "keymaps": { "zz": { "type": "scroll.vertically", "count": 10 } } }`);
|
await jsonPage.updateSettings(`{ "keymaps": { "zz": { "type": "scroll.vertically", "count": 10 } } }`);
|
||||||
|
|
||||||
await browser.tabs.create({ url: `http://127.0.0.1:${port}`, active: false });
|
await browser.tabs.create({ url: server.url(), active: false });
|
||||||
await new Promise((resolve) => setTimeout(resolve, 100));
|
await new Promise((resolve) => setTimeout(resolve, 100));
|
||||||
let handles = await webdriver.getAllWindowHandles();
|
let handles = await webdriver.getAllWindowHandles();
|
||||||
await webdriver.switchTo().window(handles[1]);
|
await webdriver.switchTo().window(handles[1]);
|
||||||
|
|
|
@ -1,26 +1,14 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver } from 'selenium-webdriver';
|
import { WebDriver } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
let app = express();
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.send('ok');
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("tab test", () => {
|
describe("tab test", () => {
|
||||||
const port = 12321;
|
let server = new TestServer().receiveContent('/*', 'ok');
|
||||||
const url = `http://127.0.0.1:${port}/`;
|
|
||||||
|
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
@ -32,22 +20,20 @@ describe("tab test", () => {
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
http = newApp().listen(port);
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
if (http) {
|
await server.stop();
|
||||||
http.close();
|
|
||||||
}
|
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
it('repeats last command', async () => {
|
it('repeats last command', async () => {
|
||||||
let page = await Page.navigateTo(webdriver, url);
|
let page = await Page.navigateTo(webdriver, server.url());
|
||||||
let console = await page.showConsole();
|
let console = await page.showConsole();
|
||||||
await console.execCommand(`tabopen ${url}newtab`);
|
await console.execCommand(`tabopen ${server.url('/newtab')}`);
|
||||||
|
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let current = await browser.tabs.query({ url: `*://*/newtab` });
|
let current = await browser.tabs.query({ url: `*://*/newtab` });
|
||||||
|
@ -65,7 +51,7 @@ describe("tab test", () => {
|
||||||
|
|
||||||
it('repeats last operation', async () => {
|
it('repeats last operation', async () => {
|
||||||
for (let i = 1; i < 5; ++i) {
|
for (let i = 1; i < 5; ++i) {
|
||||||
await browser.tabs.create({ url: `${url}#${i}` });
|
await browser.tabs.create({ url: server.url('/#' + i) });
|
||||||
}
|
}
|
||||||
let before = await browser.tabs.query({});
|
let before = await browser.tabs.query({});
|
||||||
|
|
||||||
|
|
|
@ -1,63 +1,49 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver, Key } from 'selenium-webdriver';
|
import { WebDriver, Key } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
let app = express();
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.send(`<!DOCTYPEhtml>
|
|
||||||
<html lang="en">
|
|
||||||
<body style="width:10000px; height:10000px"></body>
|
|
||||||
</html">`);
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("scroll test", () => {
|
describe("scroll test", () => {
|
||||||
const port = 12321;
|
let server = new TestServer().receiveContent('/',
|
||||||
let http: http.Server;
|
`<!DOCTYPE html><html lang="en"><body style="width:10000px; height:10000px"></body></html>`,
|
||||||
|
);
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let page: Page;
|
let page: Page;
|
||||||
|
|
||||||
before(async() => {
|
before(async() => {
|
||||||
http = newApp().listen(port);
|
|
||||||
|
|
||||||
lanthan = await Builder
|
lanthan = await Builder
|
||||||
.forBrowser('firefox')
|
.forBrowser('firefox')
|
||||||
.spyAddon(path.join(__dirname, '..'))
|
.spyAddon(path.join(__dirname, '..'))
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
|
await server.stop();
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
if (http) {
|
|
||||||
http.close();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
await webdriver.navigate().to(`http://127.0.0.1:${port}`);
|
await webdriver.navigate().to(server.url());
|
||||||
page = await Page.currentContext(webdriver);
|
page = await Page.currentContext(webdriver);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
it('scrolls up by k', async () => {
|
it('scrolls up by j', async () => {
|
||||||
await page.sendKeys('j');
|
await page.sendKeys('j');
|
||||||
|
|
||||||
let scrollY = await page.getScrollY();
|
let scrollY = await page.getScrollY();
|
||||||
assert.equal(scrollY, 64);
|
assert.equal(scrollY, 64);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('scrolls down by j', async () => {
|
it('scrolls down by k', async () => {
|
||||||
await webdriver.executeScript(() => window.scrollTo(0, 200));
|
await webdriver.executeScript(() => window.scrollTo(0, 200));
|
||||||
await page.sendKeys('k');
|
await page.sendKeys('k');
|
||||||
|
|
||||||
|
|
|
@ -1,26 +1,14 @@
|
||||||
import express from 'express';
|
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import * as assert from 'assert';
|
import * as assert from 'assert';
|
||||||
import * as http from 'http';
|
|
||||||
|
|
||||||
|
import TestServer from './lib/TestServer';
|
||||||
import eventually from './eventually';
|
import eventually from './eventually';
|
||||||
import { Builder, Lanthan } from 'lanthan';
|
import { Builder, Lanthan } from 'lanthan';
|
||||||
import { WebDriver, Key } from 'selenium-webdriver';
|
import { WebDriver, Key } from 'selenium-webdriver';
|
||||||
import Page from './lib/Page';
|
import Page from './lib/Page';
|
||||||
|
|
||||||
const newApp = () => {
|
|
||||||
let app = express();
|
|
||||||
app.get('/', (_req, res) => {
|
|
||||||
res.send('ok');
|
|
||||||
});
|
|
||||||
return app;
|
|
||||||
};
|
|
||||||
|
|
||||||
describe("tab test", () => {
|
describe("tab test", () => {
|
||||||
const port = 12321;
|
let server = new TestServer().receiveContent('/*', 'ok');
|
||||||
const url = `http://127.0.0.1:${port}/`;
|
|
||||||
|
|
||||||
let http: http.Server;
|
|
||||||
let lanthan: Lanthan;
|
let lanthan: Lanthan;
|
||||||
let webdriver: WebDriver;
|
let webdriver: WebDriver;
|
||||||
let browser: any;
|
let browser: any;
|
||||||
|
@ -34,23 +22,21 @@ describe("tab test", () => {
|
||||||
.build();
|
.build();
|
||||||
webdriver = lanthan.getWebDriver();
|
webdriver = lanthan.getWebDriver();
|
||||||
browser = lanthan.getWebExtBrowser();
|
browser = lanthan.getWebExtBrowser();
|
||||||
http = newApp().listen(port);
|
await server.start();
|
||||||
});
|
});
|
||||||
|
|
||||||
after(async() => {
|
after(async() => {
|
||||||
if (http) {
|
await server.stop();
|
||||||
http.close();
|
|
||||||
}
|
|
||||||
if (lanthan) {
|
if (lanthan) {
|
||||||
await lanthan.quit();
|
await lanthan.quit();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
win = await browser.windows.create({ url: `${url}#0` });
|
win = await browser.windows.create({ url: server.url('/#0') });
|
||||||
for (let i = 1; i < 5; ++i) {
|
for (let i = 1; i < 5; ++i) {
|
||||||
await browser.tabs.create({ url: `${url}#${i}`, windowId: win.id });
|
await browser.tabs.create({ url: server.url('/#' + i), windowId: win.id });
|
||||||
await webdriver.navigate().to(`${url}#${i}`);
|
await webdriver.navigate().to(server.url('/#' + i));
|
||||||
}
|
}
|
||||||
tabs = await browser.tabs.query({ windowId: win.id });
|
tabs = await browser.tabs.query({ windowId: win.id });
|
||||||
tabs.sort((t1: any, t2: any) => t1.index - t2.index);
|
tabs.sort((t1: any, t2: any) => t1.index - t2.index);
|
||||||
|
@ -219,7 +205,7 @@ describe("tab test", () => {
|
||||||
await eventually(async() => {
|
await eventually(async() => {
|
||||||
let current = await browser.tabs.query({ windowId: win.id });
|
let current = await browser.tabs.query({ windowId: win.id });
|
||||||
assert.ok(current.length === tabs.length + 1);
|
assert.ok(current.length === tabs.length + 1);
|
||||||
assert.ok(current[current.length - 1].url === `view-source:${url}#0`);
|
assert.ok(current[current.length - 1].url === `view-source:${server.url('/#0')}`);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Reference in a new issue