К основному контенту

Используйте mocks только, когда это действительно нужно

Мы уже знакомились с тем, что такое mock и как его использовать.

Недавно в рубрике "Google Testing on the Toilet" появилась короткая, но хорошая статья про то, какие минусы у mock'ов (достаточно очевидные для тех, кто уже с ними попрактиковался):

  • тесты становятся непонятными;
  • тесты становится трудно менять и поддерживать;
  • с mock у вас меньше уверенности в том, что тесты действительно правильно проверяют тестируемый код.
Одним из сигналов того, что вы увлеклись мокированием, является подмена mock'ом более чем двух классов. 
Если для понимания того, что делает тест, вам приходится смотреть в тестируемый код - то это  еще один признак лишних mock'ов.

Часто, лучше вместо mock'ов использовать эмуляторы систем, с которыми работает тестируемый код. Тесты при этом просто настраивают эту систему на нужную реакцию.

Комментарии

  1. Ну это смотря какие моки. Если они автоматические то они не сильно влияют.
    Конечно когда меняешь сигнатуры то приходится все тесты править. А на автомоках это просто чуть больше работы.

    Касательно эмуляторов , проблема в том что становится сложенее моделировать поведение. потому что если есть у нас класс с 5 сценариями, а таких классов минимум 5 , то при првоерке симыс в целом нужно уже 25 сценариев проверять. Что приводит к тому что модульные тесты будут вытеснены приемочными. На которые всегда будет не хватать тестировщиков, и система пойдет в штопор.

    ОтветитьУдалить
  2. Леша, ну про моки у меня эа прошедшие 2 года со статьи мнение не поменялось, добавить нечего :)
    А почему программисты не могут писать приемочные? :) Почему для этого "должно хватать тестировщиков"? Я считаю, что часто приемочные проще и быстрее написать, в т.ч. и из-за большой связанности кода, от которой редко удается избавится. Опять же моя практика показывает, что написанный функциональный тест редко меняется, редко удаляется (разве что функционал отключаем), чего не скажешь о юнит-тестах.

    ОтветитьУдалить

Отправить комментарий

Популярные сообщения из этого блога

Полезные ресурсы для молодых (и не только) тестировщиков

сперто(с) Уже 3 месяца провожу собеседования тестировщиков (март 2016). Поначалу они просто  веселили - после 15-летнего опыта собеседования С++-разработчиков, общение с тестировщиками (чаще были "-цы") было чем-то экзотическим и забавным. Потом становилось все грустнее и грустнее, мимими закончилось. Началась печаль.

Заметки на коленке - 3. Что еще делать, если ваши тесты уже "зеленые"?

"Lately I find I'm working on automated tests that return non-binary results. Tests that neither pass nor fail" by  @noahsussman Отличная мысль, которую я ретвитил еще в 2016. Но давайте вместе подумаем, что за этим может скрываться? ( кстати, не знаю, что при этом думал Noah ) Ваши тесты прошли и прошли "успешно". Все хорошо или все же есть, куда еще посмотреть? Дальше то, что использовал я лично и то, что еще можно прикрутить дополнительно. Естественно все шаги ниже должны быть автоматизированны. 1. Контролируйте время выполнения тестов. Если набор проверок не меняется (а такое часто бывает, к сожалению), то рост времени выполнения может говорить о проблемах в продакшен коде (чаще всего) или проблемах с окружением. 2. Контроль за количеством выполняемых тестов. "Все зеленое" не значит, что сегодня выполняли те же Х тестов, что и вчера. Смешно(нет), но случается такое, что какие-то проверки "исчезают" из запуска из-за того, что у кого-то &qu

Mock vs Stub

Когда мы начали изучать модульное тестирование, то одними из первых терминов, с которыми пришлось познакомиться, стали Mock и Stub. Ниже попробуем порассуждать в чем их сходство и различие, как и для чего они применяются. Проверять работоспособность тестируемого объекта (system under test - SUT) можно двумя способами: оценивая состояние объекта или его поведение. В первом случае проверка правильности работы метода SUT заключается в оценке состояния самого SUT, а также взаимодействующих объектов, после вызова этого метода. Во-втором, мы проверяем набор и порядок действий (вызовов методов взаимодействующих объектов, других методов SUT), которое должен совершить метод SUT. Собственно, если коротко, то в одном случае используется Stub, а в другом Mock. Это объекты, которые создаются и используются взамен реальных объектов, с которым взаимодействует SUT в процессе своей работы. Теперь подробнее. Gerard Meszaros использует термин Test Double (дублер), как обозначение для объе