diff options
Diffstat (limited to 'e2e/navigate.test.ts')
-rw-r--r-- | e2e/navigate.test.ts | 254 |
1 files changed, 254 insertions, 0 deletions
diff --git a/e2e/navigate.test.ts b/e2e/navigate.test.ts new file mode 100644 index 0000000..8ee209b --- /dev/null +++ b/e2e/navigate.test.ts @@ -0,0 +1,254 @@ +import * as path from 'path'; +import * as assert from 'assert'; + +import TestServer from './lib/TestServer'; +import eventually from './eventually'; +import { Builder, Lanthan } from 'lanthan'; +import { WebDriver, Key } from 'selenium-webdriver'; +import { Options as FirefoxOptions } from 'selenium-webdriver/firefox'; +import Page from './lib/Page'; + +const newApp = () => { + let server = new TestServer(); + server.handle('/pagenation-a/:page', (req, res) => { + res.status(200).send(` + <!DOCTYPE html> + <html lang="en"> + <a href="/pagenation-a/${Number(req.params.page) - 1}">prev</a> + <a href="/pagenation-a/${Number(req.params.page) + 1}">next</a> + </html">`); + }); + + server.handle('/pagenation-link/:page', (req, res) => { + res.status(200).send(` + <!DOCTYPE html> + <html lang="en"> + <head> + <link rel="prev" href="/pagenation-link/${Number(req.params.page) - 1}"></link> + <link rel="next" href="/pagenation-link/${Number(req.params.page) + 1}"></link> + </head> + </html">`); + }); + server.receiveContent('/reload', ` + <!DOCTYPE html> + <html lang="en"> + <head> + <script>window.location.hash = Date.now()</script> + </head> + <body style="width:10000px; height:10000px"></body> + </html">`); + + server.receiveContent('/*', `ok`); + + return server; +}; + +describe("navigate test", () => { + let server = newApp(); + let lanthan: Lanthan; + let webdriver: WebDriver; + let browser: any; + + before(async() => { + await server.start(); + + let opts = (new FirefoxOptions() as any) + .setPreference('browser.startup.homepage', server.url('/#home')); + lanthan = await Builder + .forBrowser('firefox') + .setOptions(opts) + .spyAddon(path.join(__dirname, '..')) + .build(); + webdriver = lanthan.getWebDriver(); + browser = lanthan.getWebExtBrowser(); + }); + + after(async() => { + await server.stop(); + if (lanthan) { + await lanthan.quit(); + } + }); + + 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 () => { + let page = await Page.navigateTo(webdriver, server.url('/a/b/c')); + await page.sendKeys('g', 'u'); + + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.strictEqual(url.pathname, `/a/b/`) + }); + }); + + it('should remove hash by gu', async () => { + let page = await Page.navigateTo(webdriver, server.url('/a/b/c#hash')); + await page.sendKeys('g', 'u'); + + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.strictEqual(url.hash, '') + assert.strictEqual(url.pathname, `/a/b/c`) + }); + }); + + it('should go to root path by gU', async () => { + let page = await Page.navigateTo(webdriver, server.url('/a/b/c#hash')); + await page.sendKeys('g', Key.SHIFT, 'u'); + + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.strictEqual(url.pathname, `/`) + }); + }); + + it('should go back and forward in history by H and L', async () => { + let page = await Page.navigateTo(webdriver, server.url('/first')); + await page.navigateTo(server.url('/second')); + await page.sendKeys(Key.SHIFT, 'h'); + + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.strictEqual(url.pathname, `/first`) + }); + + page = await Page.currentContext(webdriver); + page.sendKeys(Key.SHIFT, 'l'); + + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.strictEqual(url.pathname, `/second`) + }); + }); + + it('should go previous and next page in <a> by [[ and ]]', async () => { + let page = await Page.navigateTo(webdriver, server.url('/pagenation-a/10')); + await page.sendKeys('[', '['); + + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.strictEqual(url.pathname, '/pagenation-a/9'); + }); + }); + + it('should go next page in <a> by ]]', async () => { + let page = await Page.navigateTo(webdriver, server.url('/pagenation-a/10')); + await page.sendKeys(']', ']'); + + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.strictEqual(url.pathname, '/pagenation-a/11'); + }); + }); + + it('should go previous page in <link> by ]]', async () => { + let page = await Page.navigateTo(webdriver, server.url('/pagenation-link/10')); + await page.sendKeys('[', '['); + + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.strictEqual(url.pathname, '/pagenation-link/9'); + }); + }); + + it('should go next page by in <link> by [[', async () => { + let page = await Page.navigateTo(webdriver, server.url('/pagenation-link/10')); + await page.sendKeys(']', ']'); + + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.strictEqual(url.pathname, '/pagenation-link/11'); + }); + }); + + it('should go to home page into current tab by gh', async () => { + let page = await Page.navigateTo(webdriver, server.url()); + await page.sendKeys('g', 'h'); + + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + let url = new URL(tab.url); + assert.strictEqual(url.hash, '#home'); + }); + }); + + it('should go to home page into current tab by gH', async () => { + let page = await Page.navigateTo(webdriver, server.url()); + await page.sendKeys('g', Key.SHIFT, 'H'); + + await eventually(async() => { + let tabs = await browser.tabs.query({}); + assert.strictEqual(tabs.length, 2); + assert.strictEqual(new URL(tabs[0].url).hash, ''); + assert.strictEqual(new URL(tabs[1].url).hash, '#home'); + assert.strictEqual(tabs[1].active, true); + }); + }); + + it('should reload current tab by r', async () => { + let page = await Page.navigateTo(webdriver, server.url('/reload')); + await page.scrollTo(500, 500); + + let before: number; + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + before = Number(new URL(tab.url).hash.split('#')[1]); + assert.ok(before > 0); + }); + + await page.sendKeys('r'); + + let after + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + after = Number(new URL(tab.url).hash.split('#')[1]); + assert.ok(after > before); + }); + + await eventually(async() => { + let page = await Page.currentContext(webdriver); + assert.strictEqual(await page.getScrollX(), 500); + }); + }); + + it('should reload current tab without cache by R', async () => { + let page = await Page.navigateTo(webdriver, server.url('/reload')); + await page.scrollTo(500, 500); + + let before: number; + await eventually(async() => { + let tab = (await browser.tabs.query({}))[0]; + before = Number(new URL(tab.url).hash.split('#')[1]); + assert.ok(before > 0); + }); + + await page.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.ok(after > before); + }); + + await eventually(async() => { + let page = await Page.currentContext(webdriver); + assert.strictEqual(await page.getScrollY(), 0); + }); + }); +}); |