
- •По тестированию программного обеспечения
- •Способы обеспечения качества программного продукта
- •Организация тестирования
- •Спецификация программы
- •Разработка тестов
- •Управляющий граф программы
- •Основные проблемы тестирования
- •Критерии выбора тестов
- •Требования к идеальному критерию
- •Классы критериев
- •Структурные критерии
- •Функциональные критерии
- •Стохастические критерии
- •Мутационный критерий
- •Оценка покрытия программы и проекта
- •Методика интегральной оценки тестирования
- •Разновидности тестирования
- •Пользовательское тестирование
- •Качественные и количественные требования согласованности по скорости восприятия графической информации пользователем
- •Модульное тестирование
- •Особенности интеграционного тестирования для объектно-ориентированного программирования
- •Системное тестирование
- •Комбинирование уровней тестирования
- •Особенности индустриального тестирования
- •Автоматизация тестирования
- •Издержки тестирования
- •Качество программного продукта
- •Фазы процесса тестирования
- •Планирование тестирования
- •Типы тестирования
- •Подходы к разработке тестов
- •Документация и сопровождение тестов
- •Оценка качества тестов
- •Нагрузочное тестирование
- •Основные этапы нагрузочного тестирования
- •Основные виды нагрузочных тестов
- •Основные инструменты формирования нагрузки и сбора статистики при выполнении нагрузочного тестирования
- •Регрессионное тестирование
- •Цели и задачи регрессионного тестирования
- •Виды регрессионного тестирования
- •Управляемое регрессионное тестирование
- •Обоснование корректности метода отбора тестов
- •Классификация тестов при отборе
- •Возможности повторного использования тестов
- •Классификация выборочных методов
Планирование тестирования
Тестовый план — это документ или набор документов, содержащий:
Тестовые ресурсы.
Перечень функций и подсистем, подлежащих тестированию.
Тестовую стратегию, включающую:
Анализ функций и подсистем с целью определения наиболее слабых мест;
Определение стратегии выбора входных данных для тестирования;
Определение потребности в автоматизированной системе тестирования и дизайн такой системы.
Расписание тестовых циклов.
Фиксацию тестовой конфигурации: состава и конкретных параметров аппаратуры и программного окружения.
Определение списка тестовых метрик. Например, метрик, оценивающих степень покрытия тестами набора требований, степень покрытия кода тестируемой системы, объем тестового кода и др.
Типы тестирования
Типы тестов могут быть классифицированы по 2 категориям:
По тому, что подвергается тестированию (по виду подсистемы или продукта);
По способу выбора входных данных.
Типы тестирования по виду подсистемы или продукта:
Тестирование основной функциональности.
Тестирование инсталляции.
Тестирование пользовательской документации.
Типы тестирования по способу выбора входных данных:
Функциональное тестирование, при котором проверяется:
Покрытие функциональных требований.
Покрытие сценариев использования.
Стрессовое тестирование, при котором проверяются экстремальные режимы использования продукта.
Тестирование граничных значений.
Тестирование производительности.
Тестирование на соответствие стандартам.
Тестирование совместимости с другими программно-аппаратными комплексами.
Тестирование работы с окружением.
Тестирование работы на конкретной платформе.
На практике используются и комбинируются различные типы тестов.
Подходы к разработке тестов
Подходы к разработке тестов:
Подходы, основанные на выборе тестовых данных (тестирование спецификаций, тестирование сценариев);
Подходы, основанные на реализации тестового кода (ручная разработка тестов, генерация тестов).
Тестирование спецификации.
Для каждого требования пишется один или более тестов, которые в совокупности должны проверить выполнение данного требования в продукте.
Тестирование сценариев:
Определяется модель использования. Актором может быть пользователь, другой продукт, аппаратная часть и др.
Разрабатываются сценарии использования продукта.
Разрабатывается набор тестов, покрывающих заданные сценарии.
Ручная разработка тестов.
Производительность труда, характерная для ручной разработки тестов, не намного выше скорости создания кода продукта, а объемы тестового кода на практике зачастую превышают объем кода продукта в 5 и более раз.
Генерация тестов.
Использование специальных тестовых языков (скриптов, например, MSC) и генераторов тестов.
Использование подхода генерации позволяет значительно увеличить производительность тестирования.
Документация и сопровождение тестов
Тестовые процедуры — это формальный документ, содержащий описание необходимых шагов для выполнения тестового набора.
В случае описания ручных тестов тестовые процедуры должны содержать полное описание всех шагов и проверок, позволяющих протестировать продукт и вынести вердикт PASS/FAIL.
Описание тестов должно выполнять следующие задачи:
Анализировать степень покрытия продукта тестами;
Найти тесты использования всех функций ПО;
Определить все функции и их сочетания, которые тест использует;
Вывить структуру и взаимосвязи тестовых файлов;
Выявить принцип построения системы автоматизации тестирования.
Документирование дефекта.
Каждый дефект, обнаруженный в процессе тестирования, должен быть задокументирован и отслежен. При обнаружении нового дефекта его заносят в базу дефектов. При занесении следует указывать:
Наименование подсистемы.
Версия продукта (номер build).
Описание дефекта и шагов, необходимых для воспроизведения.
Номер теста.
Уровень критичности дефекта.
Тестовый отчет обновляется после каждого цикла тестирования:
Перечень функций, запланированный для тестирования на данном цикле, и реальные данные по нему;
Количество выполненных тестов (запланированное и реально исполненное);
Время, затраченное на тестирование каждой функции, и общее время тестирования;
Количество найденных дефектов;
Отклонения от запланированной последовательности действий;
Выводы о необходимых корректировках в системе тестов.