Автоматизация тестирования. (Занятие 7) презентация

Содержание

Слайд 2

Программа занятия Автоматизация тестирования: Преследуемые цели Стратегия Авто-тесты и инструменты

Программа занятия

Автоматизация тестирования:
Преследуемые цели
Стратегия
Авто-тесты и инструменты

Слайд 3

Занятие 7. Часть 1: цели Что значит «автоматизация»? Зачем автоматизировать? Когда не автоматизировать? Что можно автоматизировать?

Занятие 7. Часть 1: цели

Что значит «автоматизация»?
Зачем автоматизировать?
Когда не автоматизировать?
Что можно

автоматизировать?
Слайд 4

Test automation is any use of tools to support testing

Test automation is any use of tools to support testing
Rapid Software

Testing
James Bach
Michael Bolton
Слайд 5

Это – тоже автоматизация: grep ERROR *.log diff actual.txt expected.txt

Это – тоже автоматизация:

grep ERROR *.log
diff actual.txt expected.txt
Excel – генерация тестовых

данных
NDepend – отбор тестов для выполнения
BTS – поддержка процесса
Vulnerability Scanners
Слайд 6

Но обычно имеется в виду автоматизация выполнения тестов, то есть:

Но обычно имеется в виду

автоматизация выполнения тестов, то есть:
автоматизация воздействий на тестируемое

приложение +
автоматизация проверок реакций на эти воздействия
Слайд 7

Почему именно это? Это «большая» автоматизация, она может включать в

Почему именно это?

Это «большая» автоматизация, она может включать в себя «мелкие»
данные

генерируем «экселем» через COM
проверки выполняем «диффом», сравнивая с заранее заготовленным образцом
Слайд 8

Почему именно это? Это «полная» автоматизация, без промежуточного участия человека

Почему именно это?

Это «полная» автоматизация, без промежуточного участия человека
ожидание чуда, «синдром

Емели»
увы, чудо очень хрупкое
Слайд 9

Почему именно это? Это «сложная» автоматизация, требующая внимания, усилий, вложений,

Почему именно это?

Это «сложная» автоматизация, требующая внимания, усилий, вложений, навыков
требуются стратегические

решения
не тестирование, а программирование
Слайд 10

Человек и машина

Человек и машина

Слайд 11

Занятие 7. Часть 1: цели Что значит «автоматизация»? Зачем автоматизировать? Когда не автоматизировать? Что можно автоматизировать?

Занятие 7. Часть 1: цели

Что значит «автоматизация»?
Зачем автоматизировать?
Когда не автоматизировать?
Что можно

автоматизировать?
Слайд 12

Зачем автоматизировать? Должны быть выгоды по сравнению с «не автоматизировать»

Зачем автоматизировать?

Должны быть выгоды по сравнению с «не автоматизировать»
основные ожидания выгод связаны

с временем
увеличение тестового покрытия
Какие альтернативы?
выполнять вручную
не выполнять совсем
Слайд 13

Ручное и автоматизированное* * цифры условные, но отражают порядок ** пояснение через два слайда

Ручное и автоматизированное*

* цифры условные, но отражают порядок
** пояснение через

два слайда
Слайд 14

Выгоды: время Получение результата раньше Прогоны чаще (в идеале –

Выгоды: время

Получение результата раньше
Прогоны чаще (в идеале – непрерывно)
Высвобождается время –

можно выполнить другие тесты – увеличивается покрытие
Слайд 15

Выгоды: покрытие Увеличение количества тестовых данных Усложнение тестовых сценариев и

Выгоды: покрытие

Увеличение количества тестовых данных
Усложнение тестовых сценариев и увеличение их количества
Увеличение

количества окружений
Возможность сосредоточиться на проектировании тестов (да-да!)
Слайд 16

Как считать «тесты»? Сценарий – 1 Сценарий с данными –

Как считать «тесты»?

Сценарий – 1
Сценарий с данными – 10
Сценарий с данными

в окружении X – 100
Слайд 17

Выгоды: нематериальные Тестировщикам это нравится больше, чем рутинная работа (что неудивительно ☺) Тестировщики учатся программировать

Выгоды: нематериальные
Тестировщикам это нравится больше, чем рутинная работа (что неудивительно ☺)
Тестировщики

учатся программировать
Слайд 18

Занятие 7. Часть 1: цели Что значит «автоматизация»? Зачем автоматизировать? Когда не автоматизировать? Что можно автоматизировать?

Занятие 7. Часть 1: цели

Что значит «автоматизация»?
Зачем автоматизировать?
Когда не автоматизировать?
Что можно

автоматизировать?
Слайд 19

Нет выгод Результат раньше не востребован (процесс) Увеличение покрытия не востребовано (цена ошибки невысока)

Нет выгод

Результат раньше не востребован (процесс)
Увеличение покрытия не востребовано (цена ошибки

невысока)
Слайд 20

Не попадаем в «зеленую зону» Часто возникают сбои либо меняются

Не попадаем в «зеленую зону»

Часто возникают сбои
либо меняются требования
либо в программе

много ошибок
либо тесты написаны плохо
Нет специалистов нужной квалификации
Все тесты уникальные, нет «серийности»
Слайд 21

Не автоматизируется Технологий доступа нет или они сложны тач-скрин, управление

Не автоматизируется

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

использования, недетерминизм, эстетическая привлекательность, верстка
Слайд 22

Занятие 7. Часть 1: цели Что значит «автоматизация»? Зачем автоматизировать? Когда не автоматизировать? Что можно автоматизировать?

Занятие 7. Часть 1: цели

Что значит «автоматизация»?
Зачем автоматизировать?
Когда не автоматизировать?
Что можно

автоматизировать?
Слайд 23

Аспекты качества: ISO 9126 Функциональность Надёжность Эффективность Практичность Сопровождаемость Мобильность

Аспекты качества: ISO 9126

Функциональность
Надёжность
Эффективность
Практичность
Сопровождаемость
Мобильность

Слайд 24

Интерфейсы Пользовательский интерфейс (UI) Программный интерфейс (API) Сетевой протокол Состояние окружения События Таймер

Интерфейсы

Пользовательский интерфейс (UI)
Программный интерфейс (API)
Сетевой протокол
Состояние окружения
События
Таймер

Слайд 25

Уровни тестирования Модульное Интеграционное Системное

Уровни тестирования

Модульное
Интеграционное
Системное

Слайд 26

Стратегия и тактика

Стратегия и тактика

Слайд 27

Инструменты

Инструменты

Слайд 28

Критерии выбора Поддержка интерфейса Переносимость Язык программирования и IDE Расширяемость

Критерии выбора

Поддержка интерфейса
Переносимость
Язык программирования и IDE
Расширяемость
Производительность
Лицензии, цены, выход новых версий
Техсаппорт

Слайд 29

Не изобретайте велосипед

Не изобретайте велосипед

Слайд 30

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

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

Слайд 31

Базовые принципы дизайна Тесты должны быть простыми, короткими, лёгкими в

Базовые принципы дизайна

Тесты должны быть простыми, короткими, лёгкими в сопровождении
Тесты должны

быть изолированы друг от друга
Тесты должны работать с интерфейсом
Тест должен доносить намерение
Слайд 32

Тесты должны быть изолированы друг от друга Зачем? неважен порядок

Тесты должны быть изолированы друг от друга

Зачем?
неважен порядок выполнения
можно произвольно группировать
Как?
каждый

тест должен «убирать за собой»
фиктивные объекты
каждый тест должен заботиться о себе сам
дельта-проверки
Слайд 33

Тесты должны работать с интерфейсом Зачем? независимость от реализации, и

Тесты должны работать с интерфейсом

Зачем?
независимость от реализации, и как следствие упрощение

сопровождения
Как?
делать адаптеры со стабильным интерфейсом
Слайд 34

Тесты должны быть короткими Зачем? простота отладки наглядность результатов простота

Тесты должны быть короткими

Зачем?
простота отладки
наглядность результатов
простота локализации багов
Как?
не копировать ручные «один

в один», проектировать тесты специльано
Слайд 35

Тест должен доносить намерение Зачем? облегчает понимание не требуется документировать тесты Как? понятные имена вспомогательный код

Тест должен доносить намерение

Зачем?
облегчает понимание
не требуется документировать тесты
Как?
понятные имена
вспомогательный код

Слайд 36

Характеристики качества тестов Сопровождаемость удобно читать удобно вносить изменения Мобильность

Характеристики качества тестов

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

нужна
сопровождаемость важнее!
Надёжность – средняя
сопровождаемость важнее!
Слайд 37

Разделение аспектов Данные отделены от кода Конфигурация отделена от кода

Разделение аспектов

Данные отделены от кода
Конфигурация отделена от кода
Код разделён на пакеты
Код

разделён на слои
Инициализация выделена
Воздействия и проверки выделены
Слайд 38

Базовые шаблоны проектирования Четыре части – ИВПЗ Переиспользуемые фрагменты Адаптеры (изоляция) Слои (тоже изоляция)

Базовые шаблоны проектирования

Четыре части – ИВПЗ
Переиспользуемые фрагменты
Адаптеры (изоляция)
Слои (тоже изоляция)

Слайд 39

Делим тест на четыре части Инициализация Воздействие Проверка результата Завершение

Делим тест на четыре части

Инициализация
Воздействие
Проверка результата
Завершение

Слайд 40

2. Выделяем части теста

2. Выделяем части теста

Слайд 41

3. Выделяем адаптеры Адаптер реализации первого уровня идентификация элементов реализации

3. Выделяем адаптеры

Адаптер реализации первого уровня
идентификация элементов реализации
непосредственное воздействие
непосредственная реакция
Адаптер реализации

второго уровня
навигация
комплексные воздействия
сохранение состояния
Слайд 42

4. Выделяем слои Слои адаптеров Слои тестов

4. Выделяем слои

Слои адаптеров
Слои тестов

Слайд 43

После выполнения тестов Возвращать систему в исходное состояние Чистка данных Сбор статистики

После выполнения тестов
Возвращать систему в исходное состояние
Чистка данных
Сбор статистики

Имя файла: Автоматизация-тестирования.-(Занятие-7).pptx
Количество просмотров: 70
Количество скачиваний: 0