diff options
author | Shin'ya Ueoka <ueokande@i-beam.org> | 2019-04-16 21:56:17 +0900 |
---|---|---|
committer | Shin'ya Ueoka <ueokande@i-beam.org> | 2019-04-16 21:58:10 +0900 |
commit | 9f7150e96b7b228429f9f893657f4647e5a8cb51 (patch) | |
tree | 0167cef7040fd31aa4064a326995a0987a22485b /e2e/completion.test.js | |
parent | afdd9562e40c941d6cfbb9bb0a1bef7cf9a3b671 (diff) |
Add e2e tests for completions
Diffstat (limited to 'e2e/completion.test.js')
-rw-r--r-- | e2e/completion.test.js | 136 |
1 files changed, 136 insertions, 0 deletions
diff --git a/e2e/completion.test.js b/e2e/completion.test.js new file mode 100644 index 0000000..5d910c6 --- /dev/null +++ b/e2e/completion.test.js @@ -0,0 +1,136 @@ +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 Console = require('./lib/Console'); + +const Key = lanthan.Key; + +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", () => { + 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 all commands on empty line', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let c = new Console(session); + + await eventually(async() => { + let items = await c.getCompletions(); + assert.equal(items.length, 10); + assert.deepEqual(items[0], { type: 'title', text: 'Console Command' }); + assert(items[1].text.startsWith('set')) + assert(items[2].text.startsWith('open')) + assert(items[3].text.startsWith('tabopen')) + }); + }); + + it('should only commands filtered by prefix', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let c = new Console(session); + await c.sendKeys('b'); + + await eventually(async() => { + let items = await c.getCompletions(); + assert.equal(items.length, 4); + assert.deepEqual(items[0], { type: 'title', text: 'Console Command' }); + assert(items[1].text.startsWith('buffer')) + assert(items[2].text.startsWith('bdelete')) + assert(items[3].text.startsWith('bdeletes')) + }); + }); + + it('selects completion items by <Tab>/<S-Tab> keys', async() => { + await body.sendKeys(':'); + + await session.switchToFrame(0); + let c = new Console(session); + await c.sendKeys('b'); + + await eventually(async() => { + let items = await c.getCompletions(); + assert.equal(items.length, 4); + }); + + await c.sendKeys(Key.Tab); + await eventually(async() => { + let items = await c.getCompletions(); + assert(items[1].highlight) + + let v = await c.currentValue(); + assert.equal(v, 'buffer'); + }); + + await c.sendKeys(Key.Tab, Key.Tab); + await eventually(async() => { + let items = await c.getCompletions(); + assert(items[3].highlight) + + let v = await c.currentValue(); + assert.equal(v, 'bdeletes'); + }); + + await c.sendKeys(Key.Tab); + await eventually(async() => { + let v = await c.currentValue(); + assert.equal(v, 'b'); + }); + + await c.sendKeys(Key.Shift, Key.Tab); + await eventually(async() => { + let items = await c.getCompletions(); + assert(items[3].highlight) + + let v = await c.currentValue(); + assert.equal(v, 'bdeletes'); + }); + }); +}); |