aboutsummaryrefslogtreecommitdiff
path: root/e2e
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2019-04-20 07:58:29 +0000
committerGitHub <noreply@github.com>2019-04-20 07:58:29 +0000
commitc8e8b3db8ec592f43dcc3fa7920dabc26ce409b9 (patch)
tree739bcb398d389dde2453daf7bb8e407df18b3a5f /e2e
parent15b3372c668a4b6120c614e35d3c38639a04b514 (diff)
parent2562d3b9de36d8b0a25d9ec4f67c5c1430773410 (diff)
Merge pull request #568 from ueokande/add-e2e-tests
Add e2e tests
Diffstat (limited to 'e2e')
-rw-r--r--e2e/completion_open.test.js123
-rw-r--r--e2e/follow.test.js257
-rw-r--r--e2e/follow_properties.test.js146
-rw-r--r--e2e/navigate.test.js16
4 files changed, 536 insertions, 6 deletions
diff --git a/e2e/completion_open.test.js b/e2e/completion_open.test.js
index 59d6b83..80628b3 100644
--- a/e2e/completion_open.test.js
+++ b/e2e/completion_open.test.js
@@ -129,4 +129,127 @@ describe("completion on open/tabopen/winopen commands", () => {
assert(items.every(x => x.includes('https://')));
});
})
+
+ it('should display only specified items in "complete" property by set command', async() => {
+ let c = new Console(session);
+
+ const execCommand = async(line) => {
+ await body.sendKeys(':');
+ await session.switchToFrame(0);
+ await c.sendKeys(line, Key.Enter);
+ await session.switchToParentFrame();
+ }
+
+ const typeCommand = async(...keys) => {
+ await body.sendKeys(':');
+ await session.switchToFrame(0);
+ await c.sendKeys(...keys);
+ }
+
+ const cancel = async() => {
+ await c.sendKeys(Key.Escape);
+ await session.switchToParentFrame();
+ }
+
+ await execCommand('set complete=sbh');
+ await typeCommand('open ');
+
+ await eventually(async() => {
+ let completions = await c.getCompletions();
+ let titles = completions.filter(x => x.type === 'title').map(x => x.text);
+ assert.deepEqual(titles, ['Search Engines', 'Bookmarks', 'History'])
+ });
+
+ await cancel();
+ await execCommand('set complete=bss');
+ await typeCommand('open ');
+
+ await eventually(async() => {
+ let completions = await c.getCompletions();
+ let titles = completions.filter(x => x.type === 'title').map(x => x.text);
+ assert.deepEqual(titles, ['Bookmarks', 'Search Engines', 'Search Engines'])
+ });
+ })
+
+ it('should display only specified items in "complete" property by setting', async() => {
+ const settings = {
+ source: 'json',
+ json: `{
+ "keymaps": {
+ ":": { "type": "command.show" }
+ },
+ "search": {
+ "default": "google",
+ "engines": { "google": "https://google.com/search?q={}" }
+ },
+ "properties": {
+ "complete": "sbh"
+ }
+ }`,
+ };
+ await browser.storage.local.set({ settings, });
+
+ let c = new Console(session);
+
+ const typeCommand = async(...keys) => {
+ await body.sendKeys(':');
+ await session.switchToFrame(0);
+ await c.sendKeys(...keys);
+ }
+
+ const cancel = async() => {
+ await c.sendKeys(Key.Escape);
+ await session.switchToParentFrame();
+ }
+
+ await browser.storage.local.set({ settings: {
+ source: 'json',
+ json: `{
+ "keymaps": {
+ ":": { "type": "command.show" }
+ },
+ "search": {
+ "default": "google",
+ "engines": { "google": "https://google.com/search?q={}" }
+ },
+ "properties": {
+ "complete": "sbh"
+ }
+ }`,
+ }});
+ await typeCommand('open ');
+
+ await eventually(async() => {
+ let completions = await c.getCompletions();
+ let titles = completions.filter(x => x.type === 'title').map(x => x.text);
+ assert.deepEqual(titles, ['Search Engines', 'Bookmarks', 'History'])
+ });
+
+ await cancel();
+
+ await browser.storage.local.set({ settings: {
+ source: 'json',
+ json: `{
+ "keymaps": {
+ ":": { "type": "command.show" }
+ },
+ "search": {
+ "default": "google",
+ "engines": { "google": "https://google.com/search?q={}" }
+ },
+ "properties": {
+ "complete": "bss"
+ }
+ }`,
+ }});
+ await typeCommand('open ');
+
+ await eventually(async() => {
+ let completions = await c.getCompletions();
+ let titles = completions.filter(x => x.type === 'title').map(x => x.text);
+ assert.deepEqual(titles, ['Bookmarks', 'Search Engines', 'Search Engines'])
+ });
+
+
+ })
});
diff --git a/e2e/follow.test.js b/e2e/follow.test.js
new file mode 100644
index 0000000..7e49119
--- /dev/null
+++ b/e2e/follow.test.js
@@ -0,0 +1,257 @@
+const express = require('express');
+const lanthan = require('lanthan');
+const path = require('path');
+const assert = require('assert');
+const eventually = require('./eventually');
+
+const Key = lanthan.Key;
+
+const newApp = () => {
+ let app = express();
+
+ app.get('/', (req, res) => {
+ res.send(`<!DOCTYPEhtml>
+<html lang="en">
+ <body><a href="hello">hello</a></body>
+</html">`);
+ });
+
+ app.get('/follow-input', (req, res) => {
+ res.send(`<!DOCTYPEhtml>
+<html lang="en">
+ <body><input></body>
+</html">`);
+ });
+
+ app.get('/area', (req, res) => {
+ res.send(`<!DOCTYPEhtml>
+<html lang="en">
+ <body>
+ <img
+ width="256" height="256" usemap="#map"
+ src="data:image/gif;base64,R0lGODlhAQABAIAAAAUEBAAAACwAAAAAAQABAAACAkQBADs="
+ >
+ <map name="map">
+ <area shape="rect" coords="0,0,64,64" href="/">
+ <area shape="rect" coords="64,64,64,64" href="/">
+ <area shape="rect" coords="128,128,64,64" href="/">
+ </map>
+ </body>
+</html">`);
+ });
+
+ /*
+ * test case: link2 is out of the viewport
+ * +-----------------+
+ * | [link1] |<--- window
+ * | |
+ * |=================|<--- viewport
+ * | [link2] |
+ * | |
+ * +-----------------+
+ */
+ app.get('/test1', (req, res) => {
+ res.send(`<!DOCTYPEhtml>
+<html lang="en">
+ <body>
+ <div><a href="link1">link1</a></div>
+ <div style="min-height:3000px"></div>
+ <div><a href="link2">link2</a></div>
+ </body>
+</html">`);
+ });
+
+/*
+ * test case 2: link2 and link3 are out of window of the frame
+ * +-----------------+
+ * | +-----------+ |
+ * | | [link1] | |
+ * |=================|
+ * | | [link2] | |
+ * | +-----------+ |
+ * | |
+ * +-----------------+
+ */
+ app.get('/test2', (req, res) => {
+ res.send(`<!DOCTYPEhtml>
+<html lang="en">
+ <body><iframe height="5000" src='/test2-frame'></body>
+</html">`);
+ });
+ app.get('/test2-frame', (req, res) => {
+ res.send(`<!DOCTYPEhtml>
+<html lang="en">
+ <body>
+ <div><a href="link1">link1</a></div>
+ <div style="min-height:3000px"></div>
+ <div><a href="link2">link2</a></div>
+ </body>
+</html">`);
+ });
+
+/* test case 3: link2 is out of window of the frame
+ * +-----------------+
+ * | +-----------+ |
+ * | | [link1] | |
+ * | +-----------+ |
+ * | : [link2] : |
+ * | + - - - - - + |
+ * | |
+ * +-----------------+
+ */
+ app.get('/test3', (req, res) => {
+ res.send(`<!DOCTYPEhtml>
+<html lang="en">
+ <body><iframe src='/test3-frame'></body>
+</html">`);
+ });
+ app.get('/test3-frame', (req, res) => {
+ res.send(`<!DOCTYPEhtml>
+<html lang="en">
+ <body>
+ <div><a href="link1">link1</a></div>
+ <div style="min-height:3000px"></div>
+ <div><a href="link2">link2</a></div>
+ </body>
+</html">`);
+ });
+
+ return app;
+};
+
+const waitForHints = async(session) => {
+ await eventually(async() => {
+ let hints = await session.findElementsByCSS('.vimvixen-hint');
+ assert(hints.length > 0);
+ });
+};
+
+describe('follow test', () => {
+
+ const port = 12321;
+ let http;
+ let firefox;
+ let session;
+ let browser;
+
+ before(async() => {
+ http = newApp().listen(port);
+
+ firefox = await lanthan.firefox();
+ await firefox.session.installAddonFromPath(path.join(__dirname, '..'));
+ session = firefox.session;
+ browser = firefox.browser;
+ });
+
+ after(async() => {
+ if (firefox) {
+ await firefox.close();
+ }
+ http.close();
+ });
+
+ afterEach(async() => {
+ let tabs = await browser.tabs.query({});
+ for (let tab of tabs.slice(1)) {
+ await browser.tabs.remove(tab.id);
+ }
+ });
+
+ it('should focus an input by f', async () => {
+ await session.navigateTo(`http://127.0.0.1:${port}/follow-input`);
+
+ let body = await session.findElementByCSS('body');
+ await body.sendKeys('f');
+ await waitForHints(session);
+ await body.sendKeys('a');
+
+ let tagName = await session.executeScript(() => document.activeElement.tagName);
+ assert.equal(tagName.toLowerCase(), 'input');
+ });
+
+ it('should open a link by f', async () => {
+ await session.navigateTo(`http://127.0.0.1:${port}/`);
+
+ let body = await session.findElementByCSS('body');
+ await body.sendKeys('f', 'a');
+
+ let hash = await session.executeScript('location.pathname');
+ await body.sendKeys(hash, '/hello');
+ });
+
+ it('should focus an input by F', async () => {
+ await session.navigateTo(`http://127.0.0.1:${port}/follow-input`);
+
+ let body = await session.findElementByCSS('body');
+ await body.sendKeys(Key.Shift, 'f');
+ await waitForHints(session);
+ await body.sendKeys('a');
+
+ let tagName = await session.executeScript(() => document.activeElement.tagName);
+ assert.equal(tagName.toLowerCase(), 'input');
+ });
+
+ it('should open a link to new tab by F', async () => {
+ await session.navigateTo(`http://127.0.0.1:${port}/`);
+
+ let body = await session.findElementByCSS('body');
+ await body.sendKeys(Key.Shift, 'f');
+ await waitForHints(session);
+ await body.sendKeys('a');
+
+ await eventually(async() => {
+ let tabs = await browser.tabs.query({});
+ assert.equal(tabs.length, 2);
+ assert.equal(new URL(tabs[1].url).pathname, '/hello');
+ assert.equal(tabs[1].openerTabId, tabs[0].id);
+ });
+ });
+
+ it('should show hints of links in area', async () => {
+ await session.navigateTo(`http://127.0.0.1:${port}/area`);
+
+ let body = await session.findElementByCSS('body');
+ await body.sendKeys(Key.Shift, 'f');
+ await eventually(async() => {
+ let hints = await session.findElementsByCSS('.vimvixen-hint');
+ assert.equal(hints.length, 3);
+ });
+ });
+
+ it('should shows hints only in viewport', async () => {
+ await session.navigateTo(`http://127.0.0.1:${port}/test1`);
+
+ let body = await session.findElementByCSS('body');
+ await body.sendKeys(Key.Shift, 'f');
+ await eventually(async() => {
+ let hints = await session.findElementsByCSS('.vimvixen-hint');
+ assert.equal(hints.length, 1);
+ });
+ });
+
+ it('should shows hints only in window of the frame', async () => {
+ await session.navigateTo(`http://127.0.0.1:${port}/test2`);
+
+ let body = await session.findElementByCSS('body');
+ await body.sendKeys(Key.Shift, 'f');
+
+ await session.switchToFrame(0);
+ await eventually(async() => {
+ let hints = await session.findElementsByCSS('.vimvixen-hint');
+ assert.equal(hints.length, 1);
+ });
+ });
+
+ it('should shows hints only in the frame', async () => {
+ await session.navigateTo(`http://127.0.0.1:${port}/test3`);
+
+ let body = await session.findElementByCSS('body');
+ await body.sendKeys(Key.Shift, 'f');
+
+ await session.switchToFrame(0);
+ await eventually(async() => {
+ let hints = await session.findElementsByCSS('.vimvixen-hint');
+ assert.equal(hints.length, 1);
+ });
+ });
+});
diff --git a/e2e/follow_properties.test.js b/e2e/follow_properties.test.js
new file mode 100644
index 0000000..80040a3
--- /dev/null
+++ b/e2e/follow_properties.test.js
@@ -0,0 +1,146 @@
+const express = require('express');
+const lanthan = require('lanthan');
+const path = require('path');
+const assert = require('assert');
+const eventually = require('./eventually');
+
+const Key = lanthan.Key;
+
+const newApp = () => {
+ let app = express();
+
+ app.get('/', (req, res) => {
+ res.send(`<!DOCTYPEhtml>
+<html lang="en">
+ <body>
+ <a href="/">link1</a>
+ <a href="/">link2</a>
+ <a href="/">link3</a>
+ <a href="/">link4</a>
+ <a href="/">link5</a>
+ </body>
+</html">`);
+ });
+ return app;
+};
+
+const waitForHints = async(session) => {
+ await eventually(async() => {
+ let hints = await session.findElementsByCSS('.vimvixen-hint');
+ assert(hints.length > 0);
+ });
+};
+
+describe('follow properties test', () => {
+
+ const port = 12321;
+ let http;
+ let firefox;
+ let session;
+ let browser;
+ let body;
+
+ before(async() => {
+ http = newApp().listen(port);
+
+ firefox = await lanthan.firefox({
+ spy: path.join(__dirname, '..'),
+ builderf: (builder) => {
+ builder.addFile('build/settings.js');
+ },
+ });
+ session = firefox.session;
+ browser = firefox.browser;
+
+ await browser.storage.local.set({ settings: {
+ source: 'json',
+ json: `{
+ "keymaps": {
+ ":": { "type": "command.show" },
+ "f": { "type": "follow.start", "newTab": false },
+ "F": { "type": "follow.start", "newTab": true, "background": false },
+ "<C-F>": { "type": "follow.start", "newTab": true, "background": true }
+ },
+ "search": {
+ "default": "google",
+ "engines": { "google": "https://google.com/search?q={}" }
+ },
+ "properties": {
+ "hintchars": "jk"
+ }
+ }`,
+ }});
+ });
+
+ after(async() => {
+ if (firefox) {
+ await firefox.close();
+ }
+ http.close();
+ });
+
+ beforeEach(async() => {
+ await session.navigateTo(`http://127.0.0.1:${port}/`);
+ body = await session.findElementByCSS('body');
+ });
+
+ afterEach(async() => {
+ let tabs = await browser.tabs.query({});
+ for (let tab of tabs.slice(1)) {
+ await browser.tabs.remove(tab.id);
+ }
+ });
+
+ it('should show hints with hintchars by settings', async () => {
+ await body.sendKeys('f');
+ await eventually(async() => {
+ let hints = await session.findElementsByCSS('.vimvixen-hint');
+ assert.equal(hints.length, 5);
+
+ assert.equal(await hints[0].getText(), 'J');
+ assert.equal(await hints[1].getText(), 'K');
+ assert.equal(await hints[2].getText(), 'JJ');
+ assert.equal(await hints[3].getText(), 'JK');
+ assert.equal(await hints[4].getText(), 'KJ');
+ });
+
+ await body.sendKeys('j');
+
+ await eventually(async() => {
+ let hints = await session.findElementsByCSS('.vimvixen-hint');
+
+ assert.equal(await hints[0].getStyle('display'), 'block');
+ assert.equal(await hints[1].getStyle('display'), 'none');
+ assert.equal(await hints[2].getStyle('display'), 'block');
+ assert.equal(await hints[3].getStyle('display'), 'block');
+ assert.equal(await hints[4].getStyle('display'), 'none');
+
+ });
+ });
+
+ it('should open tab in background by background:false', async () => {
+ await body.sendKeys(Key.Shift, 'f');
+ await eventually(async() => {
+ let hints = await session.findElementsByCSS('.vimvixen-hint');
+ assert.equal(hints.length, 5);
+ });
+ await body.sendKeys('jj');
+
+ let tabs = await browser.tabs.query({});
+ assert.equal(tabs[0].active, false);
+ assert.equal(tabs[1].active, true);
+ });
+
+ it('should open tab in background by background:true', async () => {
+ await body.sendKeys(Key.Control, 'f');
+ await eventually(async() => {
+ let hints = await session.findElementsByCSS('.vimvixen-hint');
+ assert.equal(hints.length, 5);
+ });
+ await body.sendKeys('jj');
+
+ let tabs = await browser.tabs.query({});
+ assert.equal(tabs[0].active, true);
+ assert.equal(tabs[1].active, false);
+ });
+});
diff --git a/e2e/navigate.test.js b/e2e/navigate.test.js
index 5d9365b..17552e5 100644
--- a/e2e/navigate.test.js
+++ b/e2e/navigate.test.js
@@ -125,16 +125,20 @@ describe("navigate test", () => {
await body.sendKeys(Key.Shift, 'h');
- let tab = (await browser.tabs.query({}))[0];
- let url = new URL(tab.url);
- assert.equal(url.pathname, `/first`)
+ await eventually(async() => {
+ let tab = (await browser.tabs.query({}))[0];
+ let url = new URL(tab.url);
+ assert.equal(url.pathname, `/first`)
+ });
body = await session.findElementByCSS('body');
await body.sendKeys(Key.Shift, 'l');
- tab = (await browser.tabs.query({}))[0];
- url = new URL(tab.url);
- assert.equal(url.pathname, `/second`)
+ await eventually(async() => {
+ tab = (await browser.tabs.query({}))[0];
+ url = new URL(tab.url);
+ assert.equal(url.pathname, `/second`)
+ });
});
it('should go previous and next page in <a> by [[ and ]]', async () => {