Skip to content

Commit

Permalink
chore(demo-playwright): new tests for fixed bug
Browse files Browse the repository at this point in the history
  • Loading branch information
nsbarsukov committed Nov 7, 2024
1 parent 71b0f31 commit 0bb3c8e
Show file tree
Hide file tree
Showing 3 changed files with 104 additions and 36 deletions.
123 changes: 87 additions & 36 deletions projects/demo-playwright/tests/kit/tabs/tabs.pw.spec.ts
Original file line number Diff line number Diff line change
@@ -1,68 +1,119 @@
import {DemoRoute} from '@demo/routes';
import {TuiDocumentationPagePO, tuiGoto} from '@demo-playwright/utils';
import {TuiDocumentationPagePO, tuiGoto, TuiTabsPO} from '@demo-playwright/utils';
import type {Locator} from '@playwright/test';
import {expect, test} from '@playwright/test';

test.describe('Tabs', () => {
test('no extra margin after the last tab', async ({page}) => {
await page.setViewportSize({width: 1500, height: 500});
await tuiGoto(page, DemoRoute.Tabs);
const {describe, beforeEach} = test;

const example = new TuiDocumentationPagePO(page).getExample('#complex');
describe('Tabs', () => {
describe('Examples', () => {
beforeEach(async ({page}) => {
await tuiGoto(page, DemoRoute.Tabs);
});

describe('complex', () => {
let example!: Locator;
let tabsPO!: TuiTabsPO;

beforeEach(async ({page}) => {
example = new TuiDocumentationPagePO(page).getExample('#complex');
tabsPO = new TuiTabsPO(example.locator('tui-tabs-with-more'));

await example.scrollIntoViewIfNeeded();
});

await example.scrollIntoViewIfNeeded();
test('no extra margin after the last tab', async ({page}) => {
await page.setViewportSize({width: 1500, height: 500});

await expect(example).toHaveScreenshot('01-tabs-1.png');
await expect(example).toHaveScreenshot('01-tabs-1.png');

await page.locator('button:has-text("Collaborators")').click();
await page.locator('button:has-text("Collaborators")').click();

await expect(example).toHaveScreenshot('01-tabs-2.png');
await expect(example).toHaveScreenshot('01-tabs-2.png');

await page.locator('button:has-text("Neil Innes")').click();
await page.locator('button:has-text("Neil Innes")').click();

await expect(example).toHaveScreenshot('01-tabs-3.png');
await expect(example).toHaveScreenshot('01-tabs-3.png');

await page.setViewportSize({width: 560, height: 500});
await page.setViewportSize({width: 560, height: 500});

await expect(example).toHaveScreenshot('01-tabs-4.png');
await expect(example).toHaveScreenshot('01-tabs-4.png');

await example.locator('tui-tabs-with-more .t-more').click();
await example.locator('tui-tabs-with-more .t-more').click();

await expect(example).toHaveScreenshot('01-tabs-5.png');
await expect(example).toHaveScreenshot('01-tabs-5.png');

await page.locator('button:has-text("John Cleese")').nth(1).focus();
await page.keyboard.down('Enter');
await page.locator('button:has-text("John Cleese")').nth(1).focus();
await page.keyboard.down('Enter');

await expect(example).toHaveScreenshot('01-tabs-6.png');
await expect(example).toHaveScreenshot('01-tabs-6.png');

await example.locator('tui-tabs-with-more .t-more').click();
await page.locator('button:has-text("Collaborators")').nth(1).focus();
await page.keyboard.down('Enter');

await expect(example).toHaveScreenshot('01-tabs-7.png');

await page.locator('button:has-text("Neil Innes")').nth(0).focus();
await page.keyboard.down('Enter');

await expect(example).toHaveScreenshot('01-tabs-8.png');
});

await example.locator('tui-tabs-with-more .t-more').click();
await page.locator('button:has-text("Collaborators")').nth(1).focus();
await page.keyboard.down('Enter');
test.only('shows only a single dropdown for the nested item (with [tuiDropdown]) inside more section', async ({

Check failure on line 63 in projects/demo-playwright/tests/kit/tabs/tabs.pw.spec.ts

View workflow job for this annotation

GitHub Actions / Lint

Remove ".only()" from your test case
page,
}) => {
await page.setViewportSize({width: 600, height: 700});

await expect(example).toHaveScreenshot('01-tabs-7.png');
await expect(tabsPO.more).toBeVisible();

await page.locator('button:has-text("Neil Innes")').nth(0).focus();
await page.keyboard.down('Enter');
await tabsPO.more.click();
await tabsPO.getMoreOption('Eric Idle').click();
await tabsPO.more.click();
await tabsPO.getMoreOption('Collaborators').click();

await expect(example).toHaveScreenshot('01-tabs-8.png');
await expect(page.locator('tui-dropdown')).toHaveCount(2);
await expect(page).toHaveScreenshot(
'tabs-dropdown-inside-more-dropdown.png',
);

await page
.locator('tui-dropdown [tuiOption]', {
hasText: 'Carol Cleveland',
})
.hover();

await expect(page).toHaveScreenshot(
'tabs-dropdown-inside-more-dropdown-hover-item.png',
);
});
});
});

test.describe('API', () => {
describe('API', () => {
let example!: Locator;

beforeEach(({page}) => {
example = new TuiDocumentationPagePO(page).apiPageExample;
});

[-2, -1, 0, 1, 2, 3, 4, 5, 100, 1000].forEach((index) => {
test(`clamp active activeItemIndex=${index}`, async ({page}) => {
await tuiGoto(page, `/navigation/tabs/API?activeItemIndex=${index}`);

await expect(
new TuiDocumentationPagePO(page).apiPageExample,
).toHaveScreenshot(`02-tabs-activeItemIndex-${index}.png`);
await expect(example).toHaveScreenshot(
`02-tabs-activeItemIndex-${index}.png`,
);
});
});
});

test('Single button', async ({page}) => {
await tuiGoto(page, `${DemoRoute.Tabs}/API?activeItemIndex=2&sandboxWidth=133`);
test('Single button', async ({page}) => {
await tuiGoto(
page,
`${DemoRoute.Tabs}/API?activeItemIndex=2&sandboxWidth=133`,
);

await expect(new TuiDocumentationPagePO(page).apiPageExample).toHaveScreenshot(
'03-tabs-single-item-01.png',
);
await expect(example).toHaveScreenshot('03-tabs-single-item-01.png');
});
});
});
1 change: 1 addition & 0 deletions projects/demo-playwright/utils/page-objects/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,4 +22,5 @@ export * from './range.po';
export * from './select.po';
export * from './slider.po';
export * from './table-pagination-page.po';
export * from './tabs';
export * from './textfield-with-data-list.po';
16 changes: 16 additions & 0 deletions projects/demo-playwright/utils/page-objects/tabs.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import type {Locator} from '@playwright/test';

export class TuiTabsPO {
public readonly more = this.host.locator('> button.t-more');
public readonly moreDropdown = this.host.page().locator('tui-dropdown');

constructor(private readonly host: Locator) {}

public getMoreOption(indexOrText: number | string): Locator {
if (typeof indexOrText === 'number') {
this.moreDropdown.locator('button[tuiTab]').locator(`nth=${indexOrText}`);
}

return this.moreDropdown.locator(`button[tuiTab]:has-text("${indexOrText}")`);
}
}

0 comments on commit 0bb3c8e

Please sign in to comment.