Package Data | |
---|---|
Maintainer Username: | rymanalu |
Maintainer Contact: | rymanalu@gmail.com (Roni Yusuf Manalu) |
Package Create Date: | 2017-03-23 |
Package Last Update: | 2017-09-02 |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-01-13 15:06:44 |
Package Statistics | |
---|---|
Total Downloads: | 8,002 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 17 |
Total Watchers: | 2 |
Total Forks: | 4 |
Total Open Issues: | 3 |
This package offers a lazy way to create a new model factory files, since Laravel (< 5.5) have no Artisan command to generate it.
First, install this package via the Composer package manager:
composer require rymanalu/factory-generator
Next, you should add the FactoryGeneratorServiceProvider
to the providers
array of your config/app.php
configuration file:
Rymanalu\FactoryGenerator\FactoryGeneratorServiceProvider::class,
Now, you should be able to generate a new model factory file by executing php artisan make:factory
command.
php artisan make:factory
accept one argument: the model class name with the namespace. Make sure the model is already exists before executing this command.
Example:
php artisan make:factory "App\Post"
The command will generate a file named PostFactory.php
in /path/to/your-laravel-project/database/factories
directory:
<?php
use App\Post;
use Faker\Generator as Faker;
$factory->define(Post::class, function (Faker $faker) {
//
});
This command also using the fillable array of the model and pair all of fillable values to $faker->word
as default (you can change it to the proper Faker Formatters or other value later) in the generated model factory.
For example, if the App\Post
has fillable array like this:
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Post extends Model
{
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'text',
];
}
Then, the command will generate the PostFactory.php
like this:
<?php
use App\Post;
use Faker\Generator as Faker;
$factory->define(Post::class, function (Faker $faker) {
return [
'text' => $faker->word,
];
});