Полный цикл тестирования или постоянное управление качеством ПО
Полный цикл тестирования должен проходить через все этапы разработки ПО (программного обеспечения) — начиная с формулировки требований, постановки задачи и заканчивая релизом программного продукта, вводом его в эксплуатацию. На практике все намного сложнее. В реальных условиях реализации крупного программного продукта многое зависит от наличия свободных ресурсов, бюджетных и временных ограничений.
1. Анализ
На самом раннем этапе сбора и анализа требований, составлении технического задания стоит привлекать к работе специалиста по тестированию. Его подход к проверке работоспособности каждого разрабатываемого компонента и будущего приложения в целом схож с восприятием конечного пользователя.
2. Разработка плана, стратегии тестирования
Грамотно разработанный план тестирования позволяет избежать избыточных тестовых процедур. Сроки выполнения каждого запланированного этапа указываются с привязкой к плану разработки ПО. Осуществляется подбор видов тестирования, их порядок, сроки выполнения, а также предварительная оценка трудозатрат.
3. Тестирование требований к ПО
Все требования к будущему ПО должны быть четко систематизированы и документированы, остается только протестировать их на соответствие общим бизнес-целям, полноту, целостность и непротиворечивость.
4. Тестовая документация
Данный шаг нужен для описания расчета объема, степени детализации и хода выполнения задач на доступном понятном языке. Кроме того, необходимо постоянно поддерживать документацию в актуальной форме, регулярно обновляя, с учетом выхода новых изменений и дополнений в ходе проекта.
5. Тестирование прототипа ПО
Тестирование прототипа снижает риски разработки ошибок путем раннего выявления несоответствий, «узких мест», дефектов логики функционала еще до начала разработки.
6. Собственно тестирование в процессе разработки
Тестирование на этапе создания программного продукта состоит из функционального и нефункционального тестирования.
Функциональное тестирование – один из самых важных этапов проверки корректного выполнения заложенных функций с имитацией работы в реальном режиме времени. Для этого используются множество сценариев тестирования ПО (test cases) с подробным описанием шагов. Все они характеризуются действиями пользователя (специалиста по тестированию) и ожидаемыми результатами – ответной реакции программы на эти действия.
- Компонентное (модульное) тестирование, сфокусировано на специфике, функциональных особенностях каждого модуля.
- Интеграционное тестирование проводится после компонентного и направлено на выявление проблем взаимодействия между подсистем на уровне потоков управления и обмена данными.
Нефункциональное тестирование - все прочие виды испытаний, такие как тестирование производительности в разных режимах, тестирование эргономики пользовательского интерфейса, тестирование отказоустойчивости и т.д.
7. Стабилизация
На заключительных этапах тестирование происходит в условиях наиболее приближенных к реальным, что очень важно для отладки на больших объемах информации.
8. Эксплуатация
Необходимость такого тестирования возникает при переходе на новую версию ОС или дополнение рабочего ПО новыми компонентами, библиотеками стороннего производителя. Для этого используется регрессионное тестирование, цель которого проста: доказать, что “ничего не нарушилось”, все работает по всем заявленным ранее требованиям.
Полноценное управление качеством программного продукта возможно только при использовании полного цикла тестирования всех ключевых этапов разработки, внедрения и эксплуатации ПО.