diff options
Diffstat (limited to 'e2e/clipboard.test.ts')
-rw-r--r-- | e2e/clipboard.test.ts | 50 |
1 files changed, 20 insertions, 30 deletions
diff --git a/e2e/clipboard.test.ts b/e2e/clipboard.test.ts index 5491e89..0fd45f7 100644 --- a/e2e/clipboard.test.ts +++ b/e2e/clipboard.test.ts @@ -1,8 +1,7 @@ -import express from 'express'; -import * as path from 'path'; import * as assert from 'assert'; -import * as http from 'http'; +import * as path from 'path'; +import TestServer from './lib/TestServer'; import eventually from './eventually'; import * as clipboard from './lib/clipboard'; import settings from './settings'; @@ -10,24 +9,13 @@ import { Builder, Lanthan } from 'lanthan'; import { WebDriver, Key } from 'selenium-webdriver'; import Page from './lib/Page'; -const newApp = () => { - let app = express(); - app.get('/', (_req, res) => { - res.status(200).send(`<html lang="en"></html">`); - }); - return app; -}; - describe("clipboard test", () => { - const port = 12321; - let http: http.Server; + let server = new TestServer(12321).receiveContent('/happy', 'ok'); let lanthan: Lanthan; let webdriver: WebDriver; let browser: any; before(async() => { - http = newApp().listen(port); - lanthan = await Builder .forBrowser('firefox') .spyAddon(path.join(__dirname, '..')) @@ -38,13 +26,15 @@ describe("clipboard test", () => { await browser.storage.local.set({ settings, }); + + await server.start(); }); after(async() => { + await server.stop(); if (lanthan) { await lanthan.quit(); } - http.close(); }); beforeEach(async() => { @@ -55,38 +45,38 @@ describe("clipboard test", () => { }) it('should copy current URL by y', async () => { - let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/#should_copy_url`); + let page = await Page.navigateTo(webdriver, server.url('/#should_copy_url')); await page.sendKeys('y'); await eventually(async() => { let data = await clipboard.read(); - assert.equal(data, `http://127.0.0.1:${port}/#should_copy_url`); + assert.equal(data, server.url('/#should_copy_url')); }); }); it('should open an URL from clipboard by p', async () => { - await clipboard.write(`http://127.0.0.1:${port}/#open_from_clipboard`); + await clipboard.write(server.url('/#open_from_clipboard')); - let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/`); + let page = await Page.navigateTo(webdriver, server.url()); await page.sendKeys('p'); await eventually(async() => { let tabs = await browser.tabs.query({ active: true }); - assert.equal(tabs[0].url, `http://127.0.0.1:${port}/#open_from_clipboard`); + assert.equal(tabs[0].url, server.url('/#open_from_clipboard')); }); }); it('should open an URL from clipboard to new tab by P', async () => { - await clipboard.write(`http://127.0.0.1:${port}/#open_to_new_tab`); + await clipboard.write(server.url('/#open_to_new_tab')); - let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/`); + let page = await Page.navigateTo(webdriver, server.url()); await page.sendKeys(Key.SHIFT, 'p'); await eventually(async() => { let tabs = await browser.tabs.query({}); assert.deepEqual(tabs.map((t: any) => t.url), [ - `http://127.0.0.1:${port}/`, - `http://127.0.0.1:${port}/#open_to_new_tab`, + server.url(), + server.url('/#open_to_new_tab'), ]); }); }); @@ -94,26 +84,26 @@ describe("clipboard test", () => { it('should open search result with keywords in clipboard by p', async () => { await clipboard.write(`an apple`); - let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/`); + let page = await Page.navigateTo(webdriver, server.url()); await page.sendKeys(Key.SHIFT, 'p'); await eventually(async() => { let tabs = await browser.tabs.query({ active: true }); - assert.equal(tabs[0].url, `http://127.0.0.1:${port}/google?q=an%20apple`); + assert.equal(tabs[0].url, server.url('/google?q=an%20apple')); }); }); it('should open search result with keywords in clipboard to new tabby P', async () => { await clipboard.write(`an apple`); - let page = await Page.navigateTo(webdriver, `http://127.0.0.1:${port}/`); + let page = await Page.navigateTo(webdriver, server.url()); await page.sendKeys(Key.SHIFT, 'p'); await eventually(async() => { let tabs = await browser.tabs.query({}); assert.deepEqual(tabs.map((t: any) => t.url), [ - `http://127.0.0.1:${port}/`, - `http://127.0.0.1:${port}/google?q=an%20apple`, + server.url(), + server.url('/google?q=an%20apple'), ]); }); }); |