Тестирование приложений при разработке. Функциональное и модульное тестирование::Журнал СА 1-2.2014
www.samag.ru
     
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Наука и технологии
Подписка
Где купить
Авторам
Рекламодателям
Архив номеров
Контакты
   

  Опросы
  Статьи

Электронный документооборот  

5 способов повысить безопасность электронной подписи

Область применения технологий электронной подписи с каждым годом расширяется. Все больше задач

 Читать далее...

Рынок труда  

Системные администраторы по-прежнему востребованы и незаменимы

Системные администраторы, практически, есть везде. Порой их не видно и не слышно,

 Читать далее...

Учебные центры  

Карьерные мечты нужно воплощать! А мы поможем

Школа Bell Integrator открывает свои двери для всех, кто хочет освоить перспективную

 Читать далее...

Гость номера  

Дмитрий Галов: «Нельзя сказать, что люди становятся доверчивее, скорее эволюционирует ландшафт киберугроз»

Использование мобильных устройств растет. А вместе с ними быстро растет количество мобильных

 Читать далее...

Прошу слова  

Твердая рука в бархатной перчатке: принципы soft skills

Лауреат Нобелевской премии, специалист по рынку труда, профессор Лондонской школы экономики Кристофер

 Читать далее...

1001 и 1 книга  
19.03.2018г.
Просмотров: 9943
Комментарии: 0
Потоковая обработка данных

 Читать далее...

19.03.2018г.
Просмотров: 8154
Комментарии: 0
Релевантный поиск с использованием Elasticsearch и Solr

 Читать далее...

19.03.2018г.
Просмотров: 8258
Комментарии: 0
Конкурентное программирование на SCALA

 Читать далее...

19.03.2018г.
Просмотров: 5226
Комментарии: 0
Машинное обучение с использованием библиотеки Н2О

 Читать далее...

12.03.2018г.
Просмотров: 5910
Комментарии: 0
Особенности киберпреступлений в России: инструменты нападения и защита информации

 Читать далее...

Друзья сайта  

 Тестирование приложений при разработке. Функциональное и модульное тестирование

Архив номеров / 2014 / Выпуск №1-2 (134-135) / Тестирование приложений при разработке. Функциональное и модульное тестирование

Рубрика: Разработка /  Тестирование

Михаил Ушаков МИХАИЛ УШАКОВ, разработчик электронной аппаратуры и программного обеспечения для ядерной гаммарезонансной спектроскопии, Уральский федеральный университет, um.nix.user@gmail.com

Тестирование приложений при разработке
Функциональное и модульное тестирование

Практические рекомендации по использованию модульных и функциональных тестов с использованием NUnit и Rhino Mocks для тестирования C#-приложений

Тестирование приложений на этапе разработки должно быть обязательным перед подготовкой их к выпуску (release). Чем раньше удастся обнаружить ошибки, тем ниже стоимость их устранения [1]. Например, для водопадной модели жизненного цикла разработки программ зависимость цены ошибки от стадии проектирования и времени обнаружения представлена на рис.1 [2].

Рисунок 1. Зависимость цены устранения ошибки от стадии проектирования и времени обнаружения [2]

Рисунок 1. Зависимость цены устранения ошибки от стадии проектирования и времени обнаружения [2]

Тестирование – мощный инструмент для обнаружения ошибок и повышения качества программного обеспечения, иногда с его помощью можно обнаружить дефекты, заложенные на этапах написания технического задания и разработки архитектуры приложения по ТЗ, что намного лучше, чем разгребать ошибки в уже проданном программном обеспечении (страдают как репутация фирмы, так и люди, сопровождающие продукты).

Тестирование дает возможность обнаружить те ошибки, которые проявляются редко или очень редко при не совсем обычных условиях (когда переменным присваиваются null-значения, есть пустые строки, зависимость от регистра в строках символов и так далее). От качества тестов зависит количество ошибок, которое может быть обнаружено. Написание качественных тестов – искусство. В настоящее время часто применяют модульное, функциональное, нагрузочное и интеграционное и некоторые другие виды тестирования.

Модульные (unit) тесты используются для проверки состояния объектов в результате и процессе вызова интерфейсных методов, а также для исследования последовательности вызовов интерфейсных методов. В модульных тестах обычно тестируемые классы изолируют от реальных объектов (файлов конфигурации, баз данных, сетевых соединений и т.д.). Как правило, используются библиотеки (Rhino Mocks, Google С++ Mocking Framework, JMock и др.) для создания заглушек (stub) и эмуляторов (mock) реальных объектов.

В функциональных тестах исследуется взаимодействие тестируемых классов с реальными объектами. Нагрузочное тестирование позволяет проверять производительность API и GUI (интерфейс пользователя) приложений. А интеграционные тесты используют для проверки взаимодействия приложения с внешними сервисами.

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

Инструменты для проведения модульного и функционального тестирования в C#: NUnit и Rhino Mocks

Для проведения модульных и функциональных тестов существуют библиотеки NUnit и Microsoft Unit Test. Библиотека NUnit обладает большей гибкостью, чем библиотека модульных тестов от Microssoft. Для использования NUnit в проектах необходимо добавить ссылку (Reference) на сборку NUnit. VisualStudio 2010, 2012, 2013 и SharpDevelop, добавить NUnit через Nuget Package Manager, в консоли набрать команду:

PM> Install-Package NUnit

Для работы с NUnit в более ранних версиях Visual Studio, например, в 2008-й, необходимо установить NUnit с помощью отдельного установщика библиотеки [3], так как менеджер библиотек включен в Visual Studio начиная с версии 2010. После установки NUnit к проекту тестов требуется добавить ссылку на сборку NUnit, а в классы тестов добавляем директиву использования библиотеки:

using NUnit.Framework;

Для использования библиотеки модульных тестов Microsoft необходимо создать проект модульного тестирования и добавить директиву:

using Microsoft.VisualStudio.TestTools.UnitTesting;

Более подробно см. на MSDN [4].

Статью целиком читайте в журнале «Системный администратор», №1-2 за 2014 г. на страницах 89-93.


Комментарии отсутствуют

Добавить комментарий

Комментарии могут оставлять только зарегистрированные пользователи

               Copyright © Системный администратор

Яндекс.Метрика
Tel.: (499) 277-12-41
Fax: (499) 277-12-45
E-mail: sa@samag.ru