e2e-playwright

star 6

Use this skill when writing end-to-end tests, browser automation, or verifying user flows in a real browser. Trigger words: E2E, Playwright, ブラウザテスト, ユーザーフロー, 結合テスト, シナリオテスト, ログインテスト, getByRole, expect.

Akira-Papa By Akira-Papa schedule Updated 5/24/2026

name: e2e-playwright description: Use this skill when writing end-to-end tests, browser automation, or verifying user flows in a real browser. Trigger words: E2E, Playwright, ブラウザテスト, ユーザーフロー, 結合テスト, シナリオテスト, ログインテスト, getByRole, expect.

E2E テスト(Playwright)

いつ使うか

  • ログイン〜目的達成までのユーザーフローを通しで検証するとき。
  • フォーム送信・遷移・表示の結合的な確認が必要なとき。

やること

  • 役割/アクセシブルネームで要素を取る(getByRole/getByLabel)。CSS セレクタ依存を避ける。
  • ネットワーク待ちは await expect(...) の自動待機に任せる(固定 sleep 禁止)。
  • テストデータは各テストで独立に用意し、後始末する(他テストに依存しない)。
  • 認証が要るフローは storageState を使い回してログインを毎回しない。
  • 公式 webapp-testing スキル(_external/)があれば手順を参照。

守るルール

  • getByRole/getByLabel 中心のアクセシブルなセレクタ。
  • ✅ 自動待機(expect の retry)を使い、waitForTimeout を避ける。
  • ✅ テストは独立・再実行可能(順序非依存)。
  • ❌ 本番 DB に対して E2E を流さない(専用環境/シードを使う)。
  • ❌ セッション・秘密をテストコードにハードコードしない。

典型例(コード片)

// e2e/login.spec.ts
import { test, expect } from '@playwright/test';

test('ログインしてダッシュボードに到達', async ({ page }) => {
  await page.goto('/login');
  await page.getByLabel('メールアドレス').fill('user@example.com');
  await page.getByLabel('パスワード').fill('correct-horse');
  await page.getByRole('button', { name: 'ログイン' }).click();
  await expect(page.getByRole('heading', { name: 'ダッシュボード' })).toBeVisible();
});

アンチパターン

  • page.waitForTimeout(3000) で待つ(不安定・遅い)。
  • .css-1a2b3c のような生成クラスをセレクタにする。
  • テスト同士が同じレコードを共有して順序依存になる。
Install via CLI
npx skills add https://github.com/Akira-Papa/claude-code-nextjs-mongo-template-1 --skill e2e-playwright
Repository Details
star Stars 6
call_split Forks 6
navigation Branch main
article Path SKILL.md
More from Creator