Содержание
10 лучших инструментов для тестирования API / Хабр
10 лучших инструментальных средств тестирования интерфейсов прикладного программирования 2018 года.
Интерес к тестированию неудержимо растёт на протяжении нескольких последних лет, согласно исследованиям Google Trends. Опрос, проведенный компанией Smartbear в 2017 году среди 5000 профессионалов в области разработки программного обеспечения, показал, что более 50% опрошенных респондентов используют автоматические средства тестирования API, и ожидается рост их количества на 30% ( с 59% до 77%) в течении следующих двух лет, причем 80% участников опроса указали, что отвечают за тестирование API.
Наличие правильных процессов, инструментов и технических решений для автоматических тестирований API становится важным, как никогда ранее. И с помощью тенденции shift-left, тестирование API становится больше, чем просто решение по контролю за качеством, теперь это критически важный компонент успешной непрерывной интеграции и развёртывания программного обеспечения.
В данной статье предоставлен обзор лучших средств тестирования API, как с открытым доступом, так и коммерческих решений, из которых команды тестировщиков могут выбрать наиболее подходящие для себя.
buy reddit upvotes
5 лучших средств тестирования API в 2018 году
1. SoapUI
SoapUI представляет собой консольный инструмент, предназначенный для тестирования API и позволяющий пользователям легко тестировать API REST и SOAP, а также Web-сервисы.
При помощи SoapUI, пользователи могут получить полный исходный документ и встроить предпочтительный набор функций, в дополнение к перечисленным ниже:
- Создать тест легко и быстро при помощи технологий перетаскивания объектов «мышкой» (Drag and drop) и метода «указания и щелчка» (Point-and-click)
- Быстро создать пользовательский код при помощи Groovy
- Мощное тестирование на основе данных: Данные загружаются из файлов, баз данных и Excel, поэтому они могут создать симуляцию взаимодействия пользователя и API.
- Создание комплексных сценариев и поддержка асинхронного тестирования
- Повторное использование скриптов: загрузка тестов и сканирование безопасности могут повторно использоваться в случае функционального тестирования всего в несколько шагов
Веб-сайт: https://www.soapui.org/
Цена: Бесплатно — 659$/год EPDM
2. Postman
Будучи изначально плагином браузера Chrome, теперь Postman расширяет свои технические решения вместе с оригинальными версиями как для Mac, так и для Windows.
Postman является отличным выбором API тестирования для тех, кто не желает иметь дела с кодировками в интегрированной среде разработки, используя тот же язык программирования, что и разработчик.
- Легкий в использовании клиент REST
- Богатый интерфейс делает этот инструмент простым и удобным в использовании
- Может использоваться как при автоматическом, так и при исследовательском тестировании
- Работает в приложениях для Mac, Windows, Linux и Chrome
- Обладает пакетом средств интеграции, таких как поддержка форматов Swagger и RAML
- Обладает функциями Run, Test, Document и Monitoring
- Не требует изучения нового языка программирования
- Позволяет пользователям легко делиться опытом и знаниями с другими членами команды, поскольку позволяет упаковывать все запросы и ожидаемые ответы и отправлять их коллегам.
Веб-сайт: https://www.getpostman.com/
Цена: Бесплатно — 21$/ с пользователя в месяц
3. Katalon Studio
Katalon Studio является бесплатным инструментом автоматического тестирования, предоставляющим общую среду для создания и выполнения UI функционала, служб API/Web и тестирования мобильных платформ.
Способность комбинировать уровни UI и Business (службы API/Web) для различных операционных сред (Windows, Mac OS, Linux) расценивается как значительное преимущество Katalon Studio перед аналогичными продуктами.
Katalon Studio поддерживает запросы SOAP и RESTful с различными типами команд (GET, POST, PUT, DELETE) с параметризованными возможностями.
Основные свойства:
- Поддержка теста комбинации между верификациями UI и API.
- Поддержка тестирования запросов как SOAP, так и RESTful.
- Сотни встроенных ключей для создания тестовых заданий.
- Поддержка одной из самых мощных библиотеки проверки утверждений AssertJ для создания динамических утверждений в BDD-стиле.
- Поддержка подхода, управляемого данными.
- Может использоваться как при автоматическом, так и при исследовательском тестировании.
- Отлично подходит как для профессионалов, так и для новичков
Веб-сайт: https://www.katalon.com
Цена: Бесплатный
4. Tricentis Tosca
Tricentis Tosca представляет собой платформу непрерывного тестирования для Agile и DevOps. Среди преимуществ Tricentis Tosca следует отметить:
- Поддержку многих массивов протоколов: HTTP(s) JMS, AMQP, Rabbit MQ, TIBCO EMS, SOAP, REST, IBM MQ, NET TCP
- Интеграцию в циклы Agile и DevOps
- Максимизацию многократного использования и способность к сопровождению средств автоматизации тестирования на основе использования моделей
- Тесты API могут использоваться как на мобильных, так на браузерных и пакетных приложениях и т. д.
- Достигнута автоматизация, поддерживаемая новыми технологиями
- Снижено время, необходимое на проведение регрессивного тестирования
Веб-сайт: https://www.tricentis.com/
Цена: Уточняйте у продавца
5. Apigee
Apigee является кросс-«облачным» средством тестирования API, позволяющим пользователям измерять и тестировать производительность API, обеспечивать техническую поддержку и разработку API при помощи других редакторов, таких как Swagger.
- Данный инструмент является многошаговым и находится под управлением Javascript
- Он позволяет разрабатывать, отслеживать, выполнять разворачивание и масштабирование API
- Идентифицирует проблемы путем отслеживания трафика API, уровня ошибок и времени ответа
- Легко создает прокси API из Open API Specification и выполняет их развертку в «облаке»
- Модели разворачивания в «облаке», локального разворачивания и гибридного разворачивания работают на основе одного кода
- PCI, HIPAA, SOC2, и PII для приложений и API
- Apigee разработан специально для цифрового бизнеса и задач с интенсивной обработкой данных на под управлением мобильных платформ API и приложений, которые управляют ним.
Веб-сайт: https://apigee.com/api-management/
Цена: Бесплатный пробный период — 2 500$/месяц
6. JMeter
JMeter (открытое программное обеспечение) широко используется для функционального тестирования API, однако изначально он создавался для нагрузочного тестирования.
- Поддерживает воспроизведение результатов тестирования
- Автоматически работает с файлами CSV, позволяя команде быстро создавать уникальные значения параметров для тестирования API.
- Благодаря интеграции между JMeter и Jenkins, пользователи могут включать тесты API в конвейерные обработки CI
- Данный инструмент может использоваться как для статического, так и динамического тестирования производительности ресурсов
Веб-сайт: https://jmeter.apache.org/
Цена: Открытое программное обеспечение
7. Rest-Assured
Rest-Assured является общедоступным предметно-ориентированным Java-языком, который делает службу тестирования REST более простой и удобной.
- Обладает целым набором встроенных функционалов, наличие которых означает, что пользователю не придется кодировать заново.
- Надежно интегрирован со автоматизированной платформой Serenity, что позволяет пользователям комбинировать тесты UI и REST в рамках одной платформы и получать изумительные результаты.
- Поддерживает синтаксические конструкции BDD Given/When/Then
- Пользователям необязательно быть экспертами в области HTTP
Веб-сайт: http://rest-assured.io/
Цена: Открытое программное обеспечение
8. Assertible
Assertible представляет собой инструмент тестирования API, который в первую очередь акцентируется на автоматизации процессов и надежности.
- Обеспечивает автоматическое тестирование API на каждом этапе процесса интеграции и поставки программного обеспечения.
- Осуществляет поддержку текущих тестов API после внедрения приложений и интегрирует их с привычными инструментами, такими как GitHub, Slack, и Zapier.
- Поддерживает проверку подлинности ответов HTTP при помощи готовых операторов подтверждения отсутствия ошибок, таких как проверка достоверности JSON Schema и проверка целостности данных JSON Path
Веб-сайт: https://assertible.com/
Цена: Бесплатный — 500$/месяц
9. Karate DSL
Karate DSL это новый инструмент для тестирования API, который помогает разрабатывать сценарии для BDD тестов на основе API простым способом, без написания характеристик этапов. Эти характеристики создаются самим KarateDSL, а поэтому пользователи могут запустить тестирование API легко и быстро.
- Встроен на вершине Cucumber-JVM
- Способен запускать тестирование и генерировать отчеты как любой другой стандартный проект Java
- Тест может быть разработан без обязательного владения знаниями языка Java
- Тесты могут легко создаваться даже непрограммистами
- Поддерживает конфигурацию продвижения /переключения, а также многопотоковое параллельное выполнение кода
Веб-сайт: https://github. com/intuit/karate
Цена: Открытое программное обеспечение
10. Ни одно решение не может совместить все инструменты
Это больно осознавать, однако, это правда!
Мы верим, что приведенный выше список представляет наилучшие решения, доступные на текущий момент, если Вы решили использовать автоматическое тестирование API. Однако, как и в случае с большинством продуктов в данной сфере, найти один инструмент, который совмещает все указанные функции, практически невозможно.
Некоторые могут посчитать, что свойств коммерческих продуктов (Postman, Tricentis Tosca,…) будет достаточно, однако цена вопроса будет служить серьезным сдерживающим фактором. Бесплатные и общедоступные решения (Rest-Assured, Karate DSL,…) являются довольно-таки приемлемыми, но требуют квалифицированных умений и много усилий для имплементации правильной платформы. Инструменты, которые удерживают баланс между ценой и другими факторами (Katalon Studio, Postman), могут иметь недостатки для некоторых типов проектов, и эти недостатки требуют пристальной оценки.
Тестирование API создало свой собственный тренд в области автоматического тестирования, и чем дальше, тем больше инструментов будет создаваться для удовлетворения растущих запросов от команд разработки программного обеспечения. Найти идеальный инструмент по-прежнему сложно, но у нас есть и хорошие новости — теперь Ваш выбор стал намного шире, чем был раньше. Тщательно обдумайте Ваши требования, взвесьте все «за» и «против» каждого решения — постарайтесь быть не слишком придирчивым на ранних стадиях и попробуйте 5 лучших кандидатов из нашего списка. Когда Вы создадите список всех «за» и «против» для этих решений, Вы получите более адекватную картину критических факторов Вашего проекта и сможете отредактировать список инструментов. Данный подход предоставит Вам хорошую возможность идентифицировать подходящий инструмент для текущего этапа и информацию о следующем инструменте, когда Ваши проекты станут более комплексными, сложными и опытными.
Мне было бы очень приятно услышать Ваши отзывы, поэтому — если Вы знаете другие инструменты, которые могут использоваться для аналогичных целей — буду признателен за Ваш вклад в исследование темы.
Как выбрать инструмент для тестирования API / Хабр
В список требований, предъявляемых к QA-специалистам, включают умение тестировать API приложений.
Обращения к API помогают оптимизировать процесс тестирования: сократить время на проведение, расширить покрытие кейсами, минимизировать зависимость от внешних систем, например, клиентской части приложения. Кроме того, обращения к эндпойнтам позволяют проверить тестовые случаи, которые невозможно воспроизвести, используя только графический интерфейс.
Чтобы выбрать инструмент для тестирования API на своем проекте, вам нужно четко представлять свои цели, объект и результат, который хотите получить. Неправильно выбранный инструмент может привести к увеличению трудоемкости и затягиванию процесса тестирования, а также к пропуску багов.
В этом материале мы рассмотрим наиболее распространенные виды API, выделим их характерные особенности, а также разберем популярные инструменты для тестирования API и опишем применение на практике. Изучив этот материал, вы сможете выбрать наиболее подходящий инструмент и использовать его на своем проекте.
Что такое API
API (Application Programming Interface) – это программный интерфейс приложений. Чтобы понять, как он работает, возьмем классический пример: клиент и сервер. API можно представить как рычаги, протянутые с сервера на клиент. Благодаря им клиент может воспользоваться функциями, реализованными на сервере. То есть API – это интерфейс, с помощью которого одна система может связываться с другой.
Рассмотрим характерные особенности Web-API, наиболее распространенных в настоящее время: SOAP, REST и gRPC.
SOAP API
Первоначально предназначался преимущественно для удаленного вызова процедур. Сейчас протокол используется также для обмена произвольными сообщениями в формате XML. Основная отличительная черта SOAP API в том, что вся информация передается в XML-сообщениях между клиентом и сервером.
SOAP может использоваться с любым протоколом прикладного уровня: SMTP, FTP, HTTP, HTTPS и другими. Однако взаимодействие с каждым имеет свои особенности. Например, в случае реализации с помощью HTTP/HTTPS применяется только метод POST. Одним из ключевых понятий в данном типе API является файл WSDL, включающий себя описание методов тестируемого сервиса. Импортируя такой файл, вы получаете список готовых обращений к эндпойтам.
REST API
Архитектурный стиль сетевого взаимодействия компонентов распределенного приложения. Впервые термин был использован в 2000 году одним из создателей НТТР. Сам по себе REST не является протоколом. Это набор правил того, как разработчику организовать написание кода серверного приложения, чтобы все системы эффективно обменивались данными, и приложение можно было масштабировать.
В стиле REST можно выделить несколько характерных особенностей:
Привязка к методам HTTP и, соответственно, использование только этого протокола для передачи данных.
Использование различных форматов для передачи данных, таких как JSON, XML, HTML. Наиболее часто используется JSON ввиду его легкости, простоты и человекочитаемости.
gRPC
Система удаленного вызова процедур, разработанная компанией Google в 2015 году. В качестве транспорта gRPC использует протокол HTTP v2. Чаще всего gRPC помогает организовать взаимодействие в микросервисной архитектуре. Реализация общения через gRPC происходит следующим образом: клиентское приложение может напрямую вызвать метод серверного приложения так же, как если бы это был локальный метод клиента.
Отличительная черта реализации приложений с помощью gRPC API — наличие компонента gRPC STUB. Это модуль, который конвертирует данные из человекочитаемых в бинарные файлы и передает их между клиентом и сервером. Еще одна неотъемлемая часть gRPC API это .proto файл – описание того, какие методы есть в приложении, и взаимосвязь между запросом и ответом.
Познакомившись с примерами реализации API, становится понятно, что они представляет собой структуру вида «запрос — ответ». В запросе нужно передавать некоторые параметры, в ответ на которые приходят соответствующие данные.
Инструменты для тестирования API
Существуют десятки различных инструментов, с помощью которых тестируют API. Все их можно разделить по уровню освоения на простые, средние и сложные. Чтобы их сравнить, сформулируем основные критерии.
Принципиальная возможность обратиться к эндпойнтам приложения.
Возможность отправить свои собственные параметры запроса.
Способность хранить тест-кейсы.
Быстрота написания тестов.
Скорость освоения инструмента.
Возможности автоматизации проверки ожидаемых результатов.
Дополнительные возможности автоматизации тестирования.
Возможности использования переменных окружения.
Способность использовать мок-сервисы, заглушки и т. д.
Особенности запуска готовых тестов.
Интеграция с системами CI/CD.
Дополнительный функционал, облегчающий тестирование.
Сваггероподобные системы
Это инструменты простого уровня — Swagger UI, Яндекс Полигон, а также прочие внутрипроектные интерактивные виды документации API.
В стандартный функционал сваггероподобных систем входят: отправка запросов, просмотр ответов, возможность посмотреть готовые примеры запросов и ответов, варианты авторизации, возможность экспорта ответа в файл и генерация cURL запроса.
Плюсы сваггероподобных систем:
Это, как правило, полностью готовые инструменты, в которых уже созданы все обращения к эндпойнтам, тела запросов и другие параметры.
Они очень быстры и просты в освоении и использовании из-за элементарного функционала.
Содержат примеры ответов и описание приходящих в них параметров.
Не требуют установки на устройство пользователя, они уже развернуты на стенде.
Генерируют cURL, который можно приложить к баг-репорту, чтобы разработчик мог быстрее воспроизвести баг и исправить его.
Минусы сваггероподобных систем:
Они хранят только заранее прописанные разработчиком параметры запросов, которые могут быть избыточными или наоборот, неполными.
Нельзя сохранять свои параметры запросов. То есть после обновления страницы сваггероподобной системы пропадет все, что вы туда ввели. Таким образом, параметры запросов, использующиеся в тест-кейсах, придется хранить в отдельных документах, а это неудобно.
Нельзя создавать коллекции запросов, так как невозможно сохранять свои варианты запросов.
Нельзя создавать скрипты-проверки, ожидаемый результат с фактическим придется сверять глазами/руками.
Невозможны прогоны, то есть автоматизированный последовательный запуск запросов.
Нельзя создавать и использовать никакие окружения, переменные.
Полезность описаний в сваггероподобных системах очень разнится от проекта к проекту.
Когда выбирать сваггероподобные системы? Так как это не инструмент тестирования, а интерактивная документация по API, такие системы чаще используются для ознакомления с эндпойнтами и исследовательских проверок. В остальных случаях использовать сваггероподобные системы не рекомендуется, разве что вы работаете на специфическом проекте, и другие инструменты использовать невозможно. Например, закрытый проект, где вы работаете на виртуальных машинах и удаленных рабочих столах, и при этом нет возможности установить никакой из API-клиентов. Тогда все, что вы можете — использовать Swagger или подобную систему, чтобы тестировать эндпойнты сервиса.
API-клиенты
Инструменты среднего уровня сложности. Это, как правило, десктопные приложения, которые позволяют обратиться к эндпойнтам. Также они предоставляют дополнительные возможности — использование переменных, рандомайзеров, скриптов и других функций.
Insomnia
При открытии Insomnia мы видим главную страницу, на которой можно настроить само приложение и свой аккаунт, меню создания проектов, а также список уже созданных. Добавить новый проект можно различными способами: импортирование из локального файла, «подтягивание» с внешнего ресурса по URL, копирование API проекта из Git.
При открытии проекта становится доступным функционал добавления новых и список созданных запросов. Окно запроса дает возможность вводить и сохранять отправляемые параметры. Посмотреть и сохранить в качестве примера приходящий ответ можно в окне справа.
Insomnia поддерживает широкий набор возможностей для обращений к различным API: набор методов HTTP/s, обращения к gRPC API, а также кастомные методы со своими параметрами. Вариантов форматов передаваемых сообщений тоже много: JSON, XML, YAML, EDN, бинарные файлы, GraphQL Query.
Важная особенность Insomnia — возможность создавать переменные окружения, которые будут подтягиваться или автоматически генерироваться в зависимости от настройки. Значения из переменных можно использовать в тестах, чтобы автоматизировать их и упростить себе работу.
На странице проекта во вкладке “Test” добавляются проверки к отправляемым запросам, сравнивающие пришедший ответ с ожидаемым результатом. Запрос с добавленными проверками называется Тестом. Несколько запросов можно объединить в Тест-сьют.
Insomnia поддерживает возможность запускать тесты списками с помощью раннера. При этом отображаются отправляемые запросы и результаты проверок
Плюсы Insomnia:
Легкий в освоении интерфейс относительно других подобных API-клиентов.
Кроссплатформенность.
Возможность загрузки проектов из Swagger. Можем по URL импортировать проект, и у нас появятся все те же списки с описаниями, как это было в Swagger.
Возможность настройки окружения.
Возможность создавать динамические переменные.
Возможность создавать и прогонять тест-кейсы.
Возможность поддержки версионности кейсов с подключением их к Git.
Возможность тестирования разных API, таких как REST, SOAP, gRPC, GraphQL и другие.
Минусы Insomnia:
Создание тест-кейсов из нескольких запросов затруднено. Если тест-кейс состоит из нескольких последовательных шагов/запросов, то он будет обозначаться как тест-сьют, соответственно, построить иерархию кейсов сложно из-за одного уровня вложенности (папка (тест-сьют) – запрос).
Невозможен параллельный запуск запросов и кейсов.
Настройка переменных окружения сложная относительно других API-клиентов.
Небольшой выбор встроенных скриптов-рандомайзеров по сравнению с другими инструментами.
Нет встроенного списка проверок к ответам.
Используйте Insomnia, когда нужно тестировать разные виды API, использовать окружения, переменные, скрипты, и при этом функции Postman для вас избыточны. Или если вам нужен удобный API-клиент для тестирования gRPC.
Postman
Очень популярный API-клиент. Хоть его интерфейс и пугает насыщенностью, разобраться в нем достаточно просто. На домашней странице предлагается выбрать рабочее пространство. Это своеобразная «папка», в которую добавляются коллекции запросов, окружения, переменные, мок-заглушки и другое. Такое разделение очень удобно, если у вас есть несколько тестируемых проектов или сервисов.
В каждом рабочем пространстве есть:
список коллекций, расположенный в окне “Collections”;
документация API, сюда можно импортировать Swagger;
окно, в котором редактируются окружение и переменные;
функционал создания мок-заглушек.
«монитор» — функция, позволяющая по таймеру запускать коллекции запросов. Причем это можно делать облачно, без необходимости держать свой компьютер включенным.
Окно запроса состоит из поля для указания HTTP-метода и URL запроса, настройки параметров (заголовки и тело), Pre-request Script — скриптов, которые будут исполняться до отправки сообщения, Tests — кода, который будет исполняться после выполнения запроса.
Оранжевым цветом выделяются переменные в Postman. Они бывают автоматически генерируемые (имя начинается с $, например, $randomInt — генерирует рандомное число) и созданные пользователем (куда можно записать все что угодно).
В данном случае создается переменная ‘CreateTime’ в которую записывается время, генерируемое с помощью JS в Pre-request Script.
Во вкладке Test мы видим код, который сверяет ожидаемый и фактический результат. Проверки в Postman начинаются с конструкции ‘pm.test”. Первым тестом мы проверяем статус-код. Если он равен 200, то во вкладке Test results в ответе появится сообщение “Status code is 200”. Второй тест — проверка id животного. Видим, что в ответе пришел именно тот id животного, которое мы создавали, то есть сверяем со значением из переменной окружения.
Также во вкладку Test можно добавить код, выполняющий любые действия — например, достающий из ответа значение, которое хранится в произвольном поле, и передающий его в переменную окружения.
Плюсы Postman:
Относительно простой интерфейс.
Возможность подключения в Swagger.
Возможность создавать рабочие пространства и коллекции.
Поддержка мок-серверов и прогонов коллекций (ручные и периодические).
Отдельный компонент-перехватчик запросов.
Окружения, переменные и возможность их настраивать, создавать, редактировать.
Возможность тестирования разных видов API, таких как REST, SOAP и т.д.
Поддержка интеграции с Git.
Очень много встроенных скриптов-рандомайзеров.
Возможность написания кастомных скриптов проверок с помощью языка JavaScript.
Очень много встроенных вариантов проверок в сниппетах.
Возможность написания кастомных проверок с помощью JS.
Возможность запускать коллекции из командной строки с помощью инструмента-компаньона Newman.
Возможность интеграции Newman с системами непрерывной сборки. Например, мы можем создать коллекцию в Postman, она передается Newman, интегрируется с системами непрерывной сборки, и Newman запускает эту коллекцию при обновлении версии стенда, приложения или в других подобных ситуациях.
Минусы Postman:
Коллекции и окружения к ним экспортируются отдельно.
Невозможен параллельный запуск кейсов в Postman. Например, вы тестируете асинхронный сервис и есть некий этап ожидания между созданием задания и получением на него результата. В этом случае лучше, чтобы ваш инструмент тестирования позволял запускать проверки параллельно и ждать результата в каждом случае по отдельности. Иначе вы будете ждать их очень долго, особенно когда много тест-кейсов. Прогон такой коллекции будет растянутым.
Раннер, который последовательно запускает запросы, видит именно список запросов, а не кейсы. Это несет в себе риски, когда кейс состоит из нескольких запросов. Например, папка представляет собой тест-кейс. У вас десять папок, в которых десять тест-кейсов, и в каждом по два-три шага. Когда запускаете раннер, вам видны 30 последовательных запросов. Поэтому в некоторых запросах в разных тест-кейсах вам нужно писать скрипты, которые в случае провала автоматически очистят некоторые переменные от своих значений. Тогда следующий кейс пройдет без ошибок и там не останется значений, которые не воспринимаются следующим кейсом. Это влияет на независимость тест-кейсов друг от друга.
Postman следует использовать, когда вам нужен удобный и мощный API-клиент для тестирования разных видов API с возможностью использовать продвинутые переменные и скрипты в запросах. При этом не важен параллельный запуск кейсов в вашем проекте и вы понимаете особенности построения кейсов из нескольких запросов.
SOAPUI
Первоначально был создан для тестирования SOAP сервисов, но впоследствии стал применяться и для REST API. Инструмент позволяет создавать и импортировать проекты, в нем есть меню работы с тест-кейсами, список всех проектов и меню действий над текущим.
При открытии проекта становится доступным список всех запросов, существующих в вашем сервисе, и список тест-кейсов. Это одна из отличительных черт SOAPUI — запросы в библиотеке и тесты существуют отдельно. То есть мы описали 15 запросов, а потом можем в любых комбинациях использовать их в тестах, ставить в разном порядке в зависимости от потребности.
Тест-сьюты состоят из тест-кейсов, а тест-кейсы — из шагов. Шаги могут быть как запросами, так и служебными действиями.
Запросы настраиваются в отдельном окне, где можно добавить и сохранить передаваемые данные, отправить запрос, посмотреть ответ на него, а также прикрепить проверки ожидаемого результата (в данном случае проверки Contains).
К служебным действиям относятся, например, таблицы с тестовыми данными (testdata), которые будут с помощью переменных подтягиваться в запросы. Таблицы имеют простую структуру “name-value”, причем value может быть не только статическим, но и генерироваться скриптом.
Еще одним видом служебных действий являются шаги трансфера (Transfer mail), выполняющие передачу данных между запросами, либо между запросом и таблицей с данными. Структура передачи также простая “source-target ”. Единственная особенность тут: грамотно указать с помощью языка парсинга поля обмена данными.
Интуитивно понятный функционал запуска тест-кейсов состоит из: кнопки «старт/стоп» и переключателя последовательного или параллельного запуска проверок. При нажатии на кнопку “Start” показывается список запущенных кейсов, а также результат их прохождения. Открыв проваленный кейс можно увидеть на каком шаге он «упал» и почему (в данном примере — потому что нет значения, который передается в “mail”). При этом следующий шаг не запускался, и это одна из особенностей SOAPUI. Он видит именно тест-кейсы, а не список шагов. Если какой-то шаг в тест-кейсе провалился, то остальные шаги он не запускает и переходит далее. Следующие кейсы работают только с переменными, скриптами и тестовыми данными внутри них самих, не видя переменные из других кейсов.
Настройка последовательного или параллельного запуска кейсов «из коробки» — это также отличительная особенность SOAPUI. Во многих случаях это сильно экономит ваше время.
Плюсы SOAPUI:
Возможность создания проектов с помощью Swagger (для REST API) и файлов WSDL (для SOAP API).
Возможность тестировать REST и SOAP.
Легкий экспорт и импорт проектов одним файлом. То есть вы экспортируете этот файл один раз, передаете коллеге, он устанавливает его и импортирует себе. Нет необходимости переносить отдельно переменные, окружение и сами запросы, как в Postman.
Возможность использовать окружения и переменные.
Возможность написания кастомных скриптов для проверки ожидаемого и фактического результата.
Встроенные варианты проверок.
Параллельный запуск кейсов, что очень важно.
Раннер видит именно список кейсов, а не список запросов и список шагов в них.
Можно сделать нагрузочные тесты.
Можно написать мок-заглушки.
Eсть возможность использовать функционал прокси.
Минусы SOAPUI:
Сложный интерфейс относительно предыдущих API-клиентов.
Не поддерживает gRPC и GraphQL в бесплатной версии.
Не поддерживает интеграцию с Git в бесплатной версии.
Не поддерживает интеграцию с системами непрерывной сборки в бесплатной версии.
SOAPUI подойдет, если у вас есть много тест-кейсов из нескольких запросов, а также нужен параллельный запуск этих кейсов. Когда у вас есть кейсы с вилкой результатов. Если на проекте нет потребности тестировать API кроме REST и SOAP. Когда вам не обязательно интегрировать тесты с системами непрерывной сборки.
Библиотеки. Rest Assured
Библиотеки это не самостоятельные инструменты, они написаны для использования внутри языков программирования. Так как на рассмотрение большого количества существующих библиотек тестирования API уйдет много времени. Рассмотрим их типичный функционал на примере популярной Rest Assured.
Так выглядит тест, написанный с использованием Rest Assured. С помощью public void объявляется тест “whenCreatePerson_thenStatus201” в given() задаются предварительные условия запроса, блок when() отправляет запрос к эндпойнту, а в then() происходит сверка ожидаемого и фактического результата. В данном примере проверяется, что при успешном создании пользователя приходит статус-код 201 (Created).
Следующий тест чуть более сложный: здесь обновляется предварительно созданный пользователь. При этом проверяются два ожидания: на статус-код 200 и в теле поле “name” будет иметь значение “Michail”.
Плюсы Rest Assured:
Полная интеграция с системами CI/CD и возможность автоматически запускать проверки при появлении новой версии приложения на стенде.
Возможность подключить инструмент Allure Reporting для автоматизированного формирования отчетов о тестировании.
Возможность реализовать практически любые проверки, которые можете написать сами, и практически любые предзапросные скрипты.
Скорость работы тестов, написанных с помощью библиотек, и в частности Rest Assured, быстрее, чем у API-клиентов.
Минусы Rest Assured:
Нужно уметь писать код, причем хорошо. Rest Assured использует язык Java. Первый тест из учебника написать не сложно, но создать тесты которые действительно принесут пользу вашему проекту — это не так просто.
Официальные туториалы для фреймворков и библиотек подходят только для мелких проектов либо для написания тестов а-ля “Hello, world!”. Наилучшие паттерны написания кейсов придется искать самостоятельно по форумам и другим источникам.
Фреймворки стоит выбирать, если вы уже умеете хорошо писать код или твердо намерены прокачаться в этом деле. Когда хотите глубокой автоматизации и интеграции кейсов с CI/CD. Если в кейсах много логик, для которых нужны сложные скрипты. Если для вашего проекта важно увеличение скорости повторного тестирования, в первую очередь — регрессионного.
Сравнение реального использования инструментов
На проекте автора статьи последовательно вводилось использование инструментов тестирования API.
Сервис назовем условно «Квартет», так как он включает в себя 4 микросервиса. Тип работы — асинхронный. На данном проекте произошла последовательная смена инструментов “Postman — SOAPUI — Rest assured”. Swagger присутствует, но для тестирования он не использовался, так как прохождение кейсов с его помощью, в нашем сервисе, не сильно быстрее использования графического интерфейса. Прохождение кейсов с помощью GUI возьмем за начальную точку сравнения.
Написание каждого тест-кейса заняло 6 минут. 200 кейсов — это 1200 минут или 20 часов. Ручной прогон каждого end to end кейса в среднем занимает 4 минуты с учетом скорости работы фронта, бэка и QA специалиста. 200 кейсов это 800 минут или 13,5 часов.
То есть, если проводить регресс вручную, на это каждый раз будет уходить 13-14 часов. И это без учета времени на баг-репорты, без поправки на усталость специалиста и так далее. Конечно же, такое время неприемлемо в условиях ограниченной QA-команды.
Первым используемым инструментом стал Postman. Скорость погружения в инструмент с момента установки до написания первого кейса, который можно реально использовать — 2 часа. Время на создание первого полностью автоматизированного кейса, который ждет построения файла, проверяет ожидаемый результат и т.д. — 8 часов. То есть освоение инструмента заняло 10 часов. После этого написание и отладка кейсов стали занимать по 10 минут в среднем, то есть на 200 кейсов ушло 34 часа.
Автоматизированное прохождение такого кейса в Postman занимает 50 секунд, то есть 200 кейсов проходят за 2 часа 47 минут. Вроде бы все хорошо, но из за особенностей работы системы, 50 секунд уходит только на успешный кейс, а на неуспешный — до 30 минут. Если проваливаться будут все 200, то такое прохождение займет до 100 часов. Конечно, такого никогда не случалось, но теоретическая возможность такого сценария заставляла искать инструмент с параллельным запуском кейсов. Тем более, что сам сервис мог обрабатывать результаты параллельно.
Им стал SOAPUI. Время погружения в инструмент с установки до написания первого полезного кейса составило 3 часа. Пилотный автоматизированный кейс был написан за 10 часов. 200 кейсов в SOAP UI были написаны за 44 часа. Да, делать тест-кейсы в этом инструменте немного дольше из-за своеобразного интерфейса. Но параллельный запуск полностью окупает этот недостаток. Кейсы запускались порциями по 100 и с учетом особенностей работы сервиса это давало 18 минут на порцию в случае успешного прохождения и 46 минут при неуспешном. То есть 200 успешных кейсов проходили за 36-37 минут, 200 неуспешных — 1 час 32 минуты. Это был успех, который позволил не следить за прогоном, чтобы вовремя остановить его при нескольких неуспешных кейсах подряд. Но SOAPUI не хватает отчетности о тестировании, а главное — нет интеграции с CI/CD, а этого очень хотелось.
Поэтому перешли на Rest Assured в связке с JUnit 5. Погружение заняло 10 часов, еще 11 на написание пилотного кейса. 200 кейсов были созданы за 42 часа. JUnit умеет запускать кейсы параллельно, поэтому запускали теми же порциями по 100, что в итоге дало прохождение 200 успешных кейсов за 35 минут в среднем, неуспешных — за 1 час 29 минут. С виду ускорение незначительное, но не стоит забывать, что появилась отчетность о каждом прогоне и главное — кейсы автоматически запускались при срабатывании определенного триггера. Регресс стал полностью автоматизированным.
Заключение
Мы рассмотрели наиболее распространенные Web-API и инструменты для тестирования разных уровней: от специфичных сваггероподобных систем до библиотек языков программирования. Несмотря на то, что фреймворки и библиотеки кажутся панацеей, это не так. Из приведенного примера внедрения видно — чем «способнее» инструмент, тем он сложнее и дольше в освоении. Выбор решения для тестирования API должен совершаться, исходя из конкретных потребностей проекта. Так, если интеграция с CI/CD не особа нужна, плюс в команде нет специалистов должного уровня, то не надо гнаться за фреймворками, достаточно выбрать подходящий API-клиент.
Лучший инструмент не совершеннее других, а полезнее.
Спасибо за внимание! Полезные материалы для QA-специалистов мы также публикуем в наших соцсетях – ВК и Telegram.
Найдите свою экспериментальную программу за границей, учебу, стажировку или стажировку
Учитесь через
Начните свое практическое обучение с API и начните свой личный и профессиональный рост.
Find My Program
Обучайтесь через
Начните свое практическое обучение с помощью API и начните свой личный и профессиональный рост.
Найти мою программу
Знакомство с Испанией с API
На всех этапах жизненного пути
У нас есть программы для студентов практически на каждом этапе.
Узнать больше
Наши магистерские программы или стажировки помогут вам продвинуться по карьерной лестнице.
Подробнее
Учитесь на собственном опыте и получайте от этого удовольствие!
Подробнее
Рассмотрите дополнительные программы, которые могут быть вам полезны на данном этапе.
Подробнее
на всех этапах эмпирического путешествия
Все те, кто делает возможным
Наш подход к партнерству, основанный на отношениях, означает, что вместе мы можем сделать больше.
Узнать больше
Нужна помощь в выборе нужной программы для учащихся? Мы можем помочь!
Подробнее
Создайте свою собственную программу без риска и неопределенности. Мы можем помочь!
Узнать больше
Мы знаем, что вас больше всего беспокоит, потому что наши основатели тоже являются родителями.
Узнать больше
b3lineicon|b3icon-bulb-gear||Bulb Gear
Обучение в первую очередь
Получите образование, в котором культура не менее академична.
Подробнее
b3lineicon|b3icon-shield-law||Shield Law
Безопасность
Здоровье, безопасность и благополучие наших учеников имеют первостепенное значение.
Узнать больше
b3lineicon|b3icon-briefcase||Briefcase
The Resume Edge
Получите навыки межличностного общения, которые отчаянно нужны работодателям, а затем продемонстрируйте их с помощью нашей программы цифровых значков.
Подробнее
b3lineicon|b3icon-users-group||Группа пользователей
DEI
Независимо от того, кто вы и откуда, API поддерживает вас.
Узнать больше
b3lineicon|b3icon-money-bag||Money Bag
Доступность
API предлагает наиболее инклюзивные культурные возможности по доступной цене.
Подробнее
b3lineicon|b3icon-rocket||Rocket
Практический опыт
Самый быстрый способ ускорить обучение и продвинуться по карьерной лестнице — получить опыт.
Подробнее
b3lineicon|b3icon-browser-search-user||Поиск в браузере Пользователь
APIConnect
Эта революционная платформа обеспечивает ясность и гибкость, необходимые всем пользователям.
Узнать больше
b3lineicon|b3icon-map-pin||Пин-код карты
Мы местные
API имеет глобальную сеть местных сотрудников для всех наших программ.
Узнать больше
Типы программ
Зарабатывайте необходимые кредиты в университетах по всему миру!
Узнать больше
Подготовка к учебе за границей, получение критических кредитов или обучение онлайн за границей.
Подробнее
Не знаете, чем заняться после школы? Все еще в старшей школе и хотите некоторые варианты?
Узнать больше
Готов к получению
Найдите доступные варианты программы и классы, которые включены. Ищите, сортируйте, фильтруйте и сравнивайте варианты.
Найти мою программу
Найти мой курс
Узнать больше
Управление согласием
Программы обучения за рубежом по всему миру
Поступайте в престижные университеты по всему миру, пройдите курсы практически по любой области обучения и погрузитесь в язык, образ жизни и культуру другой страны.
Find My Program
Почему обучение за границей окупается
b3lineicon|b3icon-money-bag||Money Bag
Расширьте свое понимание мира и приобретите навыки и опыт, которые ценят работодатели. Выделите свое резюме среди аналогов, расширьте свои возможности трудоустройства, повысьте свои шансы на более быстрое трудоустройство и ваши шансы на более высокую начальную зарплату .
b3lineicon|b3icon-user-talk-2||User Talk 2
Изучайте новый язык или совершенствуйте свои языковые навыки, живя в новой стране и ориентируясь в ней, или участвуя в активном диалоге в интегрированном классе с другими учащимися. Постоянные директора API также поддерживают вас посредством разговорной практики и обучения. Способность говорить более чем на одном языке открывает двери для трудоустройства , так как потенциальные работодатели ценят многоязычие и способность общаться с людьми разного культурного и языкового происхождения.
b3lineicon|b3icon-presentation||Presentation
Почувствуйте возможность исследовать новую принимающую страну и посетить близлежащие города, получая при этом поддержку от директоров-резидентов API, которые помогут с любой возникающей потребностью. Ваша вновь обретенная уверенность будет легко узнаваема будущими работодателями и поможет вам пройти более сильных интервью.
b3lineicon|b3icon-desk-globe||Desk Globe
Взаимодействуйте напрямую с мировым сообществом, изменяя свое мировоззрение и формируя новые глобальные связи, которые разрушают барьеры и способствуют взаимопониманию. Более того, вы освоите навыки, имеющие практическое применение, такие как ценность командной работы и реальное влияние, которое доброжелательность и координация могут оказать на местное сообщество. Этих навыков и компетенций будет ценят и ценят будущие работодатели, аспиранты и не только.
Ответы на самые распространенные вопросы
b3lineicon|b3icon-university||Университет
Узнать больше
Не существует единого способа принять решение, и ни одно решение не является неправильным. Вы можете начать с определения того, что вы хотите изучать, а затем, где и когда эти курсы предлагаются. Хотите более конкретную помощь? Свяжитесь с нами, и мы поможем подобрать именно то, что вам нужно!
КОНТАКТ
b3lineicon|b3icon-users-group||Группа пользователей
Узнать больше
Мы полностью привержены тому, чтобы каждый участник нашей программы получил положительный и обогащающий опыт. Наша команда Student Success будет работать с вами, чтобы обеспечить удовлетворение всех ваших потребностей. Это важная часть нашей компании. Узнайте больше о нашей политике DEI ниже.
ПОСЕТИТЕ СТРАНИЦУ DEI
b3lineicon|b3icon-books-apple||Книги Apple
Подробнее
Наша команда может помочь вам выбрать программы и специальные курсы, которые повысят вашу степень и карьерные устремления, чтобы вы могли вовремя закончить обучение. Если определенный класс является наиболее важным элементом выбранной вами программы, начните с нашего средства поиска классов, чтобы отточить программы, которые его предлагают. Перед отъездом вам нужно будет встретиться со своим учителем за границей или научным руководителем в вашем родном кампусе, чтобы подтвердить, как заработанные вами кредиты будут переведены обратно в ваш план получения степени.
ПОСЕТИТЕ ПОИСК КЛАССА
b3lineicon|b3icon-money-bag||Money Bag
Узнать больше
Доступность является одной из главных проблем для наших студентов и их семей. Но не беспокойтесь — существует удивительное количество недорогих вариантов, а также программ финансовой помощи и вариантов составления бюджета. Вы можете узнать больше о них, посетив нашу страницу финансовой информации или нашу страницу стипендий, или свяжитесь с нами.
b3lineicon|b3icon-shield-check||Проверка щита
Подробнее
Одним словом, да. Вместе с командой API Student Success наш международный персонал работает над тем, чтобы во всем мире применялись передовые методы управления рисками. Узнайте больше о наших мерах по охране здоровья и безопасности, страховании, управлении чрезвычайными ситуациями и многом другом, нажав на ссылку ниже.
БЕЗОПАСНОСТЬ
b3lineicon|b3icon-mouse||Мышь
Узнать больше
Это самая простая часть! Просто нажмите на ссылку ниже, и мы проведем вас через шаги оттуда!
ПОДАТЬ ЗАЯВКУ
Не готовы подать заявку? Все в порядке, свяжитесь с нами, чтобы узнать больше, и мы поможем вам принять решение!
СВЯЖИТЕСЬ С НАМИ
«Серьезно… ЛУЧШИЙ ОПЫТ В МОЕЙ ЖИЗНИ! Программа API Study Abroad во Флоренции, Италия, навсегда останется во мне.
Персонал был чрезвычайно добрым, гостеприимным, и они действительно заставили нас чувствовать себя как дома, находясь за границей. API был очень полезен с той минуты, как я решил учиться за границей, и поддерживал это общение на протяжении всей моей программы и даже после того, как я вернулся домой. Обучение за границей может быть пугающим, но мне было приятно знать, что API всегда рядом, если мне что-нибудь понадобится. Я очень доволен своим выбором учиться за границей с API во Флоренции».
~Kristie K.
API Study Abroad, Флоренция, Италия
Что включено
b3lineicon|b3icon-file-image||Менеджер файла изображения
900 шагов процесс, обеспечение заполнения надлежащих форм, предоставление подробной информации и инструкций, а также помощь в обеспечении полного успеха вашего опыта.
b3lineicon|b3icon-books-apple||Книги Apple
Это не просто путешествие ради путешествия. Это путешествие с целью. Наша команда может помочь вам выбрать курсы и программы, которые улучшат вашу степень и карьерные устремления, чтобы вы могли оставаться на пути к достижению своих целей.
b3lineicon|b3icon-users-group||Users Group
Наши местные директора будут с вами на каждом этапе пути, обеспечивая вашу безопасность, планируя культурно значимые экскурсии и готовы помочь с любыми вопросами, которые могут возникнуть , 24×7.
b3lineicon|b3icon-house||House
Расположение и тип предоставляемого жилья зависит от вашей программы и местоположения, но во всех случаях мы работаем над тем, чтобы вы находились в безопасных, желаемых районах, к которым легко добраться от принимающей стороны. Университет.
b3lineicon|b3icon-heart-rate||Heart Rate
Совместно с командой API Student Success наш международный персонал работает над тем, чтобы лучшие практики управления рисками применялись во всем мире. Узнайте больше о наших мерах по охране здоровья и безопасности, страховании, управлении чрезвычайными ситуациями и многом другом, нажав здесь.
b3lineicon|b3icon-palette||Palette
Погрузитесь в культуру и опыт принимающей страны благодаря увлекательным экскурсиям и разнообразным культурным мероприятиям под руководством директоров-резидентов API и местных экспертов без дополнительной оплаты!
Объедините свое обучение за границей с виртуальными аккредитованными курсовыми работами для еще более надежного результата
Откройте для себя мир из любой точки мира с помощью виртуальных программ API.