company_banner

Собираем окружение для современного TDD на JavaScript + VS code

    TDD уже давно не является чем-то диковинным: на хабре можно найти об этом подходе сотни статей, а каждый новичок знает, какую книгу об экстремальном программировании ему нужно прочитать.

    image

    Многие мои коллеги тоже используют TDD. Они добавляют тест, пишут код, рефакторят, повторяют. Процесс вроде одинаковый, но у одних он занимает одну минуту, а у других пять. И дело не в том, что вторые медленнее думают. Просто у первых есть набор хитростей, позволяющих оптимизировать работу с тестами.

    Прыгаем к тестам


    Начнем с самого простого: до тестов нужно добраться.
    Для этого я пользуюсь Open Spec File
    Это расширение помогает открыть файл с тестами из кода на соседней вкладке.

    image

    Таких много, на любой вкус:
    UnitTest Switcher позволяет переключаться первым пунктом меню по правой кнопке мыши
    Switch to test предлагает кастомизацию пути к файлу с тестами для проектов со сложной структурой

    По моему опыту, самый быстрый вариант — хоткей. Выбрать файл с тестами из списка занимает 2 секунды, хоткеем — полсекунды.

    Запускаем тесты


    Итак, мы попали в файл с тестами. Здесь нам очень поможет расширение Add Only. С ним мы можем одним кликом покрыть describe, it, test, context модификатором only и запускать только его. Просто и удобно.

    image

    Другое расширение JavaScript Test Runner добавляет еще пару кнопок рядом с add only: запуск и debug. Удобно в моментах, когда нужно прогнать пачку тестов один раз.

    image

    Следим за покрытием


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

    image

    Расширение Code Coverage может стать как альтернативой, так и дополнением к предыдущему: подчеркивает непокрытые строки + может выводить количество покрытых строк в открытом файле в статус-бар.

    image

    Информация берется из файла lcov.info в папке coverage. Чтобы расширения указывали на актуальные проблемы, запускайте тестирование с флагами watch и coverage.

    Всё и сразу


    Если вы используете Jest, то попробуйте и одноименный плагин. Он мгновенно схватывает изменения в коде и прогоняет затронутые тесты. Добавляет фишечек в интерфейс:

    image
    Консоль Jest для отслеживания тестов

    image
    Показывает маркерами статус тестов и добавляет описание ошибкам

    Wallaby это большой платный плагин. Он ориентирован на TDD. В своей разработке я его не использую, но чувствую, что обязан рассказать. Wallaby очень быстро прогоняет тесты после изменения кода, обновляет и показывает на ходу покрытие, позволяет также прыгать в файл с тестами и многое другое. Подробнее можно почитать на сайте: wallabyjs.com.

    Резюме


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

    На VS code существует масса других хороших расширений для удобной работы с тестами — напишите, какие упрощают жизнь вам.
    • +24
    • 8,2k
    • 5
    Tinkoff.ru
    120,76
    IT’s Tinkoff.ru — просто о сложном
    Поделиться публикацией

    Похожие публикации

    Комментарии 5

      0
      Спасибо за полезные плагины. Исправьте пожалуйста только название плагина coverage-gutters на Coverage Gutters. Иначе VS Code не находит.
        0
        Странно, что не выцепляет по названию из README. Поправил, спасибо!
        0
        Javascript Test Runner, который в посте, автором более не поддерживается:
        github.com/g3offrey/javascript-test-runner/issues/41#issuecomment-497425080
          0
          К сожалению, да. Но пока работает без проблем. Также знаю ребят, которые готовят достойную альтернативу. Как только выпустят — обязательно отпишу здесь
            0
            Я в angular проекте не смог запустить, говорил, что test runner не найден, хотя просто через `ng test` работает.

        Только полноправные пользователи могут оставлять комментарии. Войдите, пожалуйста.

        Самое читаемое