WEB-Программист
Переключить навигацию

Язык

  • Русский
  • Русский
Связаться с нами

Поиск

  • Книги
  • JavaScript
  • HTML и CSS
  • Другие
  • SEO
  • wordpress
  • Дизайн
  • Laravel
  • Phyton
  • React js
  • Android
  • SQL и языки запросов
  • Yii
  • Шрифты
  • Статьи
  • Laravel
  • wordpress
  • Темы Wordpress
  • Интернет магазин
  • JavaScript
  • © 2015-2026 Andrii Beznosko

  • Hosting CityHost

Интеграционное тестирование в Laravel 5.1: Фабрики моделей

  • Описания
  • Описание/Скачать

При тестировании кода часто приходится создавать тестовые записи одной или нескольких моделей. Вы могли использовать нечто такое:

$post = new Post;
$post->title = 'Fake Blog Post Title';
$post->body = 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nullam lorem erat, luctus at diam sed, dapibus facilisis purus. In laoreet enim nunc, ut pretium arcu scelerisque in. Nunc eu cursus nibh. Etiam pulvinar vulputate libero sed molestie. In condimentum varius faucibus. Vestibulum non blandit sapien, quis tincidunt augue. Aliquam congue sapien eget mattis sagittis.';
$post->save();

 

Такой код посреди теста уже выглядит ужасным. Но что, если нужно создать несколько тестовых записей? Сделать их отличающимися друг от друга? Способ выше не подходит.

Фабрика

Если вы использовали TestDummy или Faktory, то вам, наверное, уже знакомы «фабрики» для создания тестовых записей для тестирования.

Эти библиотеки делают создание тестовых записей очень простым. Вы просто указываете им класс, объекты которого нужно получить и заполнить тестовыми данными.

Стоит обратить внимание на то, что не обязательно указывать и заполнять все поля модели. Вы можете указать лишь те, которые необходимы в контексте тестирования.

Чтобы узнать больше о том, как работают фабрики, вы можете обратиться к статье Adam Wathan’s.

Пример

Давайте посмотрим на пример фабрики в Laravel 5.1:

// app/database/ModelFactory.php
$factory->define(App\Post::class, function () {
    return [
        'title' => 'My Awesome Post',
        'body' => 'The Body'
    ];
});

 

Вы указали фабрике, что каждый раз при запросе из неё класса App\Post она должна отдавать объект с заданными атрибутами. Достаточно просто.

Получение объекта из фабрики

Для получения объекта можно воспользоваться методом make():

$post = factory(App\Post::class)->make();

dd($post->toArray());
/* Возвратит:
array:2 [
  "title" => "My Awesome Post"
  "body" => "The Body"
]
*/

 

Создание нескольких объектов

Для создания нескольких объектов достаточно задать количество вторым аргументом:

$posts = factory(App\Post::class, 3)->make();

 

Готово. Теперь у вас есть коллекция объектов класса App\Post.

dd($posts->toArray());

/* Возвратит:
array:3 [
  0 => array:2 [
    "title" => "My Awesome Post"
    "body" => "The Body"
  ]
  1 => array:2 [
    "title" => "My Awesome Post"
    "body" => "The Body"
  ]
  2 => array:2 [
    "title" => "My Awesome Post"
    "body" => "The Body"
  ]
]
*/

 

Используем Faker

Вы, наверное, обратили внимание, что у всех объектов класса App\Post одни и те же атрибуты.

Для генерации случайных тестовых атрибутов можно воспользоваться библиотекойFaker. Она полезна как для тестирования, так и для заполнения базы данных тестовыми значениями.

Faker теперь встроен в Laravel 5.1:

$factory->define(App\Post::class, function ($faker) {
    return [
        'title' => $faker->sentence,
        'body' => $faker->paragraph
    ];
});

 

Теперь каждый раз при создании новой записи фабрика будет заполнять её случайными данными.

$posts = factory(App\Post::class, 3)->make();

dd($posts->toArray());

/* Возвратит:
array:3 [
  0 => array:2 [
    "title" => "Ea quis animi ex eius in aut."
    "body" => "Animi velit rerum corrupti quod nam consequuntur. Eius mollitia ut voluptatum laborum quod ex est. Id et aut aut molestias distinctio illo."
  ]
  1 => array:2 [
    "title" => "Illo quod doloribus placeat."
    "body" => "Ea dolorem eligendi modi sit. Facilis incidunt et sequi velit quia. Ab ipsa dicta dolor doloribus."
  ]
  2 => array:2 [
    "title" => "Quod qui ea et quo."
    "body" => "Iure atque vel rerum perspiciatis voluptatem eligendi provident molestiae. Porro aut est accusamus aut. Tempora quisquam ea delectus nihil hic quidem alias velit. Necessitatibus et illum quo culpa ad sint."
  ]
]
*/

 

Сохранение в базе данных

Для сохранения созданных через фабрику объектов в базу данных достаточно воспользоваться методом create():

factory(App\Post::class, 20)->create();

 

Готово. Теперь в вашей базе данных 20 новых записей.

Несколько примеров

Использование в тестах:

<?php
...
class PostRepositoryTest extends TestCase
{
    public function test_it_paginates()
    {
        factory(App\Post::class, 50)->create();

        $thisPage = (new App\PostRepository)->paginate();

        $this->assertEquals(20, $thisPage->count());
    }
}

 

Фабрики хороши для интеграционных тестов, но они также подходят для небольших функциональных или юнит тестов.

В тесте выше мы проверяем, что наша пагинация работает корректно и возвращает 20 записей.

А вот пример небольшого интеграционного теста:

<?php
...
class PostListPageTest extends TestCase
{
    public function test_list_page_paginates()
    {
        factory(App\Post::class, 50)->create();

        $this->visit('/posts')
            ->see('Next Page');
    }
}

 

Здесь мы проверяем появление кнопки «Next Page» на нашей странице при срабатывании пагинации.

Изменение отдельных моделей фабрики

Что, если нам необходимо, чтобы атрибуты конкретной модели были такими, как нам нужно для теста?

Достаточно добавить массив аргументов методам make() или create():

$user = factory(App\Post::class)->make([
    'title' => 'THE GREATEST POST',
]);

 

Группировка моделей в фабрике

Мы также можем сгруппировать различные типы моделей. Например, у нас будут записи с длинным текстом и коротким. Для этого можно воспользоваться методом defineAs():

$factory->defineAs(App\Post::class, 'short-post', function ($faker) {
    return [
        'title' => $faker->sentence,
        'body' => $faker->paragraph
    ];
});

$factory->defineAs(App\Post::class, 'long-post', function ($faker) {
    return [
        'title' => $faker->sentence,
        'body' => implode("\n\n", $faker->paragraphs(10))
    ];
});

 

Или вы можете расширить базовый тип изменённым:

$factory->define(App\Post::class, function ($faker) {
    return [
        'title' => $faker->sentence,
        'body' => $faker->paragraph
    ];
});

$factory->defineAs(App\Post::class, 'long-post', function ($faker) use ($factory) {
    $post = $factory->raw('App\Post');

    return array_merge($post, ['body' => implode("\n\n", $faker->paragraphs(5))]);
});

 

Добавление связей к моделям

Тут всё просто благодаря магии коллекций Laravel:

$posts = factory('App\Post', 3)
    ->create()
    ->each(function($post) {
        $post->relatedItems()->save(factory('App\Item')->make());
    });

 

Заключение

Фабрики моделей давно были мощным средством тестирования и заполнения базы тестовыми данными. Теперь они встроены в фреймворк, что делает процесс тестирования проще.

Продолжение следует…

Комментарии
Всего комментариев: 0
Оставить комментарий Отменить ответ

Ваш email не будет опубликован.

Жанр: Главная » Статьи » Laravel » Интеграционное тестирование в Laravel 5.1: Фабрики моделей
Статус: Для продвинутых программистов
Ссылка на оригинал статьи (Если указана или эта статья не авторская) Скачать
На сайт предоставил Сен 18, 2015 13:29 Andriy

Статьи опубликованные на сайте WEB-Программист указаны со ссылками на источник. Администрация сайта не несет ответственность за их использование Вами

Laravel
Previous Next

Смотри также:

Уроки по Laravel 5

Доброго времени суток, сегодня ми поговорим о таком замечательном фреймворке как laravel 5. Ниже приведен курс уроков от loftblog В нем расскажут про создания гостевой книги Урок 1 Гостевая книга на Laravel 5.1 - #1 Начало https://www.youtube.com/watch?v=yA_28ab3Q8I Урок 2 Гостевая...

Интеграционное тестирование в Laravel 5.1: Мощные интеграционные тесты в несколько строк

Интеграционные тесты? Интеграционные тесты — это то, чем вы тестируете приложение как единое целое. Они являются противоположностью юнит-тестов, которые тестируют части вашего приложения отдельно друг от друга. Обычно интеграционные тесты предоставляют какие-либо данные вашему приложению (часто просто инструкции, например, «посетить...

Генерируем ЧПУ в Laravel 5

Обычно в ЧПУ страниц используется транслит, перевод или фраза в оригинальном состоянии без изменений. С третьим вариантом проблем возникать не должно, Laravel понимает кириллицу из коробки. Рассмотрим остальные два варианта. Перевод Для генерации переведённого ЧПУ нам понадобится пакет Google Translate...

Создание пакетов для Laravel

Prosper Otemuyiwa недавно написал статью о том, как создавать пакеты для Laravel 5 в своём блоге. Хотя его способ абсолютно правильный и может вам подходить, я предпочитаю немного иной способ создания пакетов. Сначала я создаю новый репозиторий на GitHub. В...

Отладка запросов в Laravel

Laravel предоставляет отличный конструктор запросов и ORM — Eloquent. Это позволяет писать запросы невероятно простым и понятным способом. Тем не менее, бывают случаи, когда вам нужно создать сложный запрос и увидеть, какой SQL в действительности сгенерируется. В этом руководстве мы...

Связаться с нами

- Премиум темы и плагины WP Star бесплатно -

We use cookies on our website to give you the most relevant experience by remembering your preferences and repeat visits. By clicking “Accept”, you consent to the use of ALL the cookies.
Cookie settingsACCEPT
Manage consent

Privacy Overview

This website uses cookies to improve your experience while you navigate through the website. Out of these, the cookies that are categorized as necessary are stored on your browser as they are essential for the working of basic functionalities of the website. We also use third-party cookies that help us analyze and understand how you use this website. These cookies will be stored in your browser only with your consent. You also have the option to opt-out of these cookies. But opting out of some of these cookies may affect your browsing experience.
Necessary
Always Enabled
Necessary cookies are absolutely essential for the website to function properly. These cookies ensure basic functionalities and security features of the website, anonymously.
CookieDurationDescription
cookielawinfo-checbox-analytics11 monthsThis cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Analytics".
cookielawinfo-checbox-functional11 monthsThe cookie is set by GDPR cookie consent to record the user consent for the cookies in the category "Functional".
cookielawinfo-checbox-others11 monthsThis cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Other.
cookielawinfo-checkbox-necessary11 monthsThis cookie is set by GDPR Cookie Consent plugin. The cookies is used to store the user consent for the cookies in the category "Necessary".
cookielawinfo-checkbox-performance11 monthsThis cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Performance".
viewed_cookie_policy11 monthsThe cookie is set by the GDPR Cookie Consent plugin and is used to store whether or not user has consented to the use of cookies. It does not store any personal data.
Functional
Functional cookies help to perform certain functionalities like sharing the content of the website on social media platforms, collect feedbacks, and other third-party features.
Performance
Performance cookies are used to understand and analyze the key performance indexes of the website which helps in delivering a better user experience for the visitors.
Analytics
Analytical cookies are used to understand how visitors interact with the website. These cookies help provide information on metrics the number of visitors, bounce rate, traffic source, etc.
Advertisement
Advertisement cookies are used to provide visitors with relevant ads and marketing campaigns. These cookies track visitors across websites and collect information to provide customized ads.
Others
Other uncategorized cookies are those that are being analyzed and have not been classified into a category as yet.
SAVE & ACCEPT