Функция Laravel factory()
внутри factory()->create()->each()
дает очень неожиданный результат.Функция возвращает огромный массив, полный строк и подмассивов, когда var_dumping внутри консоли, я должен нажать ctrl + c, чтобы остановить рендеринг результата, иначе он продолжает работать (еще не видел конец массива),При выполнении php artisan DB:seed
я получу следующий результат: Segmentation fault (Core dumped)
.
Содержимое внутри массива выглядит как данные из библиотеки Faker.
Кто-нибудь имеет представление о том, где это можетвозможно от?
Я свел свой код к минимуму до заводской для той Модели, которую я хочу вставить в свою БД.Этот курс все еще дает мне тот же результат.
Я var_dumped имя класса из возвращенного объекта, объект возвращается из класса "Illuminate \ Database \ Eloquent \ FactoryBuilder".Как и ожидалось.
Внутри файла SubscriptionFactory.php я закомментировал все внутри функции $factory->define()
.
Код
Приведенный ниже код дает мне бесконечный массив.
factory(App\SubscriptionGroup::class, 3)
->create()
->each(function ($subscriptionGroup)
{
$test = factory(App\Subscription::class);
var_dump($test);
});
Приведенный ниже код - это мой php-файл SubscriptionFactory.
use Faker\Generator as Faker;
$factory->define(App\Subscription::class, function (Faker $faker)
{
$minAge = null;
if (rand(0, 100) > 75) {
$minAge = $faker->randomElement([12, 16, 18]);
}
$maxAge = null;
if (rand(0, 100) > 75) {
$maxAge = $faker->randomElement([21, 35, 50]);
}
$duration = 1;
if (rand(0, 100) > 25) {
$duration = $faker->randomElement([1, 6, 12, 24]);
}
$paidByMember = null;
if (rand(0, 100) > 90) {
$paidByMember = true;
} elseif (rand(0, 100) > 90) {
$paidByMember = false;
}
$tokenPeriod = \App\TokenPeriod::find(rand(1, 7));
$directDebitPeriod = \App\DirectDebitPeriod::find(rand(1, 3));
$unlimitedAccess = $faker->boolean(10);
$periodicTokens = 0;
$transferableTokenPeriod = 0;
if ( ! $unlimitedAccess) {
$periodicTokens = $faker->randomElement([1, 2, 4]);
$transferableTokenPeriod = rand(0, 4);
}
$name = implode(' ', $faker->words(rand(1, 2)));
return [
'status' => 'published',
'name' => $name,
'min_age' => $minAge,
'max_age' => $maxAge,
'membership_duration' => $duration,
'membership_duration_in' => 'months',
'available_date' => \Carbon\Carbon::now(),
'withdraw_date' => null,
'visibility_order' => 1,
'paid_by_member' => $paidByMember,
'unlimited_access' => $unlimitedAccess,
'periodic_tokens' => $periodicTokens,
'transferable_token_period' => $transferableTokenPeriod,
'check_in_access_type_id' => 1,
'token_period_id' => $tokenPeriod->id,
'direct_debit_period_id' => $directDebitPeriod->id
];
});
Результат
Фабрика SubscriptionGroupработает как положено и заполняет базу данных соответственно.Но фабрика подписок дает неверный результат.См. Фрагмент полученного массива ниже.
...
["de schuitjes"]=>
array(1) {
[0]=>
string(3) "van"
}
["schuitjes van"]=>
array(1) {
[0]=>
string(3) "den"
}
["den ponton-steiger"]=>
array(1) {
[0]=>
string(3) "bij"
}
["ponton-steiger bij"]=>
array(1) {
[0]=>
string(9) "Nijmegen."
}
["bij Nijmegen."]=>
array(1) {
[0]=>
string(2) "En"
}
["Nijmegen. En"]=>
array(1) {
[0]=>
string(2) "nu"
}
["nu spraken"]=>
array(1) {
[0]=>
string(2) "ze"
}
["ze over"]=>
array(2) {
[0]=>
string(3) "z'n"
[1]=>
string(2) "'t"
}
...
EDIT
Код ниже также, кажется, вызывает ошибку Segmentation fault (core dumped)
.Таким образом, кажется, что ошибка не в factory(App\Subscription::class)
, а в отношении subscription () внутри SubscriptionGroup.Что делает его еще более странным, потому что это просто простое отношение hasMany.
factory(App\SubscriptionGroup::class)
->create()
->each(function ($subscriptionGroup)
{
$subscriptionGroup->subscriptions();
});
Отношение subscription () внутри класса SubscriptionGroup
:
/**
* @return \Illuminate\Database\Eloquent\Relations\HasMany
*/
public function subscriptions()
{
return $this->hasMany('App\Subscription');
}