Методические указания по выполнению практических работ по мдк


Практическая работа № 2.17. Автоматизация модульного тестирования



Pdf көрінісі
бет18/26
Дата12.10.2022
өлшемі2,59 Mb.
#152842
түріМетодические указания
1   ...   14   15   16   17   18   19   20   21   ...   26
Байланысты:
тестилеу лек русс

Практическая работа № 2.17. Автоматизация модульного тестирования 
Цель работы: выполнение автоматизации модульного тестирования 
Тест 
В каждом тестовом задании может быть несколько вариантов ответа. После проведения 
теста, студенты могут попробовать обосновать свои неверные ответы. 
1.
Тестовое окружение может использоваться для: 
1.
запуска и выполнения тестируемого модуля 
2.
передачи входных данных 
3.
сбора ожидаемых выходных данных 
4.
сравнения реальных выходных данных с ожидаемыми 
5.
поддержки отчуждения отдельных модулей системы от всей системы 
Ответ: 1, 2, 4, 5 
2.
Тестовое окружение для программного кода на структурных языках 
программирования состоит из: 
1.
драйвера 
2.
тестов 
3.
заглушек 
4.
исходного кода 
Ответ: 1, 3 
3.
Модульное тестирование проводится для того, чтобы: 
1.
удостовериться в корректной работе системы в целом 
2.
удостовериться в корректной работе набора модулей 
3.
удостовериться в корректной работе отдельного модуля 
Ответ: 3 
4.
Модуль – это (с точки зрения наших семинарских занятий): 
1.
часть программного кода, выполняющая одну функцию с точки зрения 
функциональных требований 
2.
программный модуль, т.е. минимальный компилируемый элемент программной 
системы 
3.
задача в списке задач проекта 
4.
участок кода, который может уместиться на одном экране или одном листе 
бумаги 
5.
один класс или их множество с единым интерфейсом. 
Ответ: 2 
5.
Какие основные задачи решаются в ходе модульного тестирования? 
1.
Поиск и документирование несоответствий требованиям 
2.
Поддержка разработки и рефакторинга низкоуровневой архитектуры системы и 
межмодульного взаимодействия 
3.
Рефакторинг модулей 
4.
Поддержка рефакторинга модулей 
5.
Отладка 
6.
Поддержка устранения дефектов и отладки 
Ответ: 1, 2, 4, 6 


65 
Возможности MVSTE по автоматизации модульного тестирования 
Замечание. 
Подробнее 
о 
модульном 
тестировании 
можно 
почитать 
по 
адресу http://msdn2.microsoft.com/en-us/library/ms182515(VS.80).aspx 
До сих пор мы выполняли часть работы вручную. Но при написании 
тестов тестировщик также может ошибиться, из-за чего в программе могут остаться 
различные ошибки. В случае, если программисты ведут разработку по методике 
экстремального программирования (XP), следуя практике написания тестов перед кодом (test 
driven development, TDD), количество тестов, которые нужно написать, становится по объему 
даже большим, чем сам код системы. Однако очевидно, что большую часть работы по 
разработке тестов отдельных методов (модульное тестирование, unit testing) можно 
автоматизировать. В MVSTE разработаны специальные средства для автоматизации 
модульного тестирования. Именно о них и пойдет речь дальше. 
Начало работы 
К моменту написания тестов мы уже имеем полностью готовый код. Можем приступить 
к созданию тестов. 
Создание тестов 
Для создания теста нажимаем правой кнопкой мыши на методе Add() и выбирая пункт 
меню Create Unit Tests.... Появится диалоговое окно, позволяющее создать тесты в другом 
проекте. По умолчанию, создаваемый проект — новый проект на Visual Basic, но также 
доступны тестовые проекты на C# и C ++. Выбираем Visual C# и нажимаем кнопку OK, перед 
тем введя имя проекта BaseCalculator.Test. 
Рисунок 32 
Рисунок 33 


66 
Созданный тестовый проект содержит четыре файла, связанных с тестированием. 
Таблица 6 
Имя файла 
Примечание 
AuthoringTest.txt Примечания о создании тестов, включающие инструкции по добавлению 
дополнительных тестов к проекту 
CalcClassTest.cs 
Включает в себя сгенерированный тест для тестирования метода Add () 
наряду с методами для тестовой инициализации и очистки 
ManualTest1.mht Шаблон, который заполняется инструкциями при ручном тестировании 
UnitTest1.cs 
Пустая структура unit test класса, куда помещаются дополнительные 
тесты 
Так как ручное тестирование мы уже провели, и файл для тестов у нас уже есть, то мы 
удалим ManualTest1.mht и UnitTest1.cs. 
В раздел References при генерации тестового проекта добавляется ссылки 
на Microsoft.VisualStudio.QualityTools.UnitTestFramework и проект BaseCalculator, который и 
будет тестироваться. Первое – сборка, которую использует "движок" модульного 
тестирования при выполнении тестов. Второе — это ссылка на ту сборку, которую мы 
тестируем. 
По умолчанию, сгенерированный тест-метод – это шаблон со следующей реализацией: 
///  
///A test for Add (long, long) 
///
 
[DeploymentItem("BaseCalculator.exe")] 
[TestMethod()] 
public void AddTest() 

long a = 0; // TODO: Initialize to an appropriate value 
long b = 0; // TODO: Initialize to an appropriate value 
int expected = 0; 
int actual; 
actual = BaseCalculator.Test. 
BaseCalculator_CalcClassAccessor.Add(a, b); 
Assert.AreEqual(expected, actual,
"BaseCalculator.CalcClass.Add did not return
the expected value."); 
Assert.Inconclusive("Verify the correctness of this test method."); 

Замечание. Сгенерированный код теста будет сильно зависеть от типа и сигнатуры того 
метода, который планируется тестировать. Например, мастер сгенерирует код, основанный на 
технологии reflection ("отражение"), для тестирования private функций. В нашем конкретном 
случае это не потребовалось, так как метод Add() объявлен как public(). 
Прежде 
всего, 
отметим, 
что 
сгенерированный 
код 
помечен 
атрибутом TestMethod типа TestMethodAttribute, 
а 
сам 
класс 
помечен 
атрибутом TestClassAttribute, 
которые 
объявлены 
в Microsoft.VisualStudio.QualityTools.UnitTesting.Framework. 
При 
помощи 
технологии 
Reflection движок модульного тестирования находит все тестовые классы в проекте, 
помеченные соответствующим атрибутом, а внутри все необходимые для тестирования 
методы. 
Замечание. 
Об 
атрибутах 
можно 
почитать 
подробнее 
по 
адресу http://msdn2.microsoft.com/en-us/library/system.attribute(VS.80).aspx 


67 
В начале теста объявляется значение всех необходимых переменных, а также ожидаемое 
выходное значение. Затем происходит вызов нужного метода, которому передаются 
необходимые параметры. В нашем случае это 
actual = BaseCalculator.Test.BaseCalculator_CalcClassAccessor.Add(a, b); 
Затем идет вызов двух методов класса Assert. Прежде всего рассмотрим второй метод. 
Assert.Inconclusive("Verify the correctness of this test method."); 
Наличие этого метода в тесте говорит о том, что реализация теста еще не закончена. 
Сделаем реализацию нашего метода: 
///  
///A test for Add (long, long) 
///
 
[DeploymentItem("BaseCalculator.exe")] 
[TestMethod()] 
public void AddTest() 

long a = 150;
long b = 350;
int expected = 500; 
int actual; 
actual = BaseCalculator. 
Test.BaseCalculator_CalcClassAccessor.Add(a, b); 
Assert.AreEqual(expected, actual,
"BaseCalculator.CalcClass. 
Add did not return the expected value."); 

Создание тестов 
Чтобы запустить все тесты в рамках проекта, необходимо просто запустить тестовый 
проект. Один из возможных способов сделать это — кликнуть правой кнопкой мыши на 
проекте BaseCalculator.Test в Solution explorer и выбрать Set as StartUp Project. Затем 
используем пункты меню Debug->Start (F5) или Debug->Start Without Debugging (Ctrl+F5), 
чтобы начать запуск тестов. 
В окне Test Results будет показан список со всеми тестами проекта. В момент начала 
выполнения теста в нашем проекте содержалось два теста: один полностью реализованный 
тест AddTest, второй – неоконченный AddTest1. В момент запуска оба теста будут в состоянии 
"неоконченный" ( Pending ), но как только тесты будет выполнены, появятся результаты 
выполнения Passed и Inconcluiseve, которые мы и ожидали. 
Рисунок 34 
Замечание. Рис. 32 показывает окно Test Results. На этом скриншоте в дополнение к 
колонкам по умолчанию изображена колонка Error Message. Колонки могут быть добавлены 


68 
или удалены правым щелчком мыши по меню на заголовках колонки и выборе пункта 
меню Add/Remove Columns... . 
Чтобы посмотреть дополнительные детали о тесте, мы можем дважды щелкнуть на нем 
в окне Test Results и открыть окно AddTest[Result]. В нем можно узнать информацию о 
скорости выполнения теста, его результате, возникшей ошибке и прочее. 
Рисунок 35 
Кроме того, мы можем кликнуть правой кнопкой мыши на отдельных тестах и выбирать 
пункт меню Open Test, чтобы переместиться на код теста. 
Обработка исключений 
На прошлом семинаре мы обнаружили, что метод RunEstimate() класса AnalaizerClass не 
достаточно хорошо проверяет объекты, с которыми он работает. Если инициализировать 
список opz значением {2,2,+,+}, то выполнение метода RunEstimate() приводит к генерации 
исключения. Действительно, реализуем тест: 
///  
///A test for RunEstimate () 
///
 
[DeploymentItem("BaseCalculator.exe")] 
[TestMethod()] 
public void RunEstimateTest() 

string expected = null; 
string actual; 
// Подготовка тестового окружения 
BaseCalculator.Test.BaseCalculator_CalcClassAccessor._lastError = ""; 
BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.opz =
new System.Collections.ArrayList(); 
BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.opz.Add("2"); 
BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.opz.Add("2"); 
BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.opz.Add("+"); 
BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.opz.Add("+"); 
actual = BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.RunEstimate(); 
Assert.AreEqual(expected, actual,
"BaseCalculator.AnalaizerClass.RunEstimate did not return the expected value."); 

Замечание. Для работы этого теста необходимо создать начальное тестовое окружение, 
при этом значение _lastError необходимо очистить, так как оно будет "испорчено" 
тестом AddTest1(). Подробнее о зависимости тестов от порядка выполнения и тестового 
окружения мы поговорим на девятом семинаре. 


69 
Несмотря на то, что явных блоков try-catch не стоит, сгенерированное исключение не 
приведет к прекращению работы тестов, а будет корректно обработано. В этом можно 
убедиться, загляну в окно на RunEstimateTest[Result]. 
Рисунок 36 
Предположим теперь, что при неверных входных параметрах метод RunEstimate() 
действительно должен генерировать исключение, которое будет перехватываться в другом 
месте. Создадим еще один тест: 
///  
///A test for RunEstimate () 
///
 
[DeploymentItem("BaseCalculator.exe")] 
[TestMethod()] 
[ExpectedException(typeof(ArgumentOutOfRangeException), 
"Была обработана неверная синтаксическая конструкция")] 
public void RunEstimateTest1() 

BaseCalculator.Test.BaseCalculator_CalcClassAccessor._lastError = ""; 
BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.opz =
new System.Collections.ArrayList(); 
BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.opz.Add("2"); 
BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.opz.Add("2"); 
BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.opz.Add("+"); 
BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.opz.Add("+"); 
BaseCalculator.Test.BaseCalculator_AnalaizerClassAccessor.RunEstimate(); 

Отметим, 
что, 
опять 
же, 
нет 
блока try-catch с 
явным 
тестом 
на ArgumentOutOfRangeException. 
Вместо 
этого 
тест 
включает 
дополнительный 
атрибут, ExpectedException, который принимает тип параметра, и произвольное сообщение об 
ошибке, которое будет показано, если исключение не было брошено. Когда тесты 
выполняются, среда будет явно следить за тем, чтобы исключение ArgumentException было 
сгенерировано, и если метод не будет генерировать такое исключение, то тест будет провален. 
Программа 
Будут выданы исходные файлы модулей для тестирования методом "белого ящика" 
средствами MVSTE, пример тестового драйвера. 
Составить тест-план и провести модульное тестирование (средствами MVSTE) 
следующих методов: 


70 
1.
public static int Mod(long a, long b) 
2.
public static bool CheckCurrency() 
3.
public static int ABS(long a) 
4.
public static string Format() 
5.
public static int IABS(long a) 
6.
public static string Format() 
7.
public static int Sub(long a, long b) 
8.
public static System.Collections.ArrayList CreateStack() 
9.
public static int Mult(long a, long b) 
10.
public static System.Collections.ArrayList CreateStack() 
11.
public static int Div(long a, long b) 
12.
public static bool CheckCurrency() 


Достарыңызбен бөлісу:
1   ...   14   15   16   17   18   19   20   21   ...   26




©engime.org 2024
әкімшілігінің қараңыз

    Басты бет