diff options
author | Shin'ya Ueoka <ueokande@i-beam.org> | 2018-05-13 18:41:35 +0900 |
---|---|---|
committer | Shin'ya Ueoka <ueokande@i-beam.org> | 2018-05-13 21:16:26 +0900 |
commit | 2801b953de8fc1059d655a689303e21de609a6c8 (patch) | |
tree | 16db2bbe0d67186714c8fd4e0b9672dd32e4a3fa | |
parent | a6c0eb06e9bdb8df32ae1ef8c7bae0adf076ba1f (diff) |
Add e2e test cases for following
-rw-r--r-- | QA.md | 4 | ||||
-rw-r--r-- | e2e/contents/follow.test.js | 121 | ||||
-rw-r--r-- | e2e/web-server/index.js | 11 |
3 files changed, 132 insertions, 4 deletions
@@ -34,10 +34,6 @@ The behaviors of the console are tested in [Console section](#consoles). ### Following links -- [ ] <kbd>f</kbd>: start following links -- [ ] <kbd>F</kbd>: start following links and open in new tab -- [ ] open link with target='_blank' in new tab by <kbd>f</kbd> -- [ ] open link with target='_blank' in new tab by <kbd>F</kbd> - [ ] Show hints on following on a page containing `<frame>`/`<iframe>` - [ ] Show hints only inside viewport of the frame on following on a page containing `<frame>`/`<iframe>` - [ ] Show hints only inside top window on following on a page containing `<frame>`/`<iframe>` diff --git a/e2e/contents/follow.test.js b/e2e/contents/follow.test.js new file mode 100644 index 0000000..f852dc0 --- /dev/null +++ b/e2e/contents/follow.test.js @@ -0,0 +1,121 @@ +import * as windows from "../ambassador/src/client/windows"; +import * as tabs from "../ambassador/src/client/tabs"; +import * as keys from "../ambassador/src/client/keys"; +import { CLIENT_URL } from '../web-server/url'; + +describe("tab test", () => { + let targetWindow; + + beforeEach(() => { + return windows.create(CLIENT_URL).then((win) => { + targetWindow = win; + }); + }); + + afterEach(() => { + return windows.remove(targetWindow.id); + }); + + it('follows link by `f`', () => { + let targetTab; + return tabs.create(targetWindow.id, CLIENT_URL + '/follow').then((tab) => { + targetTab = tab; + return keys.press(targetTab.id, 'f'); + }).then(() => { + return new Promise(resolve => { setTimeout(() => resolve(), 10) }); + }).then(() => { + return keys.press(targetTab.id, 'a'); + }).then(() => { + return new Promise(resolve => { setTimeout(() => resolve(), 10) }); + }).then(() => { + return tabs.get(targetTab.id); + }).then((tab) => { + expect(tab.url).to.be.equal(CLIENT_URL + '/follow#a'); + }); + }); + + it('follows link into new tab by `F`', () => { + let targetTab; + return tabs.create(targetWindow.id, CLIENT_URL + '/follow').then((tab) => { + targetTab = tab; + return keys.press(targetTab.id, 'F', { shiftKey: true }); + }).then(() => { + return new Promise(resolve => { setTimeout(() => resolve(), 10) }); + }).then(() => { + return keys.press(targetTab.id, 'a'); + }).then(() => { + return new Promise(resolve => { setTimeout(() => resolve(), 500) }); + }).then(() => { + return windows.get(targetWindow.id); + }).then((win) => { + let urls = win.tabs.map(t => t.url); + expect(urls).to.have.lengthOf(3); + expect(urls).to.include(CLIENT_URL + '/'); + expect(urls).to.include(CLIENT_URL + '/follow'); + expect(urls).to.include(CLIENT_URL + '/follow#a'); + }); + }); + + it('follows link with target=_blank into new tab by `f`', () => { + let targetTab; + return tabs.create(targetWindow.id, CLIENT_URL + '/follow').then((tab) => { + targetTab = tab; + return keys.press(targetTab.id, 'f'); + }).then(() => { + return new Promise(resolve => { setTimeout(() => resolve(), 10) }); + }).then(() => { + return keys.press(targetTab.id, 'b'); + }).then(() => { + return new Promise(resolve => { setTimeout(() => resolve(), 500) }); + }).then(() => { + return windows.get(targetWindow.id); + }).then((win) => { + let urls = win.tabs.map(t => t.url); + expect(urls).to.have.lengthOf(3); + expect(urls).to.include(CLIENT_URL + '/'); + expect(urls).to.include(CLIENT_URL + '/follow'); + expect(urls).to.include(CLIENT_URL + '/follow#external'); + }); + }); + + it('follows link with target=_blank into new tab by `F`', () => { + let targetTab; + return tabs.create(targetWindow.id, CLIENT_URL + '/follow').then((tab) => { + targetTab = tab; + return keys.press(targetTab.id, 'F', { shiftKey: true }); + }).then(() => { + }).then(() => { + return new Promise(resolve => { setTimeout(() => resolve(), 10) }); + }).then(() => { + return keys.press(targetTab.id, 'b'); + }).then(() => { + return new Promise(resolve => { setTimeout(() => resolve(), 500) }); + }).then(() => { + return windows.get(targetWindow.id); + }).then((win) => { + let urls = win.tabs.map(t => t.url); + expect(urls).to.have.lengthOf(3); + expect(urls).to.include(CLIENT_URL + '/'); + expect(urls).to.include(CLIENT_URL + '/follow'); + expect(urls).to.include(CLIENT_URL + '/follow#external'); + }); + }); + + it('follows area by `F`', () => { + let targetTab; + return tabs.create(targetWindow.id, CLIENT_URL + '/follow').then((tab) => { + targetTab = tab; + return keys.press(targetTab.id, 'f'); + }).then(() => { + return new Promise(resolve => { setTimeout(() => resolve(), 10) }); + }).then(() => { + return keys.press(targetTab.id, 'c'); + }).then(() => { + return new Promise(resolve => { setTimeout(() => resolve(), 10) }); + }).then(() => { + return tabs.get(targetTab.id); + }).then((tab) => { + expect(tab.url).to.be.equal(CLIENT_URL + '/follow#area'); + }); + }); +}); diff --git a/e2e/web-server/index.js b/e2e/web-server/index.js index cbeee15..bf60078 100644 --- a/e2e/web-server/index.js +++ b/e2e/web-server/index.js @@ -51,6 +51,15 @@ const handleLinkPagenation = (req, res) => { res.end('<!DOCTYPEhtml><html lang="en"><head>' + head + '</head><body"></body></html">'); }; +const handleFollow = (req, res) => { + let body = ''; + body += '<a href="#a">a</a>'; + body += '<a href="#external" target="_blank">external</a>'; + body += '<img width="320" height="240" src="data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs=" usemap="#map"><map name="map"><area href="#area" shape="rect" coords="15,19,126,104"></map>' + + res.writeHead(200, {'Content-Type': 'text/html'}); + res.end('<!DOCTYPEhtml><html lang="en"><body">' + body + '</body></html">'); +} const handle404 = (req, res) => { res.writeHead(404, {'Content-Type': 'text/plain'}); @@ -69,6 +78,8 @@ http.createServer(function (req, res) { handleAPagenation(req, res); } else if (u.pathname === '/link-pagenation') { handleLinkPagenation(req, res); + } else if (u.pathname === '/follow') { + handleFollow(req, res); } else { handle404(req, res); } |