aboutsummaryrefslogtreecommitdiff
path: root/e2e/scroll.test.ts
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2019-09-22 16:13:12 +0900
committerShin'ya Ueoka <ueokande@i-beam.org>2019-09-22 16:13:12 +0900
commit7e77e31ad64c3649888eae337e0c984fd9c2ea2a (patch)
tree4d3e630f82712abce5afd7e498d514253464a6ea /e2e/scroll.test.ts
parent91f8383ecc2f7ef3f95173ad973a74f79e277a6c (diff)
Migrate e2e tests to TypeScript
Diffstat (limited to 'e2e/scroll.test.ts')
-rw-r--r--e2e/scroll.test.ts154
1 files changed, 154 insertions, 0 deletions
diff --git a/e2e/scroll.test.ts b/e2e/scroll.test.ts
new file mode 100644
index 0000000..63ac8a8
--- /dev/null
+++ b/e2e/scroll.test.ts
@@ -0,0 +1,154 @@
+import express from 'express';
+import * as path from 'path';
+import * as assert from 'assert';
+import * as http from 'http';
+
+import { Builder, Lanthan } from 'lanthan';
+import { WebDriver, WebElement, By, Key } from 'selenium-webdriver';
+
+const newApp = () => {
+ let app = express();
+ app.get('/', (_req, res) => {
+ res.send(`<!DOCTYPEhtml>
+<html lang="en">
+ <body style="width:10000px; height:10000px"></body>
+</html">`);
+ });
+ return app;
+};
+
+describe("scroll test", () => {
+ const port = 12321;
+ let http: http.Server;
+ let lanthan: Lanthan;
+ let webdriver: WebDriver;
+ let body: WebElement;
+
+ before(async() => {
+ http = newApp().listen(port);
+
+ lanthan = await Builder
+ .forBrowser('firefox')
+ .spyAddon(path.join(__dirname, '..'))
+ .build();
+ webdriver = lanthan.getWebDriver();
+ });
+
+ after(async() => {
+ if (lanthan) {
+ await lanthan.quit();
+ }
+ if (http) {
+ http.close();
+ }
+ });
+
+ beforeEach(async() => {
+ await webdriver.navigate().to(`http://127.0.0.1:${port}`);
+ body = await webdriver.findElement(By.css('body'));
+ });
+
+
+ it('scrolls up by k', async () => {
+ await body.sendKeys('j');
+
+ let pageYOffset = await webdriver.executeScript(() => window.pageYOffset) as number;
+ assert.equal(pageYOffset, 64);
+ });
+
+ it('scrolls down by j', async () => {
+ await webdriver.executeScript(() => window.scrollTo(0, 200));
+ await body.sendKeys('k');
+
+ let pageYOffset = await webdriver.executeScript(() => window.pageYOffset) as number;
+ assert.equal(pageYOffset, 136);
+ });
+
+ it('scrolls left by h', async () => {
+ await webdriver.executeScript(() => window.scrollTo(100, 100));
+ await body.sendKeys('h');
+
+ let pageXOffset = await webdriver.executeScript(() => window.pageXOffset) as number;
+ assert.equal(pageXOffset, 36);
+ });
+
+ it('scrolls left by l', async () => {
+ await webdriver.executeScript(() => window.scrollTo(100, 100));
+ await body.sendKeys('l');
+
+ let pageXOffset = await webdriver.executeScript(() => window.pageXOffset) as number;
+ assert.equal(pageXOffset, 164);
+ });
+
+ it('scrolls top by gg', async () => {
+ await webdriver.executeScript(() => window.scrollTo(0, 100));
+ await body.sendKeys('g', 'g');
+
+ let pageYOffset = await webdriver.executeScript(() => window.pageYOffset) as number;
+ assert.equal(pageYOffset, 0);
+ });
+
+ it('scrolls bottom by G', async () => {
+ await webdriver.executeScript(() => window.scrollTo(0, 100));
+ await body.sendKeys(Key.SHIFT, 'g');
+
+ let pageYOffset = await webdriver.executeScript(() => window.pageYOffset) as number;
+ assert.ok(pageYOffset > 5000);
+ });
+
+ it('scrolls bottom by 0', async () => {
+ await webdriver.executeScript(() => window.scrollTo(0, 100));
+ await body.sendKeys(Key.SHIFT, '0');
+
+ let pageXOffset = await webdriver.executeScript(() => window.pageXOffset) as number;
+ assert.ok(pageXOffset === 0);
+ });
+
+ it('scrolls bottom by $', async () => {
+ await webdriver.executeScript(() => window.scrollTo(0, 100));
+ await body.sendKeys(Key.SHIFT, '$');
+
+ let pageXOffset = await webdriver.executeScript(() => window.pageXOffset) as number;
+ assert.ok(pageXOffset > 5000);
+ });
+
+ it('scrolls bottom by <C-U>', async () => {
+ await webdriver.executeScript(() => window.scrollTo(0, 1000));
+ await body.sendKeys(Key.CONTROL, 'u');
+
+ let pageHeight =
+ await webdriver.executeScript(() => window.document.documentElement.clientHeight) as number;
+ let pageYOffset = await webdriver.executeScript(() => window.pageYOffset) as number;
+ assert.ok(Math.abs(pageYOffset - (1000 - Math.floor(pageHeight / 2))) < 5);
+ });
+
+ it('scrolls bottom by <C-D>', async () => {
+ await webdriver.executeScript(() => window.scrollTo(0, 1000));
+ await body.sendKeys(Key.CONTROL, 'd');
+
+ let pageHeight =
+ await webdriver.executeScript(() => window.document.documentElement.clientHeight) as number;
+ let pageYOffset = await webdriver.executeScript(() => window.pageYOffset) as number;
+ assert.ok(Math.abs(pageYOffset - (1000 + Math.floor(pageHeight / 2))) < 5);
+ });
+
+ it('scrolls bottom by <C-B>', async () => {
+ await webdriver.executeScript(() => window.scrollTo(0, 1000));
+ await body.sendKeys(Key.CONTROL, 'b');
+
+ let pageHeight =
+ await webdriver.executeScript(() => window.document.documentElement.clientHeight) as number;
+ let pageYOffset = await webdriver.executeScript(() => window.pageYOffset) as number;
+ assert.ok(Math.abs(pageYOffset - (1000 - pageHeight)) < 5);
+ });
+
+ it('scrolls bottom by <C-F>', async () => {
+ await webdriver.executeScript(() => window.scrollTo(0, 1000));
+ await body.sendKeys(Key.CONTROL, 'f');
+
+ let pageHeight =
+ await webdriver.executeScript(() => window.document.documentElement.clientHeight) as number;
+ let pageYOffset = await webdriver.executeScript(() => window.pageYOffset) as number;
+ assert.ok(Math.abs(pageYOffset - (1000 + pageHeight)) < 5);
+ });
+});