Разворачиваем стенд для UI-тестирования iOS на базе Selenoid

Всем привет! Меня зовут Павел, я технический лидер тестирования в направления мобильной разработки. В моей прошлой статье я описывал, как мы разворачивали тестовый стенд для тестирования Android на базе Selenoid, и почему выбор пал именно на этот инструмент.

Следующим этапом нужно было развернуть аналогичный стенд для UI-тестирования iOS.

Здесь хотел бы отметить, что готового решения под яблочные девайсы нет, как для Android, так и в документации по Selenoid нет информации для iOS. Поэтому я опирался на статью Selenoid: Запускаем Appium UI-тесты на iOS. Часть 2. Однако, у нас была другая история, мы поднимали стенд для UI-тестирования на реальных iPhone.

030d5ebe4c9424fa5061c57ca8d1eea3.jpeg

Подготовка

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

Начнём с brew. С помощью этого приложения можно устанавливать пакеты, которые не предоставляет Apple. Идём на сайт или запускаем команду в терминале:

/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"

Далее устанавливаем npm-менеджер пакетов, входящий в состав Node.js. Для этого переходим на сайт, скачиваем файл для установки или в терминале выполняем команду:

brew install npm

Следующий шаг — установка Appium. Здесь без вариантов — устанавливаем через терминал:

sudo npm install -g appium

Также нам нужно установить appium-doctor, чтобы проверить в конце, что мы ничего не упустили при настройке Appium. Аналогично запускаем команду в терминале:

sudo npm install -g appium-doctor

Теперь на Mac нам нужно установить Сarthage. Также двумя способами: через установщик или терминал:

brew install carthage

И, наконец, открываем AppStore и ставим XCode.

А пока у нас качается и устанавливается приложение, мы можем перейти на сайт и скачать последнюю версию Selenoid для MacOS. Если у вас Intel, тогда нужна версия AMD для M1, M2 и т.д. Соответственно, нужна версия ARM.

Дальше переходим на сайт и по аналогии с Selenoid качаем последнюю версию Selenoid UI.

Подготовка закончена — можно переходить к настройке.

Настройка

Сначала нам нужно добиться, чтобы при запуске appium-doctor не было ошибок. Сперва устанавливаем Xcode Command Line Tools.

Команда в терминале:

xcode-select --install

После установки проверяем:

xcode-select -p

В терминале должны увидеть такую строку:

/Applications/Xcode.app/Contents/Developer

Запускаем appium-doctor:

appium-dcotor --ios

После чего должны увидеть примерно такое:

fea109bffcdc4422890afd853a3bd8a1.png

Appium настроен, теперь можно переходить к настройке конфигурации. Создаем конфиг для Appium и конфиг для Selenoid:

{
  "ios": {
    "default": "iPhone X",
    "versions": {
      "iPhone X": {
        "image": ["appium", "--config", "/Users/mobilefarm.am/selenoid/config/appium/iphonex.json"]
      },
      "iPhone 6s": {
        "image": ["appium", "--config", "/Users/mobilefarm.am/selenoid/config/appium/iphone6s.json"]
      }
    }
  }
}

Запускаем Selenoid со следующими параметрами:

./selenoid -disable-docker -conf config/browsers.json -limit 20 -retry-count 1000 -video-output-dir video -log-output-dir logs -max-timeout 20m -session-attempt-timeout 15m -timeout 10m -service-startup-timeout 10m

И Selenoid UI:

./selenoid-ui --selenoid-uri=http://localhost:4444

Проверяем, что Selenoid успешно запустился:

 http://localhost:8080

В браузере должна открыться стандартная UI:

b733bd56fb0ff8c302bb256f4c5a575b.png

Переходим к самому интересному…

Установка драйвера на девайсах

Самая проблематична часть в настройке тестового стенда. Открываем терминал и запускаем команду:

appium driver run xcuitest open-wda

Должен открыться проект WebDriverAgent.

f2a1d247fc0bc0606aefeb63f9b0845f.png

Нужно перейти в XcodePreferencesAccounts и добавить учетную запись AppleID. После чего:

  • вернуться к проекту;

  • в разделе Signing & Capabilities выбрать свой ранее добавленный аккаунт в поле Team;

  • и заменить в поле Bundle Identifier на свое значение.

78ea6c684d086d8575e4430ba8fd96c1.png

Запустить сборку и после проверить ProductTest. На девайсе должна появиться иконка драйвера.

aeb5e91ec0f9814a8084cc39bbd61822.png

На iPhone переходим в НастройкиОсновныеПрофили и Управление устройством и нажимаем Доверять разработчику.

f4863f89a0fcce797b820c809a8312da.png

Возможные проблемы и решение

При попытке подключиться через Appium Inspector столкнулись с такой ошибкой:

06a1a027ec6fd5433ca762f55f797bb0.png

Закрываем XCode и качаем с сайта zip-файл последней версии. Распаковываем архив и закидываем содержимое архива в директорию ~/.appium/node_modules/appium-xcuitest-driver/node_modules/appium-webdriveragent/, предварительно очистив эту папку.

Теперь запускаем проект wda и повторно собираем драйвер для девайса. Опять закрываем XCode, переустанавливаем проект.

sudo appium driver uninstall xcuitest
sudo appium driver install xcuitest

Открываем проект и ещё раз собираем драйвера на iPhone — пробуем подключиться через Appium Inspector. У нас после таких манипуляций подключение прошло успешно и запустился Safari на девайсах.

На этом всё. Далее мы планируем настроить Go GGR Router, чтобы у нас была единая точка подключения. Спасибо за внимание.

© Habrahabr.ru