diff --git a/QA.md b/QA.md index 1e71bf6..c0b4757 100644 --- a/QA.md +++ b/QA.md @@ -8,12 +8,6 @@ Test operations with default key maps. The behaviors of the console are tested in [Console section](#consoles). -- [ ] :: open empty console -- [ ] o, t, w: open a console with `open`, `tabopen`, `winopen` -- [ ] O, T, W: open a console with `open`, `tabopen`, `winopen` and current URL -- [ ] b: open a console with `buffer` -- [ ] a: open a console with `addbookmark` and the current page's title - #### Misc - [ ] y: yank current URL and show a message diff --git a/e2e/console.test.js b/e2e/console.test.js new file mode 100644 index 0000000..a7c6c63 --- /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(` + + + Hello, world! + +`); + }); + return app; +}; + + +describe("zoom 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.installAddon(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/zoom.test.js b/e2e/zoom.test.js index bc89628..e8e586e 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(` - -`); - }); - return app; -}; - describe("zoom test", () => { - const port = 12321; - let http; let firefox; let session; let browser; @@ -27,8 +15,6 @@ describe("zoom test", () => { let body; before(async() => { - http = newApp().listen(port); - firefox = await lanthan.firefox(); await firefox.session.installAddon(path.join(__dirname, '..')); session = firefox.session; @@ -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'); });