Skip to content

Commit

Permalink
chore: slow operations on deep tests
Browse files Browse the repository at this point in the history
  • Loading branch information
splincode committed Dec 13, 2024
1 parent f8ea2f2 commit aa8eed2
Show file tree
Hide file tree
Showing 5 changed files with 29 additions and 21 deletions.
1 change: 0 additions & 1 deletion .github/workflows/e2e.yml
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,6 @@ jobs:
needs: [build-demo]
strategy:
fail-fast: false
max-parallel: 9
matrix:
shard: [
# Safari
Expand Down
4 changes: 0 additions & 4 deletions projects/demo-playwright/tests/deep/deep-select.pw.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,6 @@ test.describe('Deep / Select', () => {
await expect(select).toBeVisible();

await select.click();
await api.waitTuiIcons();

const options = await api.getOptions();

Expand All @@ -47,14 +46,12 @@ test.describe('Deep / Select', () => {
await api.focusOnBody();
await api.hideNotifications();
await api.waitStableState();
await api.waitTuiIcons();

await expect(api.apiPageExample).toHaveScreenshot(

Check failure on line 50 in projects/demo-playwright/tests/deep/deep-select.pw.spec.ts

View workflow job for this annotation

GitHub Actions / Playwright / macos-latest / 3 of 9

[webkit] › tests/deep/deep-select.pw.spec.ts:13:13 › Deep / Select › /components/primitive-textfield

1) [webkit] › tests/deep/deep-select.pw.spec.ts:13:13 › Deep / Select › /components/primitive-textfield Error: expect(locator).toHaveScreenshot(expected) 120 pixels (ratio 0.01 of all image pixels) are different. Expected: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/snapshots/tests/deep/deep-select.pw.spec.ts-snapshots/deep--components-primitive-textfield--pseudoHover--row—20-select-option-1-webkit-darwin.png Received: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests-results/tests-deep-deep-select.pw--e8c6d-ponents-primitive-textfield-webkit/deep--components-primitive-6c14a--row—20-select-option-1-actual.png Diff: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests-results/tests-deep-deep-select.pw--e8c6d-ponents-primitive-textfield-webkit/deep--components-primitive-6c14a--row—20-select-option-1-diff.png Call log: - expect.toHaveScreenshot(deep-/components/primitive-textfield-[pseudoHover]-row—20-select-option-1.png) with timeout 5000ms - verifying given screenshot expectation - waiting for locator('#demo-content') - locator resolved to <div id="demo-content" _ngcontent-ng-c2476019924="">…</div> - taking element screenshot - disabled all CSS animations - waiting for fonts to load... - fonts loaded - attempting scroll into view action - waiting for element to be stable - 120 pixels (ratio 0.01 of all image pixels) are different. - waiting 100ms before taking screenshot - waiting for locator('#demo-content') - locator resolved to <div id="demo-content" _ngcontent-ng-c2476019924="">…</div> - taking element screenshot - disabled all CSS animations - waiting for fonts to load... - fonts loaded - attempting scroll into view action - waiting for element to be stable - captured a stable screenshot - 120 pixels (ratio 0.01 of all image pixels) are different. 48 | await api.waitStableState(); 49 | > 50 | await expect(api.apiPageExample).toHaveScreenshot( | ^ 51 | `deep-${path}-${name}-row—${rowIndex}-select-option-${index}.png`, 52 | ); 53 | at /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests/deep/deep-select.pw.spec.ts:50:54

Check failure on line 50 in projects/demo-playwright/tests/deep/deep-select.pw.spec.ts

View workflow job for this annotation

GitHub Actions / Playwright / macos-latest / 3 of 9

[webkit] › tests/deep/deep-select.pw.spec.ts:13:13 › Deep / Select › /components/primitive-textfield

1) [webkit] › tests/deep/deep-select.pw.spec.ts:13:13 › Deep / Select › /components/primitive-textfield Retry #1 ─────────────────────────────────────────────────────────────────────────────────────── Error: expect(locator).toHaveScreenshot(expected) 120 pixels (ratio 0.01 of all image pixels) are different. Expected: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/snapshots/tests/deep/deep-select.pw.spec.ts-snapshots/deep--components-primitive-textfield--pseudoHover--row—20-select-option-1-webkit-darwin.png Received: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests-results/tests-deep-deep-select.pw--e8c6d-ponents-primitive-textfield-webkit-retry1/deep--components-primitive-6c14a--row—20-select-option-1-actual.png Diff: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests-results/tests-deep-deep-select.pw--e8c6d-ponents-primitive-textfield-webkit-retry1/deep--components-primitive-6c14a--row—20-select-option-1-diff.png Call log: - expect.toHaveScreenshot(deep-/components/primitive-textfield-[pseudoHover]-row—20-select-option-1.png) with timeout 5000ms - verifying given screenshot expectation - waiting for locator('#demo-content') - locator resolved to <div id="demo-content" _ngcontent-ng-c2476019924="">…</div> - taking element screenshot - disabled all CSS animations - waiting for fonts to load... - fonts loaded - attempting scroll into view action - waiting for element to be stable - 120 pixels (ratio 0.01 of all image pixels) are different. - waiting 100ms before taking screenshot - waiting for locator('#demo-content') - locator resolved to <div id="demo-content" _ngcontent-ng-c2476019924="">…</div> - taking element screenshot - disabled all CSS animations - waiting for fonts to load... - fonts loaded - attempting scroll into view action - waiting for element to be stable - captured a stable screenshot - 120 pixels (ratio 0.01 of all image pixels) are different. 48 | await api.waitStableState(); 49 | > 50 | await expect(api.apiPageExample).toHaveScreenshot( | ^ 51 | `deep-${path}-${name}-row—${rowIndex}-select-option-${index}.png`, 52 | ); 53 | at /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests/deep/deep-select.pw.spec.ts:50:54

Check failure on line 50 in projects/demo-playwright/tests/deep/deep-select.pw.spec.ts

View workflow job for this annotation

GitHub Actions / Playwright / macos-latest / 3 of 9

[webkit] › tests/deep/deep-select.pw.spec.ts:13:13 › Deep / Select › /components/primitive-textfield

1) [webkit] › tests/deep/deep-select.pw.spec.ts:13:13 › Deep / Select › /components/primitive-textfield Retry #2 ─────────────────────────────────────────────────────────────────────────────────────── Error: expect(locator).toHaveScreenshot(expected) 120 pixels (ratio 0.01 of all image pixels) are different. Expected: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/snapshots/tests/deep/deep-select.pw.spec.ts-snapshots/deep--components-primitive-textfield--pseudoHover--row—20-select-option-1-webkit-darwin.png Received: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests-results/tests-deep-deep-select.pw--e8c6d-ponents-primitive-textfield-webkit-retry2/deep--components-primitive-6c14a--row—20-select-option-1-actual.png Diff: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests-results/tests-deep-deep-select.pw--e8c6d-ponents-primitive-textfield-webkit-retry2/deep--components-primitive-6c14a--row—20-select-option-1-diff.png Call log: - expect.toHaveScreenshot(deep-/components/primitive-textfield-[pseudoHover]-row—20-select-option-1.png) with timeout 5000ms - verifying given screenshot expectation - waiting for locator('#demo-content') - locator resolved to <div id="demo-content" _ngcontent-ng-c2476019924="">…</div> - taking element screenshot - disabled all CSS animations - waiting for fonts to load... - fonts loaded - attempting scroll into view action - waiting for element to be stable - 120 pixels (ratio 0.01 of all image pixels) are different. - waiting 100ms before taking screenshot - waiting for locator('#demo-content') - locator resolved to <div id="demo-content" _ngcontent-ng-c2476019924="">…</div> - taking element screenshot - disabled all CSS animations - waiting for fonts to load... - fonts loaded - attempting scroll into view action - waiting for element to be stable - captured a stable screenshot - 120 pixels (ratio 0.01 of all image pixels) are different. 48 | await api.waitStableState(); 49 | > 50 | await expect(api.apiPageExample).toHaveScreenshot( | ^ 51 | `deep-${path}-${name}-row—${rowIndex}-select-option-${index}.png`, 52 | ); 53 | at /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests/deep/deep-select.pw.spec.ts:50:54

Check failure on line 50 in projects/demo-playwright/tests/deep/deep-select.pw.spec.ts

View workflow job for this annotation

GitHub Actions / Playwright / macos-latest / 3 of 9

[webkit] › tests/deep/deep-select.pw.spec.ts:13:13 › Deep / Select › /components/input-year

2) [webkit] › tests/deep/deep-select.pw.spec.ts:13:13 › Deep / Select › /components/input-year ─── Error: expect(locator).toHaveScreenshot(expected) 563 pixels (ratio 0.01 of all image pixels) are different. Expected: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/snapshots/tests/deep/deep-select.pw.spec.ts-snapshots/deep--components-input-year--tuiTextfieldIconLeft--row—11-select-option-1-webkit-darwin.png Received: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests-results/tests-deep-deep-select.pw-Deep-Select-components-input-year-webkit/deep--components-input-yea-faf6a--row—11-select-option-1-actual.png Diff: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests-results/tests-deep-deep-select.pw-Deep-Select-components-input-year-webkit/deep--components-input-yea-faf6a--row—11-select-option-1-diff.png Call log: - expect.toHaveScreenshot(deep-/components/input-year-[tuiTextfieldIconLeft]-row—11-select-option-1.png) with timeout 5000ms - verifying given screenshot expectation - waiting for locator('#demo-content') - locator resolved to <div id="demo-content" _ngcontent-ng-c2476019924="">…</div> - taking element screenshot - disabled all CSS animations - waiting for fonts to load... - fonts loaded - attempting scroll into view action - waiting for element to be stable - 563 pixels (ratio 0.01 of all image pixels) are different. - waiting 100ms before taking screenshot - waiting for locator('#demo-content') - locator resolved to <div id="demo-content" _ngcontent-ng-c2476019924="">…</div> - taking element screenshot - disabled all CSS animations - waiting for fonts to load... - fonts loaded - attempting scroll into view action - waiting for element to be stable - captured a stable screenshot - 563 pixels (ratio 0.01 of all image pixels) are different. 48 | await api.waitStableState(); 49 | > 50 | await expect(api.apiPageExample).toHaveScreenshot( | ^ 51 | `deep-${path}-${name}-row—${rowIndex}-select-option-${index}.png`, 52 | ); 53 | at /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests/deep/deep-select.pw.spec.ts:50:54

Check failure on line 50 in projects/demo-playwright/tests/deep/deep-select.pw.spec.ts

View workflow job for this annotation

GitHub Actions / Playwright / macos-latest / 3 of 9

[webkit] › tests/deep/deep-select.pw.spec.ts:13:13 › Deep / Select › /components/textarea

3) [webkit] › tests/deep/deep-select.pw.spec.ts:13:13 › Deep / Select › /components/textarea ───── Error: expect(locator).toHaveScreenshot(expected) 657 pixels (ratio 0.01 of all image pixels) are different. Expected: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/snapshots/tests/deep/deep-select.pw.spec.ts-snapshots/deep--components-textarea--tuiTextfieldCustomContent--row—9-select-option-4-webkit-darwin.png Received: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests-results/tests-deep-deep-select.pw-Deep-Select-components-textarea-webkit/deep--components-textarea--ac765---row—9-select-option-4-actual.png Diff: /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests-results/tests-deep-deep-select.pw-Deep-Select-components-textarea-webkit/deep--components-textarea--ac765---row—9-select-option-4-diff.png Call log: - expect.toHaveScreenshot(deep-/components/textarea-[tuiTextfieldCustomContent]-row—9-select-option-4.png) with timeout 5000ms - verifying given screenshot expectation - waiting for locator('#demo-content') - locator resolved to <div id="demo-content" _ngcontent-ng-c2476019924="">…</div> - taking element screenshot - disabled all CSS animations - waiting for fonts to load... - fonts loaded - attempting scroll into view action - waiting for element to be stable - 657 pixels (ratio 0.01 of all image pixels) are different. - waiting 100ms before taking screenshot - waiting for locator('#demo-content') - locator resolved to <div id="demo-content" _ngcontent-ng-c2476019924="">…</div> - taking element screenshot - disabled all CSS animations - waiting for fonts to load... - fonts loaded - attempting scroll into view action - waiting for element to be stable - captured a stable screenshot - 657 pixels (ratio 0.01 of all image pixels) are different. 48 | await api.waitStableState(); 49 | > 50 | await expect(api.apiPageExample).toHaveScreenshot( | ^ 51 | `deep-${path}-${name}-row—${rowIndex}-select-option-${index}.png`, 52 | ); 53 | at /Users/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests/deep/deep-select.pw.spec.ts:50:54
`deep-${path}-${name}-row—${rowIndex}-select-option-${index}.png`,
);

await select.click();
await api.waitTuiIcons();
}

const cleaner = await api.getCleaner(select);
Expand All @@ -69,7 +66,6 @@ test.describe('Deep / Select', () => {

await api.waitStableState();
await api.focusOnBody();
await api.waitTuiIcons();
}
}),
);
Expand Down
2 changes: 0 additions & 2 deletions projects/demo-playwright/tests/deep/deep-toggle.pw.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@ test.describe('Deep / Toggle', () => {
await expect(toggle).toBeVisible();

await toggle.click();
await api.waitTuiIcons();
await api.hideNotifications();
await api.waitStableState();
await page.waitForTimeout(100);
Expand All @@ -41,7 +40,6 @@ test.describe('Deep / Toggle', () => {
);

await toggle.click();
await api.waitTuiIcons();
}
}),
);
Expand Down
4 changes: 2 additions & 2 deletions projects/demo-playwright/tests/demo/demo.pw.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ test.describe('Demo', () => {
const demoPaths: string[] = JSON.parse(process.env['DEMO_PATHS']!);

demoPaths.forEach((path) => {
test(`${path}`, async ({page}) => {
test(`${path}`, async ({page, browserName}) => {
const documentation = new TuiDocumentationPagePO(page);

await tuiMockImages(page);
Expand All @@ -29,7 +29,7 @@ test.describe('Demo', () => {

for (const [i, example] of examples.entries()) {
// eslint-disable-next-line playwright/no-conditional-in-test
if (tuiIsFlakyExample(path, i)) {
if (tuiIsFlakyExample(path, i, browserName)) {
continue;
}

Expand Down
39 changes: 27 additions & 12 deletions projects/demo-playwright/utils/is-flaky-examples.ts
Original file line number Diff line number Diff line change
@@ -1,26 +1,41 @@
import {DemoRoute} from '@demo/routes';

const FLAKY_EXAMPLES = new Map<string, number[]>([
const FLAKY_EXAMPLES = new Map<
string,
Array<{exampleIndex: number; browserName?: string}>
>([
[DemoRoute.AppBar, [{exampleIndex: 0, browserName: 'webkit'}]], // Flaky in safari, need to investigate a problem
[DemoRoute.Carousel, [{exampleIndex: 2, browserName: 'webkit'}]], // Flaky in safari, need to investigate a problem
[
DemoRoute.Carousel,
[
0, // [duration]="4000"
3, // just button (to open dialog)
{exampleIndex: 0}, // [duration]="4000"
{exampleIndex: 3}, // just button (to open dialog)
],
],
[DemoRoute.IconsCustomization, [0]], // TODO: investigate flaky test
[DemoRoute.MultiSelect, [3]], // Imitating server response (timer(5000))
[DemoRoute.Select, [4]], // Imitating server response (delay(3000))
[DemoRoute.Stepper, [2]], // TODO: flaky test for proprietary demo (autoscroll problems)
[DemoRoute.TabBar, [3]], // Imitating server response (timer(3000))
[DemoRoute.Table, [3, 4]], // Imitating server response (delay(3000)) and virtual scroll
[DemoRoute.Tiles, [0]], // YouTube iframe player
[DemoRoute.IconsCustomization, [{exampleIndex: 0}]], // TODO: investigate flaky test
[DemoRoute.LegendItem, [{exampleIndex: 0, browserName: 'webkit'}]], // Flaky in safari, need to investigate a problem
[DemoRoute.MultiSelect, [{exampleIndex: 3}]], // Imitating server response (timer(5000))
[DemoRoute.RingChart, [{exampleIndex: 0, browserName: 'webkit'}]], // Flaky in safari, need to investigate a problem
[DemoRoute.Select, [{exampleIndex: 4}]], // Imitating server response (delay(3000))
[DemoRoute.Stepper, [{exampleIndex: 2}]], // TODO: flaky test for proprietary demo (autoscroll problems)
[DemoRoute.TabBar, [{exampleIndex: 3}]], // Imitating server response (timer(3000))
[DemoRoute.Table, [{exampleIndex: 3}, {exampleIndex: 4}]], // Imitating server response (delay(3000)) and virtual scroll
[DemoRoute.Tiles, [{exampleIndex: 0}]], // YouTube iframe player
]);

export function tuiIsFlakyExample(path: string, exampleIndex: number): boolean {
export function tuiIsFlakyExample(
path: string,
exampleIndex: number,
browserName: string,
): boolean {
const exclusions = FLAKY_EXAMPLES.get(path) ?? [];

const excluded = !!exclusions?.includes(exampleIndex);
const excluded = !!exclusions.find(
(exclusion) =>
exclusion.exampleIndex === exampleIndex &&
(exclusion.browserName ? exclusion.browserName === browserName : true),
);

if (excluded) {
console.info(`skip test for: ${path}[${exampleIndex}]`);
Expand Down

0 comments on commit aa8eed2

Please sign in to comment.