Skip to content

Commit

Permalink
Improve e2e
Browse files Browse the repository at this point in the history
  • Loading branch information
inokawa committed Feb 5, 2024
1 parent 45c127d commit 5a37173
Show file tree
Hide file tree
Showing 3 changed files with 118 additions and 117 deletions.
204 changes: 100 additions & 104 deletions e2e/WindowVirtualizer.spec.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { test, expect, Page } from "@playwright/test";
import { test, expect } from "@playwright/test";
import {
storyUrl,
getFirstItem,
Expand All @@ -7,6 +7,10 @@ import {
getFirstItemRtl,
windowScrollToLeft,
getVirtualizer,
getWindowScrollTop,
getWindowScrollLeft,
getWindowScrollBottom,
getWindowScrollRight,
} from "./utils";

test.describe("smoke", () => {
Expand Down Expand Up @@ -84,109 +88,101 @@ test.describe("smoke", () => {
});
});

// test.describe("check if scroll jump compensation works", () => {
// test("vertical start -> end", async ({ page }) => {
// await page.goto(storyUrl("basics-windowvirtualizer--default"));
// const component = await getVirtualizer(page);
// await component.waitForElementState("stable");

// // check if start is displayed
// await expect((await getFirstItem(component)).text).toEqual("0");

// // check if offset from start is always keeped
// await component.click();
// const min = 200;
// const initial = await component.evaluate((e) => window.scrollY);
// let prev = initial;
// for (let i = 0; i < 500; i++) {
// await page.keyboard.press("ArrowDown", { delay: 10 });
// const offset = await component.evaluate((e) => window.scrollY);
// await expect(offset).toBeGreaterThanOrEqual(prev);
// prev = offset;
// }
// await expect(prev).toBeGreaterThan(initial + min);
// });

// test("vertical end -> start", async ({ page }) => {
// await page.goto(storyUrl("basics-windowvirtualizer--default"));
// const component = await getVirtualizer(page);
// await component.waitForElementState("stable");

// // check if start is displayed
// await expect((await getFirstItem(component)).text).toEqual("0");

// // scroll to the end
// await windowScrollToBottom(component);

// // check if offset from end is always keeped
// await component.click();
// const min = 200;
// const initial = await component.evaluate(
// (e) => document.body.scrollHeight - window.scrollY
// );
// let prev = initial;
// for (let i = 0; i < 500; i++) {
// await page.keyboard.press("ArrowUp", { delay: 10 });
// const offset = await component.evaluate(
// (e) => document.body.scrollHeight - window.scrollY
// );
// await expect(offset).toBeGreaterThanOrEqual(prev);
// prev = offset;
// }
// await expect(prev).toBeGreaterThan(initial + min);
// });

// test("horizontal start -> end", async ({ page }) => {
// await page.goto(storyUrl("basics-windowvirtualizer--horizontal"));
// const component = await getVirtualizer(page);
// await component.waitForElementState("stable");

// // check if start is displayed
// await expect((await getFirstItem(component)).text).toEqual("Column 0");

// // check if offset from start is always keeped
// await component.click();
// const min = 200;
// const initial = await component.evaluate((e) => window.scrollX);
// let prev = initial;
// for (let i = 0; i < 500; i++) {
// await page.keyboard.press("ArrowRight", { delay: 10 });
// const offset = await component.evaluate((e) => window.scrollX);
// await expect(offset).toBeGreaterThanOrEqual(prev);
// prev = offset;
// }
// await expect(prev).toBeGreaterThan(initial + min);
// });

// test("horizontal end -> start", async ({ page }) => {
// await page.goto(storyUrl("basics-windowvirtualizer--horizontal"));
// const component = await getVirtualizer(page);
// await component.waitForElementState("stable");

// // check if start is displayed
// await expect((await getFirstItem(component)).text).toEqual("Column 0");

// // scroll to the end
// await windowScrollToRight(component);

// // check if offset from end is always keeped
// await component.click();
// const min = 200;
// const initial = await component.evaluate(
// (e) => document.body.scrollWidth - window.scrollX
// );
// let prev = initial;
// for (let i = 0; i < 500; i++) {
// await page.keyboard.press("ArrowLeft", { delay: 10 });
// const offset = await component.evaluate(
// (e) => document.body.scrollWidth - window.scrollX
// );
// await expect(offset).toBeGreaterThanOrEqual(prev);
// prev = offset;
// }
// await expect(prev).toBeGreaterThan(initial + min);
// });
// });
test.describe("check if scroll jump compensation works", () => {
test("vertical start -> end", async ({ page }) => {
await page.goto(storyUrl("basics-windowvirtualizer--default"));
const component = await getVirtualizer(page);
await component.waitForElementState("stable");

// check if start is displayed
await expect((await getFirstItem(component)).text).toEqual("0");

// check if offset from start is always keeped
await component.click();
const min = 200;
const initial = await getWindowScrollTop(page);
let prev = initial;
for (let i = 0; i < 500; i++) {
await page.keyboard.press("ArrowDown", { delay: 10 });
const offset = await getWindowScrollTop(page);
await expect(offset).toBeGreaterThanOrEqual(prev);
prev = offset;
}
await expect(prev).toBeGreaterThan(initial + min);
});

test("vertical end -> start", async ({ page }) => {
await page.goto(storyUrl("basics-windowvirtualizer--default"));
const component = await getVirtualizer(page);
await component.waitForElementState("stable");

// check if start is displayed
await expect((await getFirstItem(component)).text).toEqual("0");

// scroll to the end
await windowScrollToBottom(component);

// check if offset from end is always keeped
await component.click();
const min = 200;
const initial = await getWindowScrollBottom(page);
let prev = initial;
for (let i = 0; i < 500; i++) {
await page.keyboard.press("ArrowUp", { delay: 10 });
const offset = await getWindowScrollBottom(page);
await expect(offset).toBeGreaterThanOrEqual(prev);
prev = offset;
}
await expect(prev).toBeGreaterThan(initial + min);
});

test("horizontal start -> end", async ({ page }) => {
await page.goto(storyUrl("basics-windowvirtualizer--horizontal"));
const component = await getVirtualizer(page);
await component.waitForElementState("stable");

// check if start is displayed
await expect((await getFirstItem(component)).text).toEqual("Column 0");

// check if offset from start is always keeped
await component.click();
const min = 200;
const initial = await getWindowScrollLeft(page);
let prev = initial;
for (let i = 0; i < 500; i++) {
await page.keyboard.press("ArrowRight", { delay: 10 });
const offset = await getWindowScrollLeft(page);
await expect(offset).toBeGreaterThanOrEqual(prev);
prev = offset;
}
await expect(prev).toBeGreaterThan(initial + min);
});

test("horizontal end -> start", async ({ page }) => {
await page.goto(storyUrl("basics-windowvirtualizer--horizontal"));
const component = await getVirtualizer(page);
await component.waitForElementState("stable");

// check if start is displayed
await expect((await getFirstItem(component)).text).toEqual("Column 0");

// scroll to the end
await windowScrollToRight(component);

// check if offset from end is always keeped
await component.click();
const min = 200;
const initial = await getWindowScrollRight(page);
let prev = initial;
for (let i = 0; i < 500; i++) {
await page.keyboard.press("ArrowLeft", { delay: 10 });
const offset = await getWindowScrollRight(page);
await expect(offset).toBeGreaterThanOrEqual(prev);
prev = offset;
}
await expect(prev).toBeGreaterThan(initial + min);
});
});

test.describe("RTL", () => {
test("vertically scrollable", async ({ page }) => {
Expand Down
16 changes: 16 additions & 0 deletions e2e/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,22 @@ export const getScrollRight = (
return scrollable.evaluate((e) => e.scrollWidth - e.scrollLeft);
};

export const getWindowScrollTop = (page: Page) => {
return page.evaluate(() => window.scrollY);
};

export const getWindowScrollBottom = (page: Page) => {
return page.evaluate(() => document.body.scrollHeight - window.scrollY);
};

export const getWindowScrollLeft = (page: Page) => {
return page.evaluate(() => window.scrollX);
};

export const getWindowScrollRight = (page: Page) => {
return page.evaluate(() => document.body.scrollWidth - window.scrollX);
};

export const scrollBy = (
scrollable: ElementHandle<HTMLElement | SVGElement>,
offset: number
Expand Down
15 changes: 2 additions & 13 deletions stories/react/basics/WindowVirtualizer.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -323,22 +323,11 @@ export const IncreasingItems: StoryObj = {
<div>
<label style={{ marginRight: 4 }}>
<input
type="radio"
style={{ marginLeft: 4 }}
checked={!prepend}
onChange={() => {
setPrepend(false);
}}
/>
append
</label>
<label style={{ marginRight: 4 }}>
<input
type="radio"
type="checkbox"
style={{ marginLeft: 4 }}
checked={prepend}
onChange={() => {
setPrepend(true);
setPrepend((prev) => !prev);
}}
/>
prepend
Expand Down

0 comments on commit 5a37173

Please sign in to comment.