aboutsummaryrefslogtreecommitdiff
path: root/e2e/options.test.ts
blob: 91a3ddea37043f8c73b3ee45841354cceedd0be0 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
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 } from 'selenium-webdriver';
import Page from './lib/Page';
import OptionPage from './lib/OptionPage';

describe("options page", () => {
  const server = new TestServer().receiveContent('/',
    `<!DOCTYPE html><html lang="en"><body style="width:10000px; height:10000px"></body></html>`,
  );
  let lanthan: Lanthan;
  let webdriver: WebDriver;
  let browser: any;

  before(async() => {
    lanthan = await Builder
      .forBrowser('firefox')
      .spyAddon(path.join(__dirname, '..'))
      .build();
    webdriver = lanthan.getWebDriver();
    browser = lanthan.getWebExtBrowser();

    await server.start();
  });

  after(async() => {
    if (lanthan) {
      await lanthan.quit();
    }
    await server.stop();
  });

  beforeEach(async() => {
    const tabs = await browser.tabs.query({});
    for (const tab of tabs.slice(1)) {
      await browser.tabs.remove(tab.id);
    }
  });

  it('saves current config on blur', async () => {
    const page = await OptionPage.open(lanthan);
    const jsonPage = await page.asJSONOptionPage();
    await jsonPage.updateSettings(`{ "blacklist": [ "https://example.com" ] }`);

    let { settings } = await browser.storage.local.get('settings');
    assert.strictEqual(settings.source, 'json');
    assert.strictEqual(settings.json, '{ "blacklist": [ "https://example.com" ] } ');

    await jsonPage.updateSettings(`invalid json`);

    settings = (await browser.storage.local.get('settings')).settings;
    assert.strictEqual(settings.source, 'json');
    assert.strictEqual(settings.json, '{ "blacklist": [ "https://example.com" ] } ');

    const message = await jsonPage.getErrorMessage();
    assert.ok(message.startsWith('SyntaxError:'))
  });

  it('updates keymaps without reloading', async () => {
    const optionPage = await OptionPage.open(lanthan);
    const jsonPage = await optionPage.asJSONOptionPage();
    await jsonPage.updateSettings(`{ "keymaps": { "zz": { "type": "scroll.vertically", "count": 10 } } }`);

    await browser.tabs.create({ url: server.url(), active: false });
    await new Promise((resolve) => setTimeout(resolve, 100));
    const handles = await webdriver.getAllWindowHandles();
    await webdriver.switchTo().window(handles[1]);

    const page = await Page.currentContext(webdriver);
    await page.sendKeys('zz');

    await eventually(async() => {
      const y = await page.getScrollY();
      assert.strictEqual(y, 640);
    });
  })
});