В этом документе представлены лучшие практики использования Firebase App Distribution для обеспечения устойчивости и воспроизводимости рабочих процессов предварительного тестирования Android-приложений в среде CI/CD. В качестве решений предлагаются Gradle и fastlane, но для большей гибкости мы также включили решения, доступные через консоль Firebase , Firebase CLI и публичный API Firebase App Distribution . Мы также описываем ограничения на количество релизов и тестировщиков, чтобы вы могли заранее спланировать оптимальные условия работы.
Если вы также используете платформы Apple, ознакомьтесь с рекомендациями по распространению приложений Apple среди тестировщиков с помощью CI/CD и fastlane .
Прежде чем начать
Прежде чем внедрять рекомендации, описанные в этом документе, обязательно включите функцию App Distribution в консоли Firebase для каждого приложения . Если App Distribution не включена, вы получите ошибку 404.
Чтобы включить App Distribution , выполните следующие действия:
- Откройте страницу App Distribution в консоли Firebase .
- Выберите ваше приложение для Android.
- Нажмите « Начать» .
Учитывая, что пакеты приложений Android (AAB) становятся наиболее распространенным форматом пакетов Android, мы рекомендуем настроить возможность распространения AAB-пакетов среди ваших тестировщиков путем привязки к Google Play .
Автоматизируйте процесс тестирования перед релизом с помощью конвейера CI/CD.
Если вы хотите автоматизировать сборку и выпуск приложений для тестировщиков и используете CI/CD, мы рекомендуем использовать fastlane или Gradle . Другой вариант — использовать Firebase CLI , который предоставляет доступ к широкому спектру продуктов Firebase.
Воспользуйтесь скоростной полосой.
Интегрируйте App Distribution в свой конвейер CI/CD с помощью fastlane — инструмента с открытым исходным кодом, который автоматизирует сборку и выпуск приложений для iOS и Android. Автоматическая сборка и распространение последних версий для тестировщиков гарантирует, что у них всегда будет самая актуальная тестовая версия вашего приложения.
Чтобы узнать, как интегрировать App Distribution с fastlane, см. раздел «Распространение Android-приложений среди тестировщиков с помощью fastlane» .
Используйте Gradle
Используйте Gradle для интеграции App Distribution в процесс сборки Android с помощью плагина App Distribution Gradle. Плагин позволяет указывать тестировщиков и примечания к релизу в файле build.gradle вашего приложения, что дает возможность настраивать дистрибутивы для различных типов сборок и вариантов вашего приложения.
Чтобы узнать, как интегрировать App Distribution с Gradle, см. раздел «Распространение приложений Android среди тестировщиков с помощью Gradle» .
Используйте Firebase CLI
Используйте инструменты командной строки Firebase , предоставляемые App Distribution , для программного распространения сборок среди тестировщиков. Вы можете указать тестировщиков и примечания к выпуску для сборки.
Распространите последнюю сборку Android, указав идентификатор приложения в Firebase, при желании добавив примечания к релизу и файл с адресами электронной почты тестировщиков:
firebase appdistribution:distribute test.aab \
--app 1:1234567890:android:0a1b2c3d4e5f67890 \
--release-notes "Bug fixes and improvements" --testers-file testers.txt
Чтобы узнать больше об использовании Firebase CLI для автоматизации сборки, см. раздел «Распространение приложений Android среди тестировщиков с помощью Firebase CLI» .
Используйте учетные данные службы для аутентификации.
Используйте плагин Fastlane App Distribution , плагин Gradle или Firebase CLI с учетными записями служб. Учетная запись службы — это тип учетной записи Google, представляющий приложения (в отличие от пользователей). Ваша система CI может использовать учетные записи служб для запуска рабочих нагрузок App Distribution . Для получения дополнительной информации см. раздел «Аутентификация с помощью учетной записи службы» .
Если вы используете федерацию идентификации рабочих нагрузок, вы можете сгенерировать и использовать файл конфигурации учетных данных вместо ключа учетной записи службы.
Учитывайте ограничения на выпуск.
App Distribution поддерживает максимум 1000 релизов на приложение. Это означает, что при превышении лимита релизов App Distribution автоматически удаляет самые старые релизы, превышающие лимит. Чтобы узнать, как управлять лимитами релизов, см. раздел «Как долго доступны релизы приложений?».
Добавлять один и тот же набор тестировщиков в несколько релизов
Если вы хотите добавить большое количество тестировщиков к своим релизам, воспользуйтесь функцией массового управления тестировщиками в App Distribution .
Мы рекомендуем использовать группы для добавления одних и тех же тестировщиков к нескольким релизам. Группа действует как список контроля доступа; при удалении тестировщика из группы он теряет доступ ко всем релизам, распространяемым в рамках этой группы. Для получения дополнительной информации см. раздел «Добавление и удаление тестировщиков из группы» .
Если у вас много тестировщиков, вы можете добавлять и удалять их одновременно с помощью консоли Firebase . Для автоматизации добавления и удаления тестировщиков используйте Firebase CLI , fastlane , Gradle или общедоступный API Firebase App Distribution .
Учитывайте ограничения тестировщика.
App Distribution ограничивает количество тестировщиков, которых вы можете добавить в проект Firebase или группу App Distribution . При превышении этих лимитов вы не сможете распространить свое приложение среди дополнительных тестировщиков. Чтобы узнать больше об ограничениях на количество тестировщиков, см. раздел «Существуют ли ограничения на добавление тестировщиков в мое приложение?».
Предоставьте потенциальным тестировщикам возможность самостоятельно зарегистрироваться для участия в тестировании.
Чтобы упростить распространение вашего приложения среди большего числа тестировщиков, мы рекомендуем использовать ссылки-приглашения. Ссылка-приглашение — это уникальный URL-адрес, который позволяет тестировщикам ввести свои адреса электронной почты для регистрации на тестирование приложения. Предоставление пользователям возможности добавлять себя в список тестировщиков вашего приложения — это простой способ расширить вашу внутреннюю базу тестировщиков.
Примеры использования ссылок-приглашений включают корпоративные программы тестирования, организации с большими командами контроля качества и группы разработчиков, которые хотят, чтобы отдельные клиенты могли контролировать доступ тестировщиков.
Мы рекомендуем создать ссылку-приглашение для группы. Любой тестировщик, зарегистрировавшийся по этой ссылке, автоматически будет добавлен в последующие релизы.
Для получения дополнительной информации см. разделы «Создание ссылок-приглашений» и «Добавление и удаление тестировщиков из группы» .
Убедитесь, что тестировщики тестируют именно ту версию, которая вас интересует.
Когда загружается новая версия, ваши тестировщики получают уведомление по электронной почте. В дополнение к этому уведомлению вы можете использовать следующие функции — ссылки на релизы и внутриприложения оповещения — чтобы убедиться, что ваши тестировщики тестируют именно ту версию приложения, которая вас интересует:
- Ссылки на релизы: используйте эту функцию, если хотите поделиться определенной версией с тестировщиками. Чтобы узнать, как использовать ссылки на релизы, см. раздел «Распространение приложений Android среди тестировщиков с помощью консоли Firebase . Эти ссылки также доступны в наших инструментах командной строки (CLI) Firebase , fastlane и Gradle для использования с вашими инструментами автоматизации сборки.
- Встроенные оповещения: используйте эти оповещения, чтобы убедиться, что ваши тестировщики тестируют последнюю версию вашего приложения. Интегрировав Android SDK Firebase App Distribution , вы можете отображать оповещения непосредственно в приложении для тестировщиков, когда становятся доступны новые сборки вашего приложения. Чтобы узнать, как добавить встроенные оповещения, см. раздел «Уведомление тестировщиков о новых сборках» .
Автоматически лишать доступа тестировщиков, покидающих компанию.
Когда ваш внутренний процесс тестирования CI/CD запущен и работает, вам необходимо убедиться, что сотрудники, покидающие компанию, больше не имеют доступа к вашим внутренним сборкам. Чтобы помочь вам управлять доступом тестировщиков к сборкам, App Distribution предоставляет следующие возможности:
- fastlane: Используйте свой файл Fastfile или запускайте действия fastlane напрямую. Для получения дополнительной информации см. раздел «Распространение приложений Android среди тестировщиков с помощью fastlane» .
- Firebase CLI: Используйте действие
firebase appdistribution:testers:remove. Для получения дополнительной информации см. раздел «Распространение приложений Android среди тестировщиков с помощью Firebase CLI» . - Gradle: Если вы используете Gradle для удаления тестировщиков, передайте
appDistributionRemoveTestersс аргументами-- PROJECT_NUMBERфайле-- EMAILSbuild.gradle. Для получения дополнительной информации см. раздел «Распространение приложений Android среди тестировщиков с помощью Gradle» . - Публичный API App Distribution Firebase : используйте конечную точку
testers.batchRemove.