Мы немного разобрались с тестами, давайте поговорим о культуре их запуска. В этом уроке вы познакомитесь с непрерывной интеграцией и узнаете, как тестировать правильно.
Локальный запуск тестов – это персональная ответственность. Хорошие разработчики используют тесты непрерывно во время разработки и обязательно запускают их перед пушем (git push
).
Но этого недостаточно, ведь всегда присутствует человеческий фактор и ошибки. Даже несмотря на локальный запуск, тесты должны запускаться автоматически на серверах непрерывной интеграции.
Непрерывная интеграция – это практика разработки, которая заключается в частой и автоматизированной сборке приложения для быстрого выявления проблем.
Обычно интеграция выполняется на коммиты в репозиторий. За этим следит либо специальный сервер, либо сервис непрерывной интеграции. Он загружает код и по необходимости собирает его, а затем запускает различные проверки.
Что и как запускается? Программист определяет заранее. В первую очередь это тесты и линтер — проверка оформления кода. Кроме них, могут запускаться утилиты, анализирующие безопасность, актуальность зависимостей и многое другое.
Так непрерывную интеграцию можно изобразить на схеме:
Подробнее разберемся в терминологии и самом процессе:
Для внедрения непрерывной интеграции есть два пути.
Первый путь — поставить себе на сервер Jenkins или его аналог. Этот вариант требует много ручной работы, в том числе по поддержке сервера. Такое решение подходит компаниям, которые:
Второй путь – воспользоваться сервисом непрерывной интеграции. Таких сервисов десятки, если не сотни. Есть из чего выбрать. Как правило, большинство из них бесплатны для открытых проектов.
Одно из распространенных решений — это Github Actions, встроенный сервис Github:
Github Actions не только обеспечивает непрерывную интеграцию — он может гораздо больше. Хекслет использует Actions во всех своих открытых и закрытых проектах (пример такого проекта).
Для удобства, сервис дает «бейджик» — картинку, которая вставляется в README-файл проекта. Бейджик показывает текущий статус проекта — успешна последняя сборка или нет. По клику на него можно попасть на страницу с последними сборками.
Вам ответят команда поддержки Хекслета или другие студенты.
Базовый план откроет полный доступ ко всем курсам, упражнениям и урокам Хекслета, проектам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.
Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно
Наши выпускники работают в компаниях:
С нуля до разработчика. Возвращаем деньги, если не удалось найти работу.
Зарегистрируйтесь или войдите в свой аккаунт