Agent Skills by ALSEL
Anthropic Claudeソフトウェア開発⭐ リポ 299品質スコア 84/100

phpunit

Laravelのフィーチャーテストおよびユニットテストにおける、PHPUnitのテスト構造、命名規則、アサーション、ファクトリーの使用慣例について説明します。

description の原文を見る

PHPUnit test structure, naming, assertions, and factory conventions for Laravel feature and unit tests.

SKILL.md 本文

名前: PHPUnit 説明: PHPUnit のテスト構造、命名規則、アサーション、および Laravel フィーチャーテストとユニットテストのファクトリー規約。 互換エージェント: general-purpose, testing タグ: tests/**/*.php, laravel, php, testing, phpunit, unit-test, feature-test

ルール

  • フィーチャーテストtests/Feature/ に配置し、Tests\TestCase を継承する
  • ユニットテストtests/Unit/ に配置し、PHPUnit\Framework\TestCase を継承する
  • データベースに関わるフィーチャーテストでは常に Illuminate\Foundation\Testing\RefreshDatabase を使用する
  • ユニットテストは Laravel ブートストラップなし — 純粋な PHP テストのみ
  • test_ メソッドプレフィックスにスネークケースの名前を使用する:test_user_can_create_resource
  • すべてのテストメソッドは : void リターンタイプを持つ必要がある
  • 1 つのアサーション関心事あたり 1 つのテストメソッド — テストを焦点を当てた状態に保つ
  • assertEquals よりも assertSame を優先し、厳密な型と値の比較を行う
  • 真偽値だけでなく、具体的な値をアサートする
  • すべての新しいモデルは database/factories/ に対応するファクトリーを持つ必要がある
  • テストではファクトリーを使用し、手動の create() / insert() 呼び出しの代わりに使用する
  • 意味のあるデフォルトファクトリー値を定義し、バリエーションにはステートを使用する

// フィーチャーテスト
use Illuminate\Foundation\Testing\RefreshDatabase;
use Tests\TestCase;

class InvoiceControllerTest extends TestCase
{
    use RefreshDatabase;

    public function test_user_can_create_invoice(): void
    {
        $user  = User::factory()->create();
        $order = Order::factory()->create(['user_id' => $user->id]);

        $response = $this->actingAs($user)
            ->postJson('/api/invoices', ['order_id' => $order->id]);

        $response->assertStatus(201);
        $this->assertDatabaseHas('invoices', ['order_id' => $order->id]);
    }
}
// ユニットテスト — Laravel ブートストラップなし
use PHPUnit\Framework\TestCase;

class MoneyHelperTest extends TestCase
{
    public function test_formats_amount_in_cents_as_currency_string(): void
    {
        $result = MoneyHelper::format(1000, 'CHF');

        $this->assertSame('10.00 CHF', $result);
    }
}
// ステート付きファクトリー
// database/factories/UserFactory.php
public function unverified(): static
{
    return $this->state(fn (array $attributes) => [
        'email_verified_at' => null,
    ]);
}

// テストでの使用
User::factory()->create();
User::factory()->unverified()->create();

アンチパターン

  • データベースに書き込むフィーチャーテストで RefreshDatabase を使用しない
  • テストで insert() または create() の生の呼び出しの代わりにファクトリーを使用しない
  • 単一のテストメソッドで複数のアサーション関心事を混在させる
  • 厳密な比較が必要な場合に assertEquals を使用する(assertSame を使用すべき)
  • 具体的な値ではなく真偽値をアサートする(assertTrue($result !== null)
  • 完全な Laravel アプリケーションをブートストラップするユニットテスト(フィーチャーテストのみで Tests\TestCase を使用する)

リファレンス

ライセンス: MIT(寛容ライセンスのため全文を引用しています) · 原本リポジトリ

詳細情報

作者
majiayu000
リポジトリ
majiayu000/claude-skill-registry
ライセンス
MIT
最終更新
2026/5/4

Source: https://github.com/majiayu000/claude-skill-registry / ライセンス: MIT

本サイトは GitHub 上で公開されているオープンソースの SKILL.md ファイルをクロール・インデックス化したものです。 各スキルの著作権は原作者に帰属します。掲載に問題がある場合は info@alsel.co.jp または /takedown フォームよりご連絡ください。
原作者: majiayu000 · majiayu000/claude-skill-registry · ライセンス: MIT