diff options
author | Shin'ya Ueoka <ueokande@i-beam.org> | 2019-04-14 12:35:37 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-04-14 12:35:37 +0000 |
commit | 640ac38fb6d486159057d1bc8d78d1792f1d1784 (patch) | |
tree | f9b4f6da33a445856f8dc22487588ba6b69323cd /e2e | |
parent | 859d0372b5bb7297a0b8ed37a559d88a425f3799 (diff) | |
parent | 908973a0a246474342246c2bad09a6db809e9084 (diff) |
Merge pull request #564 from ueokande/lanthan-integration-test
Use lanthan to do E2E testing
Diffstat (limited to 'e2e')
-rw-r--r-- | e2e/command_addbookmark.test.js | 67 | ||||
-rw-r--r-- | e2e/command_bdelete.test.js | 203 | ||||
-rw-r--r-- | e2e/command_buffer.test.js | 202 | ||||
-rw-r--r-- | e2e/command_open.test.js | 149 | ||||
-rw-r--r-- | e2e/command_quit.test.js | 125 | ||||
-rw-r--r-- | e2e/command_tabopen.test.js | 160 | ||||
-rw-r--r-- | e2e/command_winopen.test.js | 172 | ||||
-rw-r--r-- | e2e/console.test.js | 125 | ||||
-rw-r--r-- | e2e/mark.test.js | 2 | ||||
-rw-r--r-- | e2e/navigate.test.js | 125 | ||||
-rw-r--r-- | e2e/scroll.test.js | 2 | ||||
-rw-r--r-- | e2e/settings.js | 85 | ||||
-rw-r--r-- | e2e/tab.test.js | 2 | ||||
-rw-r--r-- | e2e/zoom.test.js | 19 |
14 files changed, 1407 insertions, 31 deletions
diff --git a/e2e/command_addbookmark.test.js b/e2e/command_addbookmark.test.js new file mode 100644 index 0000000..e8995bc --- /dev/null +++ b/e2e/command_addbookmark.test.js @@ -0,0 +1,67 @@ +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('/happy', (req, res) => { + res.send(`<!DOCTYPEhtml> +<html lang="en"> + <head> + <title>how to be happy</title> + </head> +</html">`); + }); + return app; +}; + +describe('addbookmark command test', () => { + const port = 12321; + let http; + let firefox; + let session; + let browser; + + 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; + }); + + after(async() => { + http.close(); + if (firefox) { + await firefox.close(); + } + }); + + beforeEach(async() => { + await session.navigateTo(`http://127.0.0.1:${port}/happy`); + }); + + it('should add a bookmark from the current page', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('addbookmark how to be happy', Key.Enter); + + await eventually(async() => { + var bookmarks = await browser.bookmarks.search({ title: 'how to be happy' }); + assert.equal(bookmarks.length, 1); + assert.equal(bookmarks[0].url, `http://127.0.0.1:${port}/happy`); + }); + }); +}); diff --git a/e2e/command_bdelete.test.js b/e2e/command_bdelete.test.js new file mode 100644 index 0000000..1f416db --- /dev/null +++ b/e2e/command_bdelete.test.js @@ -0,0 +1,203 @@ +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"> + <head> + <title>my_${req.path.slice(1)}</title> + </head> + <body><h1>${req.path}</h1></body> +</html">`); + }); + return app; +}; + +describe('bdelete/bdeletes command test', () => { + const port = 12321; + let http; + let firefox; + let session; + let browser; + + 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; + }); + + after(async() => { + http.close(); + if (firefox) { + await firefox.close(); + } + }); + + beforeEach(async() => { + let tabs = await browser.tabs.query({}); + for (let tab of tabs.slice(1)) { + 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.create({ url: `http://127.0.0.1:${port}/site2`, pinned: true }) + await browser.tabs.create({ url: `http://127.0.0.1:${port}/site3`, pinned: true }) + await browser.tabs.create({ url: `http://127.0.0.1:${port}/site4` }) + await browser.tabs.create({ url: `http://127.0.0.1:${port}/site5` }) + + await eventually(async() => { + let handles = await session.getWindowHandles(); + assert.equal(handles.length, 5); + await session.switchToWindow(handles[2]); + await session.findElementByCSS('iframe'); + }); + + await new Promise((resolve) => setTimeout(resolve, 100)); + }); + + it('should delete an unpinned tab by bdelete command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('bdelete site5', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.deepEqual(tabs.map(t => t.url), [ + `http://127.0.0.1:${port}/site1`, + `http://127.0.0.1:${port}/site2`, + `http://127.0.0.1:${port}/site3`, + `http://127.0.0.1:${port}/site4`, + ]) + }); + }); + + it('should not delete an pinned tab by bdelete command by bdelete command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('bdelete site1', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 5); + }); + }); + + it('should show an error when no tabs are matched by bdelete command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('bdelete xyz', Key.Enter); + + await eventually(async() => { + let p = await session.findElementByCSS('.vimvixen-console-error'); + let text = await p.getText(); + assert.equal(text, 'No matching buffer for xyz'); + }); + }); + + it('should show an error when more than one tabs are matched by bdelete command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('bdelete site', Key.Enter); + + await eventually(async() => { + let p = await session.findElementByCSS('.vimvixen-console-error'); + let text = await p.getText(); + assert.equal(text, 'More than one match for site'); + }); + }); + + it('should delete an unpinned tab by bdelete! command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('bdelete! site5', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.deepEqual(tabs.map(t => t.url), [ + `http://127.0.0.1:${port}/site1`, + `http://127.0.0.1:${port}/site2`, + `http://127.0.0.1:${port}/site3`, + `http://127.0.0.1:${port}/site4`, + ]) + }); + }); + + it('should delete an pinned tab by bdelete! command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('bdelete! site1', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.deepEqual(tabs.map(t => t.url), [ + `http://127.0.0.1:${port}/site2`, + `http://127.0.0.1:${port}/site3`, + `http://127.0.0.1:${port}/site4`, + `http://127.0.0.1:${port}/site5`, + ]) + }); + }); + + it('should delete unpinned tabs by bdeletes command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('bdeletes site', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.deepEqual(tabs.map(t => t.url), [ + `http://127.0.0.1:${port}/site1`, + `http://127.0.0.1:${port}/site2`, + `http://127.0.0.1:${port}/site3`, + ]) + }); + }); + + it('should delete both pinned and unpinned tabs by bdeletes! command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('bdeletes! site', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 1); + }); + }); +}); diff --git a/e2e/command_buffer.test.js b/e2e/command_buffer.test.js new file mode 100644 index 0000000..bf94428 --- /dev/null +++ b/e2e/command_buffer.test.js @@ -0,0 +1,202 @@ +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"> + <head> + <title>my_${req.path.slice(1)}</title> + </head> + <body><h1>${req.path}</h1></body> +</html">`); + }); + return app; +}; + +describe('buffer command test', () => { + const port = 12321; + let http; + let firefox; + let session; + let browser; + + 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; + }); + + after(async() => { + http.close(); + if (firefox) { + await firefox.close(); + } + }); + + beforeEach(async() => { + let tabs = await browser.tabs.query({}); + for (let tab of tabs.slice(1)) { + await browser.tabs.remove(tab.id); + } + await browser.tabs.update(tabs[0].id, { url: `http://127.0.0.1:${port}/site1` }); + for (let i = 2; i <= 5; ++i) { + await browser.tabs.create({ url: `http://127.0.0.1:${port}/site${i}`}) + } + + await eventually(async() => { + let handles = await session.getWindowHandles(); + assert.equal(handles.length, 5); + await session.switchToWindow(handles[2]); + await session.findElementByCSS('iframe'); + }); + + await new Promise((resolve) => setTimeout(resolve, 100)); + }); + + it('should do nothing by buffer command with no parameters', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('buffer', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }); + assert.equal(tabs[0].index, 2); + }); + }); + + it('should select a tab by buffer command with a number', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('buffer', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }); + assert.equal(tabs[0].index, 2); + }); + }); + + it('should should an out of range error by buffer commands', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('buffer 0', Key.Enter); + + await eventually(async() => { + let p = await session.findElementByCSS('.vimvixen-console-error'); + let text = await p.getText(); + assert.equal(text, 'tab 0 does not exist'); + }); + + await session.switchToParentFrame(); + body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + input = await session.findElementByCSS('input'); + await input.sendKeys('buffer 9', Key.Enter); + + await eventually(async() => { + let p = await session.findElementByCSS('.vimvixen-console-error'); + let text = await p.getText(); + assert.equal(text, 'tab 9 does not exist'); + }); + }); + + it('should select a tab by buffer command with a title', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('buffer my_site1', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }); + assert.equal(tabs[0].index, 0); + }); + }); + + it('should select a tab by buffer command with an URL', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('buffer /site1', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }); + assert.equal(tabs[0].index, 0); + }); + }); + + it('should select tabs rotately', async() => { + let handles = await session.getWindowHandles(); + await session.switchToWindow(handles[4]); + + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('buffer site', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }); + assert.equal(tabs[0].index, 0); + }); + }); + + it('should do nothing by ":buffer %"', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('buffer %', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }); + assert.equal(tabs[0].index, 2); + }); + }); + + it('should selects last selected tab by ":buffer #"', async() => { + let handles = await session.getWindowHandles(); + await session.switchToWindow(handles[1]); + + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('buffer #', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }); + assert.equal(tabs[0].index, 2); + }); + }); +}); diff --git a/e2e/command_open.test.js b/e2e/command_open.test.js new file mode 100644 index 0000000..0d41f96 --- /dev/null +++ b/e2e/command_open.test.js @@ -0,0 +1,149 @@ +const express = require('express'); +const lanthan = require('lanthan'); +const path = require('path'); +const assert = require('assert'); +const eventually = require('./eventually'); +const settings = require('./settings'); + +const Key = lanthan.Key; + +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", () => { + const port = 12321; + let http; + let firefox; + let session; + let browser; + let body; + + before(async() => { + firefox = await lanthan.firefox({ + spy: path.join(__dirname, '..'), + builderf: (builder) => { + builder.addFile('build/settings.js'); + }, + }); + session = firefox.session; + browser = firefox.browser; + http = newApp().listen(port); + + await browser.storage.local.set({ + settings, + }); + }); + + after(async() => { + http.close(); + if (firefox) { + await firefox.close(); + } + }); + + beforeEach(async() => { + await session.navigateTo(`http://127.0.0.1:${port}`); + body = await session.findElementByCSS('body'); + }) + + it('should open default search for keywords by open command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('open an apple', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }); + let url = new URL(tabs[0].url); + assert.equal(url.href, `http://127.0.0.1:${port}/google?q=an%20apple`) + }); + }); + + it('should open certain search page for keywords by open command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('open yahoo an apple', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }) + let url = new URL(tabs[0].url); + assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=an%20apple`) + }); + }); + + it('should open default engine with empty keywords by open command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('open', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }) + let url = new URL(tabs[0].url); + assert.equal(url.href, `http://127.0.0.1:${port}/google?q=`) + }); + }); + + it('should open certain search page for empty keywords by open command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('open yahoo', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }) + let url = new URL(tabs[0].url); + assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=`) + }); + }); + + it('should open a site with domain by open command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('open i-beam.org', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }) + let url = new URL(tabs[0].url); + assert.equal(url.href, 'https://i-beam.org/') + }); + }); + + it('should open a site with URL by open command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('open https://i-beam.org', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({ active: true }) + let url = new URL(tabs[0].url); + assert.equal(url.href, 'https://i-beam.org/') + }); + }); +}); diff --git a/e2e/command_quit.test.js b/e2e/command_quit.test.js new file mode 100644 index 0000000..ee4c2d8 --- /dev/null +++ b/e2e/command_quit.test.js @@ -0,0 +1,125 @@ +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"> + <head> + <title>my_${req.path.slice(1)}</title> + </head> + <body><h1>${req.path}</h1></body> +</html">`); + }); + return app; +}; + +describe('quit/quitall command test', () => { + const port = 12321; + let http; + let firefox; + let session; + let browser; + + 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; + }); + + after(async() => { + http.close(); + if (firefox) { + await firefox.close(); + } + }); + + beforeEach(async() => { + let tabs = await browser.tabs.query({}); + for (let tab of tabs.slice(1)) { + await browser.tabs.remove(tab.id); + } + await browser.tabs.update(tabs[0].id, { url: `http://127.0.0.1:${port}/site1` }); + for (let i = 2; i <= 5; ++i) { + await browser.tabs.create({ url: `http://127.0.0.1:${port}/site${i}`}) + } + + await eventually(async() => { + let handles = await session.getWindowHandles(); + assert.equal(handles.length, 5); + await session.switchToWindow(handles[2]); + await session.findElementByCSS('iframe'); + }); + + await new Promise((resolve) => setTimeout(resolve, 100)); + }); + + it('should current tab by q command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('q', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 4) + }); + }); + + it('should current tab by quit command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('quit', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 4) + }); + }); + + it('should current tab by qa command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('qa', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 1) + }); + }); + + it('should current tab by quitall command', async() => { + let body = await session.findElementByCSS('body'); + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + await input.sendKeys('quitall', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 1) + }); + }); +}); diff --git a/e2e/command_tabopen.test.js b/e2e/command_tabopen.test.js new file mode 100644 index 0000000..9c5cf3a --- /dev/null +++ b/e2e/command_tabopen.test.js @@ -0,0 +1,160 @@ +const express = require('express'); +const lanthan = require('lanthan'); +const path = require('path'); +const assert = require('assert'); +const eventually = require('./eventually'); +const settings = require('./settings'); + +const Key = lanthan.Key; + +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", () => { + 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, + }); + }); + + after(async() => { + http.close(); + if (firefox) { + await firefox.close(); + } + }); + + beforeEach(async() => { + let tabs = await browser.tabs.query({}); + for (let tab of tabs.slice(1)) { + await browser.tabs.remove(tab.id); + } + + await session.navigateTo(`http://127.0.0.1:${port}`); + body = await session.findElementByCSS('body'); + }) + + it('should open default search for keywords by tabopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('tabopen an apple', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 2); + let url = new URL(tabs[1].url); + assert.equal(url.href, `http://127.0.0.1:${port}/google?q=an%20apple`) + }); + }); + + it('should open certain search page for keywords by tabopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('tabopen yahoo an apple', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 2); + let url = new URL(tabs[1].url); + assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=an%20apple`) + }); + }); + + it('should open default engine with empty keywords by tabopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('tabopen', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 2); + let url = new URL(tabs[1].url); + assert.equal(url.href, `http://127.0.0.1:${port}/google?q=`) + }); + }); + + it('should open certain search page for empty keywords by tabopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('tabopen yahoo', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 2); + let url = new URL(tabs[1].url); + assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=`) + }); + }); + + it('should open a site with domain by tabopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('tabopen i-beam.org', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 2); + let url = new URL(tabs[1].url); + assert.equal(url.href, 'https://i-beam.org/') + }); + }); + + it('should open a site with URL by tabopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('tabopen https://i-beam.org', Key.Enter); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 2); + let url = new URL(tabs[1].url); + assert.equal(url.href, 'https://i-beam.org/') + }); + }); +}); diff --git a/e2e/command_winopen.test.js b/e2e/command_winopen.test.js new file mode 100644 index 0000000..536d759 --- /dev/null +++ b/e2e/command_winopen.test.js @@ -0,0 +1,172 @@ +const express = require('express'); +const lanthan = require('lanthan'); +const path = require('path'); +const assert = require('assert'); +const eventually = require('./eventually'); +const settings = require('./settings'); + +const Key = lanthan.Key; + +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", () => { + 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, + }); + }); + + after(async() => { + http.close(); + if (firefox) { + await firefox.close(); + } + }); + + beforeEach(async() => { + let wins = await browser.windows.getAll(); + for (let win of wins.slice(1)) { + await browser.windows.remove(win.id); + } + + await session.navigateTo(`http://127.0.0.1:${port}`); + body = await session.findElementByCSS('body'); + }) + + it('should open default search for keywords by winopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('winopen an apple', Key.Enter); + + await eventually(async() => { + let wins = await browser.windows.getAll(); + assert.equal(wins.length, 2); + + let tabs = await browser.tabs.query({ windowId: wins[1].id }); + let url = new URL(tabs[0].url); + assert.equal(url.href, `http://127.0.0.1:${port}/google?q=an%20apple`) + }); + }); + + it('should open certain search page for keywords by winopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('winopen yahoo an apple', Key.Enter); + + await eventually(async() => { + let wins = await browser.windows.getAll(); + assert.equal(wins.length, 2); + + let tabs = await browser.tabs.query({ windowId: wins[1].id }); + let url = new URL(tabs[0].url); + assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=an%20apple`) + }); + }); + + it('should open default engine with empty keywords by winopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('winopen', Key.Enter); + + await eventually(async() => { + let wins = await browser.windows.getAll(); + assert.equal(wins.length, 2); + + let tabs = await browser.tabs.query({ windowId: wins[1].id }); + let url = new URL(tabs[0].url); + assert.equal(url.href, `http://127.0.0.1:${port}/google?q=`) + }); + }); + + it('should open certain search page for empty keywords by winopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('winopen yahoo', Key.Enter); + + await eventually(async() => { + let wins = await browser.windows.getAll(); + assert.equal(wins.length, 2); + + let tabs = await browser.tabs.query({ windowId: wins[1].id }); + let url = new URL(tabs[0].url); + assert.equal(url.href, `http://127.0.0.1:${port}/yahoo?q=`) + }); + }); + + it('should open a site with domain by winopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('winopen i-beam.org', Key.Enter); + + await eventually(async() => { + let wins = await browser.windows.getAll(); + assert.equal(wins.length, 2); + + let tabs = await browser.tabs.query({ windowId: wins[1].id }); + let url = new URL(tabs[0].url); + assert.equal(url.href, 'https://i-beam.org/') + }); + }); + + it('should open a site with URL by winopen command ', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let input = await session.findElementByCSS('input'); + input.sendKeys('winopen https://i-beam.org', Key.Enter); + + await eventually(async() => { + let wins = await browser.windows.getAll(); + assert.equal(wins.length, 2); + + let tabs = await browser.tabs.query({ windowId: wins[1].id }); + let url = new URL(tabs[0].url); + assert.equal(url.href, 'https://i-beam.org/') + }); + }); +}); diff --git a/e2e/console.test.js b/e2e/console.test.js new file mode 100644 index 0000000..6f6341f --- /dev/null +++ b/e2e/console.test.js @@ -0,0 +1,125 @@ +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"> + <head> + <title>Hello, world!</title> + </head> +</html">`); + }); + return app; +}; + + +describe("console test", () => { + const port = 12321; + let http; + let firefox; + let session; + let browser; + let tab; + let body; + + before(async() => { + firefox = await lanthan.firefox(); + await firefox.session.installAddonFromPath(path.join(__dirname, '..')); + session = firefox.session; + browser = firefox.browser; + http = newApp().listen(port); + }); + + after(async() => { + http.close(); + if (firefox) { + await firefox.close(); + } + }); + + beforeEach(async() => { + await session.navigateTo(`http://127.0.0.1:${port}`); + body = await session.findElementByCSS('body'); + }); + + it('open console with :', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + + let input = await session.findElementByCSS('input'); + assert.equal(await input.isDisplayed(), true); + }); + + it('open console with open command by o', async() => { + await body.sendKeys('o'); + + await session.switchToFrame(0); + let value = await session.executeScript(() => document.querySelector('input').value); + assert.equal(value, 'open '); + }); + + it('open console with open command and current URL by O', async() => { + await body.sendKeys(Key.Shift, 'o'); + + await session.switchToFrame(0); + let value = await session.executeScript(() => document.querySelector('input').value); + assert.equal(value, `open http://127.0.0.1:${port}/`); + }); + + it('open console with tabopen command by t', async() => { + await body.sendKeys('t'); + + await session.switchToFrame(0); + let value = await session.executeScript(() => document.querySelector('input').value); + assert.equal(value, 'tabopen '); + }); + + it('open console with tabopen command and current URL by T', async() => { + await body.sendKeys(Key.Shift, 't'); + + await session.switchToFrame(0); + let value = await session.executeScript(() => document.querySelector('input').value); + assert.equal(value, `tabopen http://127.0.0.1:${port}/`); + }); + + it('open console with winopen command by w', async() => { + await body.sendKeys('w'); + + await session.switchToFrame(0); + let value = await session.executeScript(() => document.querySelector('input').value); + assert.equal(value, 'winopen '); + }); + + it('open console with winopen command and current URL by W', async() => { + await body.sendKeys(Key.Shift, 'W'); + + await session.switchToFrame(0); + let value = await session.executeScript(() => document.querySelector('input').value); + assert.equal(value, `winopen http://127.0.0.1:${port}/`); + }); + + it('open console with buffer command by b', async() => { + await body.sendKeys('b'); + + await session.switchToFrame(0); + let value = await session.executeScript(() => document.querySelector('input').value); + assert.equal(value, `buffer `); + }); + + it('open console with addbookmark command with title by a', async() => { + await body.sendKeys('a'); + + await session.switchToFrame(0); + let value = await session.executeScript(() => document.querySelector('input').value); + assert.equal(value, `addbookmark Hello, world!`); + }); +}); + diff --git a/e2e/mark.test.js b/e2e/mark.test.js index 8f350b7..8716c1e 100644 --- a/e2e/mark.test.js +++ b/e2e/mark.test.js @@ -29,7 +29,7 @@ describe("mark test", () => { http = newApp().listen(port); firefox = await lanthan.firefox(); - await firefox.session.installAddon(path.join(__dirname, '..')); + await firefox.session.installAddonFromPath(path.join(__dirname, '..')); session = firefox.session; browser = firefox.browser; }); diff --git a/e2e/navigate.test.js b/e2e/navigate.test.js index 089fa56..5d9365b 100644 --- a/e2e/navigate.test.js +++ b/e2e/navigate.test.js @@ -24,6 +24,15 @@ const newApp = () => { </head> </html">`); }); + app.get('/reload', (req, res) => { + res.status(200).send(` +<html lang="en"> + <head> + <script>window.location.hash = Date.now()</script> + </head> + <body style="width:10000px; height:10000px"></body> +</html">`); + }); app.get('/*', (req, res) => { res.send(`<!DOCTYPEhtml> @@ -34,7 +43,7 @@ const newApp = () => { return app; }; -describe("zoom test", () => { +describe("navigate test", () => { const port = 12321; let http; @@ -45,8 +54,12 @@ describe("zoom test", () => { before(async() => { http = newApp().listen(port); - firefox = await lanthan.firefox(); - await firefox.session.installAddon(path.join(__dirname, '..')); + firefox = await lanthan.firefox({ + prefs: { + 'browser.startup.homepage': `http://127.0.0.1:${port}#home`, + } + }); + await firefox.session.installAddonFromPath(path.join(__dirname, '..')); session = firefox.session; browser = firefox.browser; }); @@ -58,15 +71,24 @@ describe("zoom test", () => { http.close(); }); + beforeEach(async() => { + let tabs = await browser.tabs.query({}); + for (let tab of tabs.slice(1)) { + await browser.tabs.remove(tab.id); + } + }) + it('should go to parent path without hash by gu', async () => { await session.navigateTo(`http://127.0.0.1:${port}/a/b/c`); let body = await session.findElementByCSS('body'); await body.sendKeys('g', 'u'); - let tab = (await browser.tabs.query({}))[0]; - let url = new URL(tab.url); - assert.equal(url.pathname, `/a/b/`) + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.equal(url.pathname, `/a/b/`) + }); }); it('should remove hash by gu', async () => { @@ -75,10 +97,12 @@ describe("zoom test", () => { await body.sendKeys('g', 'u'); - let tab = (await browser.tabs.query({}))[0]; - let url = new URL(tab.url); - assert.equal(url.hash, '') - assert.equal(url.pathname, `/a/b/c`) + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.equal(url.hash, '') + assert.equal(url.pathname, `/a/b/c`) + }); }); it('should go to root path by gU', async () => { @@ -162,6 +186,85 @@ describe("zoom test", () => { assert.equal(url.pathname, '/pagenation-link/11'); }); }); -}); + it('should go to home page into current tab by gh', async () => { + await session.navigateTo(`http://127.0.0.1:${port}`); + let body = await session.findElementByCSS('body'); + await body.sendKeys('g', 'h'); + + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.equal(url.hash, '#home'); + }); + }); + + it('should go to home page into current tab by gH', async () => { + await session.navigateTo(`http://127.0.0.1:${port}`); + let body = await session.findElementByCSS('body'); + await body.sendKeys('g', Key.Shift, 'H'); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.equal(tabs.length, 2); + assert.equal(new URL(tabs[0].url).hash, ''); + assert.equal(new URL(tabs[1].url).hash, '#home'); + assert.equal(tabs[1].active, true); + }); + }); + + it('should reload current tab by r', async () => { + await session.navigateTo(`http://127.0.0.1:${port}/reload`); + await session.executeScript(() => window.scrollTo(500, 500)); + let before + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + before = Number(new URL(tab.url).hash.split('#')[1]); + assert(before > 0); + }); + + let body = await session.findElementByCSS('body'); + await body.sendKeys('r'); + + let after + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + after = Number(new URL(tab.url).hash.split('#')[1]); + assert(after > before); + }); + await eventually(async() => { + let pageYOffset = await session.executeScript(() => window.pageYOffset); + assert.equal(pageYOffset, 500); + }); + }); + + it('should reload current tab without cache by R', async () => { + await session.navigateTo(`http://127.0.0.1:${port}/reload`); + await session.executeScript(() => window.scrollTo(500, 500)); + let before + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + before = Number(new URL(tab.url).hash.split('#')[1]); + assert(before > 0); + }); + + let body = await session.findElementByCSS('body'); + await body.sendKeys(Key.Shift, 'R'); + + let after + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + after = Number(new URL(tab.url).hash.split('#')[1]); + assert(after > before); + }); + + // assert that the page offset is reset to 0, and 'eventually' is timed-out. + await assert.rejects(async () => { + await eventually(async() => { + let pageYOffset = await session.executeScript(() => window.pageYOffset); + assert.equal(pageYOffset, 500); + }); + }); + }); +}); diff --git a/e2e/scroll.test.js b/e2e/scroll.test.js index 32b0012..0ce3ec6 100644 --- a/e2e/scroll.test.js +++ b/e2e/scroll.test.js @@ -28,7 +28,7 @@ describe("scroll test", () => { http = newApp().listen(port); firefox = await lanthan.firefox(); - await firefox.session.installAddon(path.join(__dirname, '..')); + await firefox.session.installAddonFromPath(path.join(__dirname, '..')); session = firefox.session; }); diff --git a/e2e/settings.js b/e2e/settings.js new file mode 100644 index 0000000..e09747f --- /dev/null +++ b/e2e/settings.js @@ -0,0 +1,85 @@ +module.exports = { + source: 'json', + json: `{ + "keymaps": { + "0": { "type": "scroll.home" }, + ":": { "type": "command.show" }, + "o": { "type": "command.show.open", "alter": false }, + "O": { "type": "command.show.open", "alter": true }, + "t": { "type": "command.show.tabopen", "alter": false }, + "T": { "type": "command.show.tabopen", "alter": true }, + "w": { "type": "command.show.winopen", "alter": false }, + "W": { "type": "command.show.winopen", "alter": true }, + "b": { "type": "command.show.buffer" }, + "a": { "type": "command.show.addbookmark", "alter": true }, + "k": { "type": "scroll.vertically", "count": -1 }, + "j": { "type": "scroll.vertically", "count": 1 }, + "h": { "type": "scroll.horizonally", "count": -1 }, + "l": { "type": "scroll.horizonally", "count": 1 }, + "<C-U>": { "type": "scroll.pages", "count": -0.5 }, + "<C-D>": { "type": "scroll.pages", "count": 0.5 }, + "<C-B>": { "type": "scroll.pages", "count": -1 }, + "<C-F>": { "type": "scroll.pages", "count": 1 }, + "gg": { "type": "scroll.top" }, + "G": { "type": "scroll.bottom" }, + "$": { "type": "scroll.end" }, + "d": { "type": "tabs.close" }, + "D": { "type": "tabs.close.right" }, + "!d": { "type": "tabs.close.force" }, + "u": { "type": "tabs.reopen" }, + "K": { "type": "tabs.prev", "count": 1 }, + "J": { "type": "tabs.next", "count": 1 }, + "gT": { "type": "tabs.prev", "count": 1 }, + "gt": { "type": "tabs.next", "count": 1 }, + "g0": { "type": "tabs.first" }, + "g$": { "type": "tabs.last" }, + "<C-6>": { "type": "tabs.prevsel" }, + "r": { "type": "tabs.reload", "cache": false }, + "R": { "type": "tabs.reload", "cache": true }, + "zp": { "type": "tabs.pin.toggle" }, + "zd": { "type": "tabs.duplicate" }, + "zi": { "type": "zoom.in" }, + "zo": { "type": "zoom.out" }, + "zz": { "type": "zoom.neutral" }, + "f": { "type": "follow.start", "newTab": false }, + "F": { "type": "follow.start", "newTab": true, "background": false }, + "m": { "type": "mark.set.prefix" }, + "'": { "type": "mark.jump.prefix" }, + "H": { "type": "navigate.history.prev" }, + "L": { "type": "navigate.history.next" }, + "[[": { "type": "navigate.link.prev" }, + "]]": { "type": "navigate.link.next" }, + "gu": { "type": "navigate.parent" }, + "gU": { "type": "navigate.root" }, + "gi": { "type": "focus.input" }, + "gf": { "type": "page.source" }, + "gh": { "type": "page.home" }, + "gH": { "type": "page.home", "newTab": true }, + "y": { "type": "urls.yank" }, + "p": { "type": "urls.paste", "newTab": false }, + "P": { "type": "urls.paste", "newTab": true }, + "/": { "type": "find.start" }, + "n": { "type": "find.next" }, + "N": { "type": "find.prev" }, + "<S-Esc>": { "type": "addon.toggle.enabled" } + }, + "search": { + "default": "google", + "engines": { + "google": "http://127.0.0.1:12321/google?q={}", + "yahoo": "http://127.0.0.1:12321/yahoo?q={}", + "bing": "http://127.0.0.1:12321/bind?q={}", + "duckduckgo": "http://127.0.0.1:12321/duplicate?q={}", + "twitter": "http://127.0.0.1:12321/twitter?q={}", + "wikipedia": "http://127.0.0.1:12321/wikipedia?q={}" + } + }, + "properties": { + "hintchars": "abcdefghijklmnopqrstuvwxyz", + "smoothscroll": false, + "complete": "sbh" + }, + "blacklist": [ + ] +}`, +} diff --git a/e2e/tab.test.js b/e2e/tab.test.js index 39338aa..16d61ae 100644 --- a/e2e/tab.test.js +++ b/e2e/tab.test.js @@ -28,7 +28,7 @@ describe("tab test", () => { before(async() => { firefox = await lanthan.firefox(); - await firefox.session.installAddon(path.join(__dirname, '..')); + await firefox.session.installAddonFromPath(path.join(__dirname, '..')); session = firefox.session; browser = firefox.browser; http = newApp().listen(port); diff --git a/e2e/zoom.test.js b/e2e/zoom.test.js index bc89628..186f67f 100644 --- a/e2e/zoom.test.js +++ b/e2e/zoom.test.js @@ -6,20 +6,8 @@ const eventually = require('./eventually'); const Key = lanthan.Key; -const newApp = () => { - let app = express(); - app.get('/', (req, res) => { - res.send(`<!DOCTYPEhtml> -<html lang="en"> -</html">`); - }); - return app; -}; - describe("zoom test", () => { - const port = 12321; - let http; let firefox; let session; let browser; @@ -27,10 +15,8 @@ describe("zoom test", () => { let body; before(async() => { - http = newApp().listen(port); - firefox = await lanthan.firefox(); - await firefox.session.installAddon(path.join(__dirname, '..')); + await firefox.session.installAddonFromPath(path.join(__dirname, '..')); session = firefox.session; browser = firefox.browser; tab = (await browser.tabs.query({}))[0] @@ -40,11 +26,10 @@ describe("zoom test", () => { if (firefox) { await firefox.close(); } - http.close(); }); beforeEach(async() => { - await session.navigateTo(`http://127.0.0.1:${port}`); + await session.navigateTo('about:blank'); body = await session.findElementByCSS('body'); }); |