Статья:

ЭТАПЫ ОРГАНИЗАЦИИ СИСТЕМ АВТОМАТИЧЕСКОГО ТЕСТИРОВАНИЯ

Журнал: Научный журнал «Студенческий форум» выпуск №17(196)

Рубрика: Технические науки

Выходные данные
Абдреев И.О., Пержинский С.М., Филиппов Д.А. ЭТАПЫ ОРГАНИЗАЦИИ СИСТЕМ АВТОМАТИЧЕСКОГО ТЕСТИРОВАНИЯ // Студенческий форум: электрон. научн. журн. 2022. № 17(196). URL: https://nauchforum.ru/journal/stud/196/110722 (дата обращения: 13.01.2025).
Журнал опубликован
Мне нравится
на печатьскачать .pdfподелиться

ЭТАПЫ ОРГАНИЗАЦИИ СИСТЕМ АВТОМАТИЧЕСКОГО ТЕСТИРОВАНИЯ

Абдреев Иван Олегович
студент, кафедра телекоммуникационных систем Уфимского государственного технического авиационного университета, РФ, г. Уфа
Пержинский Святослав Максимович
студент, кафедра телекоммуникационных систем Уфимского государственного технического авиационного университета, РФ, г. Уфа
Филиппов Даниил Александрович
студент, кафедра телекоммуникационных систем Уфимского государственного технического авиационного университета, РФ, г. Уфа

 

Процесс автоматизации тестирования – это интеллектуальное творчество ИТ-специалистов высокой квалификации, но для достижения поставленных целей его тоже необходимо вести планомерно. На каждом этапе специалисты выбирают правильную стратегию испытаний при проверке качества исследуемого объекта. Основные этапы автоматизации тестирования:

Подготовка – выбор бизнес-операций, подлежащих автоматизации тестирования, определение требований к Системе Автоматизированного Функционального Тестирования (САФТ), согласование проектных сроков, выбор инструмента автоматизации, оценка возможных рисков.

Проведение – производится запуск автоматизированных тестов и проведение регрессионного автоматизированного тестирования, если необходимо.

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

Инструменты тестирования позволяют делать выбор между подходами: работать по Behaviour Driven Development или просто писать сценарные тесты для их автоматического запуска и проверки поведения системы. Разница примерно такая же как между Test Driven Development и покрытием юнит тестами. TDD говорит о том, что модульный тест (юнит тест), которому должен удовлетворять модуль (объект, метод) пишется до того, как написана реализация программного модуля. Максимум, что может быть описано одновременно с тестом – это интерфейс – сигнатура метода, интерфейс объекта. Первый запуск теста обязан "упасть" – подтвердить, что текущая реализация не работает.

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

Покрытие тестами без применения TDD – это наоборот, написание модульных тестов на уже реализованный функционал. Покрытие тестами делается для безопасного рефакторинга модуля и регрессионного тестирования. Того же самого результата позволяет добиться TDD, но TDD это другая концепция. И в том, и в другом случае количество кода, создаваемого программистами, сильно увеличивается, стоимости разработки растет в начале, но компенсируется сокращением сроков на развитие, отладку, тестирование, рефакторинг и поддержку. Аналогично BDD отличается от применения сценарных тестов для проверки уже реализованного функционала. BDD говорит о том, что фича-файл и содержащиеся в нем сценарии являются спецификацией на часть программного продукта. И эта спецификация пишется до реализации программного продукта. Но в отличие от TDD, где речь идет лишь о коде и взаимодействии программиста и кода, в BDD речь идет о поведении пользователя в системе и о постановки задачи разработчику бизнес-аналитиком. Или о совместной проработке спецификации бизнес аналитиком и программистом. При этом сценарии, описывающие поведение пользователя и смотрящие на систему глазами пользователей, опираются не на интерфейс метода, не на сигнатуру функции, а на пользовательский графический интерфейс приложения.

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

 

Список литературы:
1. Автоматизированное тестирование, автоматизация тестирования приложений. URL: https://daglab.ru/avtomatizirovannoe-testirovanie-avtomatizacija-testirovanija-prilozhenij/ (дата обращения: 20.04.2022).
2. Автоматизация тестирования. URL: https://coderlessons.com/tutorials/kachestvo-programmnogo-obespecheniia/ruchnoe-testirovanie/avtomatizatsiia-testirovaniia (дата обращения: 21.04.2022).
3. Разработка системы автоматизированного тестирования. URL: https://dspace.spbu.ru/bitstream/11701/4023/1/diploma_-_diploma.pdf (дата обращения: 22.04.2022).
4. Лекция 8: Автоматизация тестирования. URL: https://intuit.ru/studies/courses/48/48/lecture/1438?page=1 (дата обращения: 21.04.2022).