Что касается тестовые двойники, можно ли размещать их в основном коде, чтобы их можно было использовать при тестировании кода, который содержит исходную библиотеку jar в качестве зависимости?
Есть код, который помогает мне в модульном тестировании (двойные тесты) в библиотеке, которую я реализовал. Можно ли хранить этот код в банке, чтобы его можно было использовать в коде, использующем библиотеку в качестве зависимости.
еще раз Мартин использует свой собственный словарь :)




Короткий ответ: нет.
Поскольку вы имеете в виду Java, я могу указать на зависимости от Maven и конфигурации Gradle. Они отделяют зависимости между вашим основным кодом и кодом, предназначенным исключительно для целей тестирования. И они существуют не просто так. Вы можете использовать готовые библиотеки для своего теста, но вы не должны развертывать тестовые двойники в своей производственной системе.
Я верю, что ваши тестовые двойники соответствуют вашему руководству по стилю и сами тестируются. А как же требования безопасности? Вы действительно уверены, что не вводите уязвимости в свою систему с помощью этих тестовых двойников? Вы действительно хотите учитывать эти ненужные части вашей системы при планировании теста на проникновение? Или, что еще хуже, вы хотите объяснить своему специалисту по тестированию пера, чтобы он их учитывал?
Если вы разработали повторно используемые тестовые компоненты, вы сделали что-то полезное. Но вы должны изолировать их в отдельных библиотеках. Они являются частью специальной системы тестирования. Относитесь к ним так же, как к JUnit.
не могли бы вы уточнить? что такое "тестовые двойники"?