Automation EmpireAutomation EmpireAutomation Empire
(ПН - ВС) [10:00 - 22:00]
https://t.me/t_fire
Automation EmpireAutomation EmpireAutomation Empire

Про автоматизацию тестирования

Многие компании, которые занимаются производством крупного программного обеспечения, нуждаются в регулярном тестировании своих разработок.

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

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

Разрушая мифы

Автоматизация подходит не всем и вся. Разберем популярные тезисы:

Автоматизация экономит время и ресурсы

Реальность: Автоматизация экономит время при многократном выполнении сценариев тестирования. Зачем автоматизировать процесс, если сценарий пройдет один раз?

Автоматизация экономит время и ресурсы

Реальность: Тезис действителен только для исполнения сценариев на стабильной системе. Иногда отладить сценарий автоматизации и добиться его стабильного выполнения отнимет больше времени, чем «поработать руками».

Более широкий тестовый охват функций приложения

Реальность: Тезис верен, только если система автоматизации позволяет автоматизацию этой функции.

Автоматизация позволяет тестировать часто и тщательно

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

Автоматизация — фу. А, не — показалось

У автоматизации есть и свои плюсы:

  • Построение и внедрение полноценного процесса DevOps.
  • Быстрая подготовка большого объема тестовых данных.
  • Возможность оперативно протестировать ПО до публикации кода.
  • Быстрая проверка исправлений багов тестировщиками.
  • Сокращение времени полной проверки продукта с нескольких недель до нескольких часов (зависит от продукта).

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

  • Соответствие возможностей выбранного инструмента/платформы для автоматизации тестирования вашего ПО (или тестовой модели для проверки вашего ПО).
  • Требования к квалификации персонала для работы с инструментом.
  • Сложность обучения.
  • Сложность и стоимость масштабирования.
  • Стоимость инструмента.

Какие сложности при использовании бесплатных решений:

  • Нужно иметь хороший скилл программирования.
  • Ресурсоемкие поддержка и доработка используемых инструментов.
  • Конфигурация DevOps происходит самостоятельно и без поддержки -> Внедрение решения по автоматизации в DevOps происходит самостоятельно и без поддержки.
  • Большие ресурсы на поддержку документации и подготовку обучающих материалов.

Какие сложности при использовании платных решений:

  • Удовольствие является достаточно дорогим.
  • Команда автоматизации должна хорошо знать английский.
  • Масштабирование отдельных продуктов представило свои сложности.

Что осознали про автоматизацию тестирования:

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

Переход на нашу RPA

В итоге, мы переходим на нашу собственную систему Browser Automation Studio RPA (Robotic Process Automation). И у такого перехода видим свои плюсы:

Плюс #1: Визуализация автоматизирования

Использование платформы предполагает либо полное отсутствие, либо минимальное знание языков программирования, которые используем (Java, C#, Python) => Спасибо визуальному интерфейсу. Если и надо добавить код, то на уровне простых функций.

Плюс #2: No English

Использование RPA-платформы BAS не требует знаний английского – весь контент, включая документацию, написан на русском языке.

Плюс #3: Легкий онбординг

Подготовка обучающих материалов и обучение сотрудников – большая часть гайдов уже готова + сам интерфейс является интуитивно понятным.

Плюс #4: Минимальные затраты на поддержку

Мы не тратим финансовые ресурсы на развитие платформу. Совсем.

Плюс #5: Поддержка DevOps

Разворачивание и поддержка DevOps либо не требует времени, либо отнимает на 80% меньше времени, чем обычно => Спасибо встроенному решению Модулей FTP/SQL и др. + возможность его вызова из другой CI системы.

Плюс #6: Легко перебрасывать сотрудников на проекты

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

Плюс #7: Возможность работы с гос. учреждениями

Учитывая, что государственные учреждения максимально предпочитают либо бесплатные, либо российские аналоги – работа с их проектами проходит легче.

RPA BAS как инструмент нагрузочного тестирования

Платформа RPA BAS может использоваться для нагрузочного тестирования, ибо функционал позволяет исполнять сценарии параллельно. Однако, на момент написания статьи есть и ограничения, поэтому не стоит сравнивать его с теми же Jmeter или LoadRunner:

  • Каждый робот (алгоритм) – это отдельный процесс, и будет потреблять больше ресурсов, чем выделенный поток.
  • Один робот = один сценарий нагрузки.
  • Отчетность есть, но не больно детальная.
  • Нет встроенного инструмента анализа потребления системных ресурсов
  • Нет инструмента перехватывания HTTP запросов => сложность при эмуляции работы пользователей в Web-приложении.

Держим пункты, описанные выше, в голове и рассмотрим реализацию нагрузочного тестирования с помощью BAS:

API

С определенными ограничениями: предусмотрены готовые действия (шаги в алгоритме в визуальном интерфейсе) для эмуляции SOAP и REST запросов.

Web:

Большое количество требуемых ресурсов железа, потому что BAS воспроизводит сценарий во встроенном Chrome браузере оф. сборки. Исполнение происходит тяжелее, чем эмуляция HTTP-потока через специализированные инструменты.

Получается:

Если нет необходимости в реализации сложного сценария или глубокого анализа влияния каждого шага на потребление ресурсов или эмуляции высокой нагрузки на систему, то RPA могёт:

  1. Под каждый сценарий написать отдельного Робота.
  2. Написать Робота, запускающего другие Роботы.
  3. Получить отчет о работе Роботов.

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

Общие выводы

Получается:

  • Автоматизация нужна не в каждом случае.
  • А если автоматизация нужна – можно попробовать RPA BAS.
  • Сколько чашек чая с печеньками вы можете выпить, пока робот делает за вас работу?

Leave A Comment

At vero eos et accusamus et iusto odio digni goikussimos ducimus qui to bonfo blanditiis praese. Ntium voluum deleniti atque.

Melbourne, Australia
(Sat - Thursday)
(10am - 05 pm)
 
AE Live Chat

Привет, меня зовут Антон. Чем могу помочь?