本文將介紹使用 Firebase App Distribution 和 fastlane 的最佳做法,讓 Apple 平台的預先發布測試工作流程在 CI/CD 環境中可持續且可重複執行。雖然本文件著重於 Fastlane,但我們也會說明透過 Firebase 主控台、Firebase CLI 和公開的 Firebase App Distribution API 提供的解決方案,讓您享有更彈性的運用方式。我們也會說明發布版本和測試人員的限制,方便您預先規劃以獲得最佳體驗。
如果您也使用 Android,請參閱使用 CI/CD 將 Android 應用程式發布給品質確保測試人員的最佳做法。
事前準備
實作本文件中的最佳做法之前,請務必在 每個應用程式的 Firebase 控制台中啟用 App Distribution。如果您未啟用 App Distribution,將會收到 404 錯誤。
如要啟用 App Distribution,請按照下列步驟操作:
在 Firebase 主控台中開啟 App Distribution 頁面。
選取 iOS 應用程式。
點選「開始使用」。
運用 CI/CD 自動化處理預先發布測試工作流程
如果您想自動建構應用程式並發布給測試人員,且正在使用 CI/CD,建議您使用 fastlane。另一種做法是使用 Firebase CLI,這可讓您存取各種 Firebase 產品。
使用 fastlane
使用 fastlane 將 App Distribution 整合至 CI/CD 管道,這是可自動建構及發布 iOS 和 Android 應用程式的開放原始碼工具。自動建構並發布最新版本給測試人員,確保測試人員隨時都能取得應用程式的最新測試版本。
如要瞭解如何將 App Distribution 與 fastlane 整合,請參閱「使用 fastlane 將 iOS 應用程式發布給測試人員」。另請參閱程式碼研究室,瞭解 Quicklane 整合程序。
使用 Firebase CLI
使用 App Distribution 提供的 Firebase CLI 工具,以程式輔助方式將版本發布給測試人員。您可以為建構指定測試人員和版本附註。
指定應用程式的 Firebase 應用程式 ID,然後視需要新增發布說明和包含測試人員電子郵件的檔案,即可發布最新的 iOS 版本 test.ipa
:
firebase appdistribution:distribute test.ipa \ --app 1:1234567890:ios:0a1b2c3d4e5f67890 \ --release-notes "Bug fixes and improvements" --testers-file testers.txt
如要進一步瞭解如何使用 Firebase CLI 自動執行建構作業,請參閱「使用 Firebase CLI 將 iOS 應用程式發布給測試人員」。
使用服務憑證進行驗證
透過服務帳戶使用 App Distribution Fastlane 外掛程式或 Firebase CLI,以充分運用應用程式預設憑證並協助您管理持續整合。服務帳戶是一種 Google 帳戶類型,代表應用程式而非使用者。CI 系統可以使用服務帳戶執行 App Distribution 工作負載。詳情請參閱使用服務帳戶進行驗證。
如果您使用 Workload Identity 聯盟,可以產生並使用憑證設定檔,而非服務帳戶金鑰。
請注意版本數量上限
App Distribution 支援的每個應用程式版本數量上限為 1,000 個。也就是說,如果您超過版本數量上限,App Distribution 會自動刪除超過上限的舊版本。如要瞭解如何管理版本限制,請參閱「應用程式版本的推出時間為何?」一節。
將相同的測試人員加入多個版本
如要在版本中新增大量測試人員,請使用 App Distribution 的大量測試人員管理功能。
建議您使用群組,將相同的測試人員加入多個版本。群組可做為存取權控制清單,當您從群組中移除測試人員時,他們就無法存取分發給該群組的所有版本。詳情請參閱「在群組中新增及移除測試人員」。
如果有很多測試人員需要管理,您可以透過 Firebase 控制台大量新增及刪除測試人員。如要自動新增及移除測試人員,請使用 Firebase CLI、fastlane 或 公開 Firebase App Distribution API。
請注意測試人員限制
App Distribution 會限制您可新增至 Firebase 專案或 App Distribution 群組的測試人員人數。一旦超過限制,您就無法將應用程式發布給其他測試人員。如要進一步瞭解測試人員限制,請參閱「應用程式可新增的測試人員有上限嗎?」
管理及自動新增 iOS 測試人員裝置
App Distribution 會透過電子郵件或 CSV 檔案通知您新的測試人員 iOS 裝置,協助您在 Apple Developer Portal 中管理 iOS 測試人員裝置。詳情請參閱「從 CSV 檔案匯入測試人員」。您也可以透過程式輔助方式使用 fastlane 匯出新裝置。
如要瞭解如何設定能自動提取 UDID 的 Quicklane 動作,將 UDID 新增至 Apple 開發人員控制台,然後重新建構應用程式並發布應用程式,請參閱「使用 App Distribution 和 Fastlane 加快發布 iOS 預先發布版本的速度」。
讓潛在測試人員自行註冊測試
為了讓您更輕鬆地將應用程式發送給更多測試人員,建議您使用邀請連結。邀請連結是專屬網址,可讓測試人員輸入電子郵件地址,以便註冊測試應用程式。允許使用者將自己加入應用程式測試人員清單,是增加內部測試基礎的順暢方式。
邀請連結的用途包括公司內部測試計畫、擁有龐大品質保證團隊的機構,以及希望個別客戶能夠控管測試人員存取權的開發人員群組。
建議您為群組建立邀請連結。任何使用邀請連結登錄的測試人員都會自動加入後續版本。
詳情請參閱「建立邀請連結」和「在群組中新增及移除測試人員」。
確認測試人員測試的是您關心的版本
上傳新版本後,系統會透過電子郵件通知測試人員。如要補充這則通知,您可以使用下列功能 (發布連結和應用程式內快訊),確保測試人員能測試您重視的應用程式版本:
版本連結:如果您想與測試人員分享特定版本,請使用這項功能。如要瞭解如何使用發布連結,請參閱「使用 Firebase 控制台將 iOS 應用程式發布給測試人員」一文。這些連結也可透過 Firebase 和 fastlane 指令列 (CLI) 工具取得,並與建構自動化工具搭配使用。
應用程式內警示:如要確保測試人員測試的是最新版應用程式,請使用這類警示。整合 Firebase App Distribution iOS SDK 後,您就能在應用程式內直接向測試人員顯示警示,告知應用程式有新版本可供測試。如要瞭解如何新增應用程式內快訊,請參閱「通知測試人員新版本」。
自動移除離職測試人員的存取權
當您的 CI/CD 內部測試流程開始運作後,您必須確保離開公司的人員無法再存取您的內部版本。為協助您管理測試人員對建構版本的存取權,App Distribution 提供下列選項:
fastlane:使用 Fastfile 檔案或直接執行 Fastlane 動作。如要進一步瞭解如何使用 fastlane 移除測試人員,請參閱「使用 fastlane 將 iOS 應用程式發布給測試人員」。
公開 Firebase App Distribution API: 使用
testers.batchRemove
端點。