Автоматизированное тестирование. Уровни пирамиды Кона

Практически в каждой сфере есть приёмы и секреты, которые помогают повысить эффективность работы и упростить сложные для восприятия факты и концепции. Тестирование программного обеспечения, как часть IT-индустрии, не исключение и обладает своими особенностями и хитростями.

Одним из распространённых инструментов здесь являются так называемые «визуализаторы» — диаграммы, схемы, изображения и другие наглядные материалы. Они помогают лучше понять сложные процессы, которых в IT-сфере довольно много.

Автоматизированное тестирование тесно связано с именем Майка Кона, который предложил концепцию автоматизации тестирования в виде пирамиды. По ней хорошо видно, какой объём тестов должен быть на том или ином уровне. Пирамида включает три ключевых элемента, которые мы разберем в этой статье.

Автоматизированное тестирование. Уровни пирамиды Кона

Майк Кон — известный эксперт в области разработки ПО и тестирования, особенно в контексте гибких методологий (Agile). Он является одним из основателей Agile-движения и автором нескольких популярных книг, включая «Agile: оценка и планирование проектов» и «Пользовательские истории: гибкая разработка программного обеспечения».

Уровни пирамиды тестирования

Автоматизированное модульное

Модульное тестирование (также известное как компонентное или юнит-тестирование) проводится для проверки соответствия программного обеспечения его функциональным требованиям и выявления ошибок в самых мелких компонентах приложения, которые можно тестировать изолированно. Это могут быть отдельные модули, объекты, классы, функции и другие элементы программы.

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

Основная цель юнит-тестирования заключается в изолированной проверке каждого компонента через запуск тестов в специально созданной среде. Главная задача — подтвердить, что отдельные элементы приложения функционируют правильно.

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

Автоматизированное интеграционное

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

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

Автоматизированное сквозное

Также называется End-to-End testing, то есть процесс тестирования всей системы от начала до конца (полный путь использования) для проверки корректной работы всех компонентов в реальных сценариях использования пользователем. В ходе сквозного тестирования проверяются все уровни взаимодействия: от интерфейса до базы данных и внешних систем.

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

Ручное

В пирамиде тестирования Майка Кона сквозное тестирование расположено в вершине, а модульное тестирование формирует основание. На верхнем уровне пирамиды также находятся тесты пользовательского интерфейса. 

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

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

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

Резюмируем

Пирамида Майка Кона является типичной для тестирования ПО. Но существует множество её версий. Всё зависит от типа проверки продукта, будь то мобильное тестирование или тестирование приложений. В пирамиде измененными могут быть сами составляющие элементы, а также их порядок. Иногда она может быть даже перевернута. Пирамида Кона — основная концепция для тех, кто хочет эффективно использовать автоматизацию тестирования в создании конечного продукта.

Другие статьи
Об авторе
author

Разработчик WordPress, СЕО-специалист "Лаборатории качества". В IT с 2015 года. Работает в департаменте аналитики и технической поддержки и решает внутренние задачи саппорта.

Поиск
Получите совет