Skip to content

Commit

Permalink
chore(demo): add new e2e test for field error
Browse files Browse the repository at this point in the history
  • Loading branch information
splincode committed Jan 29, 2024
1 parent 6132683 commit 767344b
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 11 deletions.
30 changes: 20 additions & 10 deletions projects/demo-playwright/tests/kit/field-error/field-error.spec.ts
Original file line number Diff line number Diff line change
@@ -1,23 +1,33 @@
import {tuiGoto} from '@demo-playwright/utils';
import {TuiDocumentationPagePO, tuiGoto} from '@demo-playwright/utils';
import {expect, test} from '@playwright/test';

test.describe('TuiFieldError', () => {
test.describe('FieldError', () => {
test('Errors of invalid control are shown correctly', async ({page}) => {
const example = new TuiDocumentationPagePO(page).getExample('#base');

await tuiGoto(page, '/pipes/field-error');

const errorPipeInput = page
.locator('tui-field-error-pipe-example-1 input')
.first();
const input = example.locator('input').first();

await errorPipeInput.focus();
await input.focus();
await input.blur();

await page.waitForTimeout(50);
await page.waitForTimeout(500);

await errorPipeInput.blur();
await expect(example).toHaveScreenshot('01-field-error.png', {
animations: 'allow',
});
});

test('Submit invalid form', async ({page}) => {
const example = new TuiDocumentationPagePO(page).getExample('#patterns');

await tuiGoto(page, '/pipes/field-error');
await example.locator('button').click();

Check failure on line 26 in projects/demo-playwright/tests/kit/field-error/field-error.spec.ts

View workflow job for this annotation

GitHub Actions / playwright / (6 of 8)

[chromium] › tests/kit/field-error/field-error.spec.ts:22:9 › FieldError › Submit invalid form

1) [chromium] › tests/kit/field-error/field-error.spec.ts:22:9 › FieldError › Submit invalid form TimeoutError: locator.click: Timeout 10000ms exceeded. Call log: - waiting for locator('#patterns [automation-id="tui-doc-example"]').locator('button') 24 | 25 | await tuiGoto(page, '/pipes/field-error'); > 26 | await example.locator('button').click(); | ^ 27 | 28 | await page.waitForTimeout(500); 29 | at /home/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests/kit/field-error/field-error.spec.ts:26:41

Check failure on line 26 in projects/demo-playwright/tests/kit/field-error/field-error.spec.ts

View workflow job for this annotation

GitHub Actions / playwright / (6 of 8)

[chromium] › tests/kit/field-error/field-error.spec.ts:22:9 › FieldError › Submit invalid form

1) [chromium] › tests/kit/field-error/field-error.spec.ts:22:9 › FieldError › Submit invalid form Retry #1 ─────────────────────────────────────────────────────────────────────────────────────── TimeoutError: locator.click: Timeout 10000ms exceeded. Call log: - waiting for locator('#patterns [automation-id="tui-doc-example"]').locator('button') 24 | 25 | await tuiGoto(page, '/pipes/field-error'); > 26 | await example.locator('button').click(); | ^ 27 | 28 | await page.waitForTimeout(500); 29 | at /home/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests/kit/field-error/field-error.spec.ts:26:41

Check failure on line 26 in projects/demo-playwright/tests/kit/field-error/field-error.spec.ts

View workflow job for this annotation

GitHub Actions / playwright / (6 of 8)

[chromium] › tests/kit/field-error/field-error.spec.ts:22:9 › FieldError › Submit invalid form

1) [chromium] › tests/kit/field-error/field-error.spec.ts:22:9 › FieldError › Submit invalid form Retry #2 ─────────────────────────────────────────────────────────────────────────────────────── TimeoutError: locator.click: Timeout 10000ms exceeded. Call log: - waiting for locator('#patterns [automation-id="tui-doc-example"]').locator('button') 24 | 25 | await tuiGoto(page, '/pipes/field-error'); > 26 | await example.locator('button').click(); | ^ 27 | 28 | await page.waitForTimeout(500); 29 | at /home/runner/work/taiga-ui/taiga-ui/projects/demo-playwright/tests/kit/field-error/field-error.spec.ts:26:41

const example = page.getByTestId('tui-doc-example').first();
await page.waitForTimeout(500);

await expect(example).toHaveScreenshot('shows-error-under-field.png', {
await expect(example).toHaveScreenshot('02-field-error.png', {
animations: 'allow',
});
});
Expand Down
10 changes: 10 additions & 0 deletions projects/demo/src/modules/pipes/field-error/examples/3/index.html
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
<form
class="b-form"
[formGroup]="testForm"
(submit)="onSubmit()"
>
<label tuiLabel="Secret number">
<tui-input
Expand Down Expand Up @@ -47,4 +48,13 @@
[error]="[] | tuiFieldError | async"
></tui-error>
</label>

<button
size="m"
tuiButton
type="submit"
class="tui-space_top-4"
>
Submit
</button>
</form>
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import {
} from '@angular/forms';
import {changeDetection} from '@demo/emulate/change-detection';
import {encapsulation} from '@demo/emulate/encapsulation';
import {TuiValidationError} from '@taiga-ui/cdk';
import {tuiMarkControlAsTouchedAndValidate, TuiValidationError} from '@taiga-ui/cdk';
import {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';

const secretRegexTen = /^\d{10}$/;
Expand Down Expand Up @@ -47,6 +47,10 @@ export class TuiFieldErrorPipeExample3 implements OnInit {
this.testValue2.setValidators([Validators.required, this.companyValidator]);
}

onSubmit(): void {
tuiMarkControlAsTouchedAndValidate(this.testForm);
}

private readonly companyValidator = (
field: AbstractControl,
): ValidationErrors | null =>
Expand Down

0 comments on commit 767344b

Please sign in to comment.