Модульное тестирование: различия между версиями

Материал из Википедии — свободной энциклопедии
Перейти к навигации Перейти к поиску
[непроверенная версия][непроверенная версия]
Содержимое удалено Содержимое добавлено
Строка 33: Строка 33:
* Для [[C++]]
* Для [[C++]]
** [[CPPUnit]] [http://cppunit.sourceforge.net/cgi-bin/moin.cgi]
** [[CPPUnit]] [http://cppunit.sourceforge.net/cgi-bin/moin.cgi]
** [[Библиотека Boost|Boost]] Test [http://www.boost.org/libs/test/doc/index.html]
** [[Библиотека Boost|Boost]] Test [http://www.boost.org/doc/libs/1_38_0/libs/test/doc/html/index.html]
** [[Symbian OS|Symbian]][http://www.symbianosunit.co.uk/] — фреймворк для Symbian OS всех версий.
** [[Symbian OS|Symbian]][http://www.symbianosunit.co.uk/] — фреймворк для Symbian OS всех версий.
* [[DUnit]] [http://dunit.sourceforge.net/] — для [[Delphi]]
* [[DUnit]] [http://dunit.sourceforge.net/] — для [[Delphi]]

Версия от 12:42, 24 февраля 2009

Юнит-тестирование (англ. unit testing) — процесс в программировании, позволяющий проверить на корректность отдельные модули исходного кода программы. Идея состоит в том, чтобы писать тесты для каждой нетривиальной функции или метода. Это позволяет достаточно быстро проверить, не привело ли очередное изменение кода к регрессии, то есть к появлению ошибок в уже написанных и оттестированных местах программы, а также облегчает локализацию и устранение таких ошибок.

Преимущества

Цель юнит-тестирования — изолировать отдельные части программы и показать, что по отдельности эти части — работоспособны.

Этот тип тестирования обычно выполняется программистами.

Поощрение изменений
Юнит-тестирование позже позволяет программистам проводить рефакторинг, будучи уверенными, что модуль по-прежнему работает корректно (регрессионное тестирование). Это поощряет программистов к изменениям кода, поскольку достаточно легко проверить, что код работает и после изменений.
Упрощение интеграции
Юнит-тестирование помогает устранить сомнения по поводу отдельных модулей и может быть использовано для подхода к тестированию «снизу вверх»: сначала тестируются отдельные части программы, затем программа в целом.
Документирование кода
Юнит-тесты можно рассматривать как «живой документ» для тестируемого класса. Клиенты, которые не знают, как использовать данный класс, могут использовать юнит-тест в качестве примера.
Отделение интерфейса от реализации
Поскольку некоторые классы могут использовать другие классы, тестирование отдельного класса часто распространяется на связанные с ним. Например, класс пользуется базой данных; в ходе написания теста программист обнаруживает, что тесту приходится взаимодействовать с базой. Это ошибка, поскольку тест не должен выходить за границу класса. В результате разработчик абстрагируется от соединения с базой данных и реализует этот интерфейс, используя свой собственный mock-объект. Это приводит к менее связанному коду, минимизируя зависимости в системе.

Ограничения

Важно понимать, что юнит-тестирование не выловит все ошибки. По определению, оно тестирует только модули сами по себе. Тем самым, оно не выявит ошибки интеграции, проблемы производительности или любые другие проблемы системы в целом. Кроме того, довольно трудно предугадать все варианты исходных данных, которые могут быть переданы модулю в реальной работе. Юнит-тестирование будет эффективным только при использовании совместно с другими способами тестирования.

Инструментарий

Для большинства популярных языков программирования высокого уровня существуют инструменты и библиотеки юнит-тестирования. Некоторые из них:

См. также