Получение неожиданного ответа от фабрики Laravel (), вызывающего Сегментационный сбой (Core Dumped) - PullRequest
0 голосов
/ 28 марта 2019

Функция 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');
}

1 Ответ

0 голосов
/ 28 марта 2019

Я нашел ответ на свою проблему.

Для некоторых моделей я создал абстрактный класс с атрибутом $ scope. Атрибут имеет значение по умолчанию «public». После удаления значения по умолчанию из этого атрибута все заработало.

Я переместил значение по умолчанию для этого атрибута в метод конструктора.

...