код. Есть класс, запускаемый по расписанию. В нем метод - №1 - роутер, который а). вызовет метод №2, который дернет внешнее API, б). передаст результат в метод №3 который что-то сделает с результатом. в). передаст получившееся на шаге "б" в другй класс для сохранения в БД, транслирования во внешнюю очередь и т.п. Методы по сути все приватные, извне они не дергаются.
И как бы хотелось бы проверить что скажем метод №3 делает правильные преобразования. Но выносить его для этого в отдельный класс... ?
А у метода №2 по сути только и нужно понять, что он дергает API с правильными парментрами.
И вообще, вот эта конструкция в целом правильныя? Может изначально проблема не в тестах, а я должен по другому классы и методы организовать?
То, что совершенно раздельные куски логики с разными внешними зависимостями спрятаны в приватные методы одного класса - так себе затея, да.
Тестировать надо не сам факт вызова методов с "правильными" параметрами, а результат их работы / ожидаемые сайд эффекты
Обсуждают сегодня