INFONKO.RU

Совместимое тестирование модулей

Известны два подхода к совместному тестированию модулей: пошаговое и монолитное тестирование. При монолитном тестировании сначала по отдельности тестируются все модули программного комплекса, а затем все они объединяются в рабочую программу для комплексного тестирования. При пошаговом тестировании каждый модуль для своего тестирования подключается к набору уже проверенных модулей.

В первом случае для автономного тестирования каждого модуля требуется модуль - драйвер (то есть вспомогательный модуль, имитирующий вызов тестируемого модуля и один или несколько модулей - заглушек то есть вспомогательных модулей, имитирующих работу модулей, вызываемых из тестируемого). При пошаговом тестировании модули проверяются не изолированно друг от друга, поэтому требуются либо только драйверы, либо только заглушки. При сравнении пошагового и монолитного тестирования можно отметить следующие преимущества первого подхода:

меньшая трудоемкость (при монолитном тестировании требуются 5 драйверов и 5 заглушек; при пошаговом тестировании требуются или только 5 драйверов - если модули подключаются “снизу вверх ”, - или только 5 заглушек - если модули подключаются “сверху вниз”); более раннее обнаружение ошибок в интерфейсах между модулями

(их сборка начинается раньше, чем при монолитном тестировании); легче отладка, то есть локализация ошибок (они в основном связаны

с последним из подключенных модулей); более совершенные результаты тестирования (более тщательная

проверка совместного использования модулей).

При использовании пошагового тестирования возможны две стратегии подключения модулей: нисходящая и восходящая.

Нисходящее тестирование начинается с главного (или верхнего) модуля программы, а выбор следующего подключаемого модуля происходит из числа модулей, вызываемых из уже протестированных.

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


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

a) модули, содержащие операции ввода-вывода, должны подключаться к тестированию как можно раньше;

b) критические (т.е. наиболее важные) для программы в целом модули также должны тестироваться в первую очередь.



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

Проблемы, которые могут возникать при нисходящем тестировании: появляется соблазн совмещения нисходящего проектирования с тестированием, что, как правило, неразумно, т.к. проектирование - процесс итеративный и в нем неизбежен возврат на верхние уровни и исправление принятых ранее решений, что обесценивает результаты уже проведенного тестирования; может возникнуть желание перейти к тестированию модуля следующего уровня до завершения тестирования предыдущего по объективным причинам (необходимости создания нескольких версий заглушек, использования модулями верхнего уровня ресурсов модулей нижних уровней).

При восходящем тестировании проверка программы начинается с терминальных модулей (т.е. тех, которые не вызывают не каких других модулей программы). Эта стратегия во многом противоположна нисходящему тестированию (в частности, преимущества становятся недостатками и наоборот). Нет проблемы выбора следующего подключаемого модуля - учитывается лишь то, чтобы он вызывал только уже протестированные модули. В отличие от заглушек драйверы не должны иметь несколько версий, поэтому их разработка в большинстве случаев проще.

Другие достоинства восходящего тестирования: поскольку нет промежуточных модулей (тестируемый модуль является для рабочего варианта программы модулем самого верхнего уровня), нет проблем, связанных с возможностью или трудностью задания тестов; нет возможности совмещения проектирования с тестированием; нет трудностей, вызывающих


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

Семантическая отладка

Ошибки этапа выполнения или семантические ошибки происходят, когда вы компилируете полную программу, которая при ее выполнении делает что-то недопустимое. То есть,программа содержит допустимые операторы,но при их выполнении что-то происходит неверно. Например, программа может пытаться открыть для ввода несуществующий файл или выполнить деление на ноль.

Семантическая отладка - это процесс нахождения и исправления ошибок, связанных с неправильным указанием логических страниц данных.

Существует 3 способа отладки программы:

1. Пошаговая отладка программ с заходом в подпрограммы;

2. Пошаговая отладка программ с выполнением подпрограммы как одного оператора;

3. Выполнение программы до точки остановки.

Пошаговая отладка программ заключается в том, что выполняется один оператор программы и, затем контролируются те переменные, на которые должен был воздействовать данный оператор.

Если в программе имеются уже отлаженные подпрограммы, то подпрограмму можно рассматривать, как один оператор программы и воспользоваться вторым способом отладки программ.

Если в программе существует достаточно большой участок программы, уже отлаженный ранее, то его можно выполнить, не контролируя переменные, на которые он воздействует. Использование точек остановки позволяет пропускать уже отлаженную часть программы. Точка остановки устанавливается в местах, где необходимо проверить содержимое переменных или просто проконтролировать, передаётся ли управление данному оператору.


Документирование программы

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

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



infonko.ru/tema-1-rol-i-znachenie-investicij-v-makro-i-mikroekonomike.html infonko.ru/tema-1-rol-resheniya-v-processe-upravleniya-4chasa.html infonko.ru/tema-1-rossijskie-istoricheskie-shkoli-i-ih-predstaviteli.html infonko.ru/tema-1-rukovodstvo-i-liderstvo.html infonko.ru/tema-1-sbor-bibliograficheskogo-materiala-i-ego-pasportizaciya.html infonko.ru/tema-1-servisnaya-deyatelnost-kak-forma-udovletvoreniya-potrebnostej.html infonko.ru/tema-1-sistema-ekonomicheskogo-analiza-deyatelnosti-torgovih-predpriyatij.html infonko.ru/tema-1-sistematizaciya-zakonodatelstva-ponyatie-i-vidi.html infonko.ru/tema1-sovremennoe-ponyatie-ob-okruzhayushej-srede.html infonko.ru/tema-1-specifikaciya-ekonometricheskoj-modeli.html infonko.ru/tema-1-sposobi-virazheniya-koncentracii-rastvora.html infonko.ru/tema-1-sssr-v-poslevoennoe-desyatiletie-1945-1953.html infonko.ru/tema-1-stanovlenie-i-razvitie-finansovoj-sistemi.html infonko.ru/tema-1-stanovlenie-i-razvitie-issledovatelskoj-deyatelnosti-v-rossii.html infonko.ru/tema-1-stanovlenie-i-razvitie-sistemi-ugolovnogo-zakonodatelstva-i-prava-rossii.html infonko.ru/tema-1-stanovlenie-i-razvitie-sovremennih-form-i-metodov-vedeniya-setevogo-gostinichnogo-hozyajstva.html infonko.ru/tema-1-statistiko-ekonomicheskij-analiz-urovnya-i-effektivnosti-proizvodstva-produkcii-rastenievodstva.html infonko.ru/tema-1-stilistika-i-literaturnoe-redaktirovanie-kak-predmet-izucheniya-napravleniya-stilisticheskih-issledovanij.html infonko.ru/tema-1-storichnij-rozvitok-seksolog-yak-naukovo-disciplni-predmet-ta-zavdannya-disciplni-osnovi-seksolog-ta-seksopatolog.html infonko.ru/tema-1-strahov-poslugi-realzacya-strahovih-poslug.html