53. Playwright E2E
End-to-End (E2E) тесты проверяют все приложение целиком в реальном браузере, имитируя полный путь пользователя.
Icon: Monitor (Монитор)
Описание
Заголовок раздела «Описание»Playwright — это современный фреймворк от Microsoft, который позволяет запускать тесты в Chromium, Firefox и Webkit. Он быстрее и стабильнее старых инструментов вроде Selenium.
Mermaid Диаграмма
Заголовок раздела «Mermaid Диаграмма»graph TD Playwright[Playwright Test Runner] -->|Launch| Browser[Real Browser] Browser -->|Navigate| App[React Web App] App -->|API Calls| DB[Backend/Database] Playwright -->|Assert| BrowserУстановка
Заголовок раздела «Установка»npm init playwright@latestПример теста
Заголовок раздела «Пример теста»Создайте файл tests/auth.spec.ts:
import { test, expect } from '@playwright/test';
test('успешный логин пользователя', async ({ page }) => { await page.goto('http://localhost:3000/login');
await page.fill('input[name="password"]', 'password123'); await page.click('button[type="submit"]');
await expect(page).toHaveURL('http://localhost:3000/dashboard'); await expect(page.locator('h1')).toContainText('Добро пожаловать');});Ключевые фишки Playwright
Заголовок раздела «Ключевые фишки Playwright»- Auto-waiting: Playwright ждет, пока элемент станет видимым и доступным для клика, прежде чем выполнить действие. Это убирает 90% “хрупких” тестов.
- Trace Viewer: Возможность просмотреть запись выполнения теста, увидеть скриншоты и состояние DOM на каждом шагу.
- Параллелизм: Тесты запускаются очень быстро благодаря нативной поддержке параллельного выполнения.
- Скриншот-тестирование: Сравнение визуального вида страниц.
Когда использовать?
Заголовок раздела «Когда использовать?»E2E тесты дороги в поддержке и медленны. Используйте их для “критических путей” (Critical Path): регистрация, оплата, оформление заказа. Для всего остального лучше подходят Unit и Integration тесты.
🔗 Полезные ссылки
Заголовок раздела «🔗 Полезные ссылки»Практика
Заголовок раздела «Практика»Попробуйте примеры в интерактивном редакторе: