エロクエント: ファクトリ
はじめに
アプリケーションのテストやデータベースのシード時に、データベースにいくつかのレコードを挿入する必要があるかもしれません。手動で各列の値を指定する代わりに、Laravelではモデルファクトリを使用して、各Eloquentモデルのデフォルト属性セットを定義することができます。
ファクトリの作成方法の例を見るには、アプリケーション内の database/factories/UserFactory.php
ファイルをご覧ください。このファクトリはすべての新しいLaravelアプリケーションに含まれており、次のファクトリ定義が含まれています:
namespace Database\Factories;
use Illuminate\Database\Eloquent\Factories\Factory;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Str;
/**
* @extends \Illuminate\Database\Eloquent\Factories\Factory<\App\Models\User>
*/
class UserFactory extends Factory
{
/**
* The current password being used by the factory.
*/
protected static ?string $password;
/**
* Define the model's default state.
*
* @return array<string, mixed>
*/
public function definition(): array
{
return [
'name' => fake()->name(),
'email' => fake()->unique()->safeEmail(),
'email_verified_at' => now(),
'password' => static::$password ??= Hash::make('password'),
'remember_token' => Str::random(10),
];
}
/**
* Indicate that the model's email address should be unverified.
*/
public function unverified(): static
{
return $this->state(fn (array $attributes) => [
'email_verified_at' => null,
]);
}
}
基本的な形式では、ファクトリはLaravelの基本ファクトリクラスを拡張し、definition
メソッドを定義するクラスです。definition
メソッドは、ファクト リを使用してモデルを作成する際に適用されるデフォルトの属性値セットを返します。
fake
ヘルパーを介して、ファクトリはFaker PHPライブラリにアクセスできます。これにより、テストやシード用にさまざまな種類のランダムデータを便利に生成することができます。
注記
config/app.php
構成ファイル内の faker_locale
オプションを更新することで、アプリケーションのFakerロケールを変更できます。