diff options
author | Shin'ya Ueoka <ueokande@i-beam.org> | 2020-02-22 22:03:58 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-02-22 22:03:58 +0900 |
commit | 4c3be5b014fe61a608b4f4aa69e40e3575d63b68 (patch) | |
tree | e061c016ffc8efabccd647b4ab9ef07fe77c6434 /e2e | |
parent | 78c87e895e6ac50b6c6d83d4cc77bfd8017e5384 (diff) | |
parent | 2f0cea1debd2b37b51e31adb8bf16d914655171a (diff) |
Merge pull request #714 from ueokande/qa-0.27
QA 0.27
Diffstat (limited to 'e2e')
-rw-r--r-- | e2e/find.test.ts | 113 | ||||
-rw-r--r-- | e2e/lib/Console.ts | 5 | ||||
-rw-r--r-- | e2e/lib/Page.ts | 18 |
3 files changed, 136 insertions, 0 deletions
diff --git a/e2e/find.test.ts b/e2e/find.test.ts new file mode 100644 index 0000000..74097ab --- /dev/null +++ b/e2e/find.test.ts @@ -0,0 +1,113 @@ +import * as path from 'path'; +import * as assert from 'assert'; + +import eventually from './eventually'; +import TestServer from './lib/TestServer'; +import { Builder, Lanthan } from 'lanthan'; +import { Key, WebDriver } from 'selenium-webdriver'; +import Page from './lib/Page'; + +describe("find test", () => { + const server = new TestServer().receiveContent('/', + `<!DOCTYPE html><html lang="en"><body>--hello--hello--hello--</body></html>`, + ); + let lanthan: Lanthan; + let webdriver: WebDriver; + let page: Page; + + before(async() => { + lanthan = await Builder + .forBrowser('firefox') + .spyAddon(path.join(__dirname, '..')) + .build(); + webdriver = lanthan.getWebDriver(); + await server.start(); + }); + + after(async() => { + await server.stop(); + if (lanthan) { + await lanthan.quit(); + } + }); + + beforeEach(async() => { + page = await Page.navigateTo(webdriver, server.url()); + }); + + it('starts searching', async() => { + await page.sendKeys('/'); + const console = await page.getConsole(); + await console.execCommand("hello"); + await page.switchToTop(); + + let selection = await page.getSelection(); + assert.deepStrictEqual(selection, { from: 2, to: 7 }); + + // search next keyword + await page.sendKeys("n"); + selection = await page.getSelection(); + assert.deepStrictEqual(selection, { from: 9, to: 14 }); + + // search previous keyword + await page.sendKeys(Key.SHIFT, "N"); + selection = await page.getSelection(); + assert.deepStrictEqual(selection, { from: 2, to: 7 }); + + // search previous keyword by wrap-search + await page.sendKeys(Key.SHIFT, "N"); + selection = await page.getSelection(); + assert.deepStrictEqual(selection, { from: 16, to: 21 }); + }); + + it('shows error if pattern not found', async() => { + await page.sendKeys('/'); + let console = await page.getConsole(); + await console.execCommand('world'); + + await page.switchToTop(); + const selection = await page.getSelection(); + assert.deepStrictEqual(selection, { from: 0, to: 0 }); + + await eventually(async() => { + console = await page.getConsole(); + const message = await console.getErrorMessage(); + assert.strictEqual(message, 'Pattern not found: world'); + }); + }); + + it('search with last keyword if keyword is empty', async() => { + await page.sendKeys('/'); + let console = await page.getConsole(); + await console.execCommand('hello'); + await page.switchToTop(); + + await page.clearSelection(); + let selection = await page.getSelection(); + assert.deepStrictEqual(selection, { from: 0, to: 0 }); + + await page.sendKeys('/'); + console = await page.getConsole(); + await console.execCommand(''); + await page.switchToTop(); + + selection = await page.getSelection(); + assert.deepStrictEqual(selection, { from: 2, to: 7 }); + }); + + it('search with last keyword on new page', async() => { + await page.sendKeys('/'); + const console = await page.getConsole(); + await console.execCommand('hello'); + + await page.switchToTop(); + await page.sendKeys('n'); + let selection = await page.getSelection(); + assert.deepStrictEqual(selection, { from: 9, to: 14 }); + + page = await Page.navigateTo(webdriver, server.url()); + await page.sendKeys('n'); + selection = await page.getSelection(); + assert.deepStrictEqual(selection, { from: 2, to: 7 }); + }); +}); diff --git a/e2e/lib/Console.ts b/e2e/lib/Console.ts index 6a82387..e3bd2d6 100644 --- a/e2e/lib/Console.ts +++ b/e2e/lib/Console.ts @@ -35,6 +35,11 @@ export class Console { return p.getText(); } + async getInformationMessage(): Promise<string> { + const p = await this.webdriver.findElement(By.css('.vimvixen-console-info')); + return p.getText(); + } + async inputKeys(...keys: string[]) { const input = await this.webdriver.findElement(By.css('input')); await input.sendKeys(...keys); diff --git a/e2e/lib/Page.ts b/e2e/lib/Page.ts index ad3f454..31605cb 100644 --- a/e2e/lib/Page.ts +++ b/e2e/lib/Page.ts @@ -6,6 +6,11 @@ type Hint = { text: string, }; +type Selection = { + from: number, + to: number, +}; + export default class Page { private constructor(private webdriver: WebDriver) { } @@ -66,6 +71,19 @@ export default class Page { return this.webdriver.executeScript(() => window.document.documentElement.clientHeight); } + async getSelection(): Promise<Selection> { + const obj = await this.webdriver.executeScript(`return window.getSelection();`) as any; + return { from: obj.anchorOffset, to: obj.focusOffset }; + } + + async clearSelection(): Promise<void> { + await this.webdriver.executeScript(`window.getSelection().removeAllRanges()`); + } + + async switchToTop(): Promise<void> { + await this.webdriver.switchTo().defaultContent(); + } + async waitAndGetHints(): Promise<Hint[]> { await this.webdriver.wait(until.elementsLocated(By.css('.vimvixen-hint'))); |