Bạn có thể tích hợp Phân phối ứng dụng vào quy trình xây dựng Android của mình bằng cách sử dụng plugin Phân phối ứng dụng cho Gradle. Plugin cho phép bạn chỉ định người thử nghiệm và ghi chú phát hành trong tệp Gradle của ứng dụng, cho phép bạn định cấu hình bản phân phối cho các loại bản dựng và biến thể khác nhau của ứng dụng.
Hướng dẫn này mô tả cách phân phối APK cho người thử nghiệm bằng cách sử dụng plugin Phân phối ứng dụng cho Gradle.
Trước khi bắt đầu
Nếu bạn chưa có, hãy thêm Firebase vào dự án Android của bạn .
Nếu không sử dụng bất kỳ sản phẩm Firebase nào khác, bạn chỉ phải tạo dự án và đăng ký ứng dụng của mình. Tuy nhiên, nếu bạn quyết định sử dụng các sản phẩm bổ sung trong tương lai, hãy nhớ hoàn thành tất cả các bước trên trang được liên kết ở trên.
Bước 1. Thiết lập dự án Android của bạn
Trong tệp Gradle cấp cơ sở (cấp dự án) (
<project>/build.gradle.kts
hoặc<project>/build.gradle
), hãy thêm plugin Gradle phân phối ứng dụng làm phần phụ thuộc:Kotlin
plugins { // ... id("com.android.application") version "7.3.0" apply false // Make sure that you have the Google services Gradle plugin dependency id("com.google.gms.google-services") version "4.4.0" apply false // Add the dependency for the App Distribution Gradle plugin id("com.google.firebase.appdistribution") version "4.0.1" apply false }
Groovy
plugins { // ... id 'com.android.application' version '7.3.0' apply false // Make sure that you have the Google services Gradle plugin dependency id 'com.google.gms.google-services' version '4.4.0' apply false // Add the dependency for the App Distribution Gradle plugin id 'com.google.firebase.appdistribution' version '4.0.1' apply false }
Trong tệp Gradle mô-đun (cấp ứng dụng) của bạn (thường là
<project>/<app-module>/build.gradle.kts
hoặc<project>/<app-module>/build.gradle
), hãy thêm plugin Gradle phân phối ứng dụng:Kotlin
plugins { id("com.android.application") // Make sure that you have the Google services Gradle plugin id("com.google.gms.google-services") // Add the App Distribution Gradle plugin id("com.google.firebase.appdistribution") }
Groovy
plugins { id 'com.android.application' // Make sure that you have the Google services Gradle plugin id 'com.google.gms.google-services' // Add the App Distribution Gradle plugin id 'com.google.firebase.appdistribution' }
Nếu bạn sử dụng proxy hoặc tường lửa công ty, hãy thêm thuộc tính hệ thống Java sau để cho phép Phân phối ứng dụng tải các bản phân phối của bạn lên Firebase:
-Djavax.net.ssl.trustStore=/path/to/truststore -Djavax.net.ssl.trustStorePassword=password
Bước 2. Xác thực bằng Firebase
Trước khi có thể sử dụng plugin Gradle, trước tiên bạn phải xác thực với dự án Firebase của mình theo một trong các cách sau. Theo mặc định, plugin Gradle tìm kiếm thông tin xác thực từ Firebase CLI nếu không sử dụng phương thức xác thực nào khác.
Xác thực bằng tài khoản dịch vụ cho phép bạn sử dụng linh hoạt plugin với hệ thống tích hợp liên tục (CI) của mình. Có hai cách để cung cấp thông tin xác thực tài khoản dịch vụ:
- Chuyển tệp khóa tài khoản dịch vụ của bạn tới
build.gradle
. Bạn có thể thấy phương pháp này thuận tiện nếu bạn đã có tệp khóa tài khoản dịch vụ trong môi trường xây dựng của mình. - Đặt biến môi trường
GOOGLE_APPLICATION_CREDENTIALS
để trỏ đến tệp khóa tài khoản dịch vụ của bạn. Bạn có thể thích phương pháp này hơn nếu bạn đã định cấu hình Thông tin xác thực mặc định của ứng dụng (ADC) cho một dịch vụ khác của Google (ví dụ: Google Cloud).
Để xác thực bằng thông tin xác thực tài khoản dịch vụ:
- Trên Google Cloud Console, chọn dự án của bạn và tạo tài khoản dịch vụ mới.
- Thêm vai trò Quản trị viên phân phối ứng dụng Firebase .
- Tạo khóa json riêng và di chuyển khóa đến vị trí có thể truy cập được vào môi trường xây dựng của bạn. Hãy đảm bảo giữ tệp này ở nơi an toàn vì nó cấp cho quản trị viên quyền truy cập vào Phân phối ứng dụng trong dự án Firebase của bạn.
- Bỏ qua bước này nếu bạn tạo ứng dụng của mình sau ngày 20 tháng 9 năm 2019: Trong bảng điều khiển API của Google, hãy bật API phân phối ứng dụng Firebase. Khi được nhắc, hãy chọn dự án có cùng tên với dự án Firebase của bạn.
Cung cấp hoặc xác định thông tin đăng nhập tài khoản dịch vụ của bạn:
- Để truyền cho Gradle khóa tài khoản dịch vụ của bạn, trong tệp
build.gradle
, hãy đặt thuộc tínhserviceCredentialsFile
thành tệp JSON khóa riêng tư. Để xác định thông tin xác thực của bạn bằng ADC, hãy đặt biến môi trường
GOOGLE_APPLICATION_CREDENTIALS
thành đường dẫn cho tệp JSON khóa riêng tư. Ví dụ:export GOOGLE_APPLICATION_CREDENTIALS=/absolute/path/to/credentials/file.json
Để biết thêm thông tin về xác thực bằng ADC, hãy đọc Cung cấp thông tin xác thực cho ứng dụng của bạn.
- Để truyền cho Gradle khóa tài khoản dịch vụ của bạn, trong tệp
Xem Đăng nhập bằng Firebase CLI để biết hướng dẫn về cách xác thực dự án của bạn.
Bước 3. Định cấu hình thuộc tính phân phối của bạn
Trong tệp Gradle mô -đun (cấp ứng dụng) của bạn (thường là <project>/<app-module>/build.gradle.kts
hoặc <project>/<app-module>/build.gradle
), hãy định cấu hình Phân phối ứng dụng bằng cách thêm ít nhất một phần firebaseAppDistribution
.
Ví dụ: để phân phối bản release
cho người thử nghiệm, hãy làm theo các hướng dẫn sau::
Kotlin
import com.google.firebase.appdistribution.gradle.firebaseAppDistribution android { // ... buildTypes { getByName("release") { firebaseAppDistribution { artifactType = "APK" releaseNotesFile = "/path/to/releasenotes.txt" testers = "ali@example.com, bri@example.com, cal@example.com" } } } // ... }
Groovy
android { // ... buildTypes { release { firebaseAppDistribution { artifactType="APK" releaseNotesFile="/path/to/releasenotes.txt" testers="ali@example.com, bri@example.com, cal@example.com" } } } // ... }
Bạn có thể định cấu hình Phân phối ứng dụng cho loại bản dựng và phiên bản sản phẩm .
Ví dụ: để phân phối các bản dựng debug
và release
ở các phiên bản sản phẩm "bản demo" và "đầy đủ", hãy làm theo các hướng dẫn sau:
Kotlin
import com.google.firebase.appdistribution.gradle.firebaseAppDistribution android { // ... buildTypes { getByName("debug") {...} getByName("release") {...} } flavorDimensions += "version" productFlavors { create("demo") { dimension = "version" firebaseAppDistribution { releaseNotes = "Release notes for demo version" testers = "demo@testers.com" } } create("full") { dimension = "version" firebaseAppDistribution { releaseNotes = "Release notes for full version" testers = "full@testers.com" } } } // ... }
Groovy
android { // ... buildTypes { debug {...} release {...} } flavorDimensions "version" productFlavors { demo { dimension "version" firebaseAppDistribution { releaseNotes="Release notes for demo version" testers="demo@testers.com" } } full { dimension "version" firebaseAppDistribution { releaseNotes="Release notes for full version" testers="full@testers.com" } } } // ... }
Sử dụng các tham số sau để định cấu hình phân phối:
Thông số bản dựng phân phối ứng dụng | |
---|---|
appId | ID ứng dụng Firebase của ứng dụng của bạn. Chỉ bắt buộc nếu bạn chưa cài đặt plugin Google Services Gradle. Bạn có thể tìm thấy ID ứng dụng trong tệp appId="1:1234567890:android:321abc456def7890" |
serviceCredentialsFile | Đường dẫn đến tệp JSON khóa riêng của tài khoản dịch vụ của bạn. Chỉ bắt buộc nếu bạn sử dụng xác thực tài khoản dịch vụ. |
artifactType | Chỉ định loại tệp ứng dụng của bạn. Có thể được đặt thành |
artifactPath | Đường dẫn tuyệt đối đến tệp APK hoặc AAB bạn muốn tải lên. |
releaseNotes hoặc releaseNotesFile | Ghi chú phát hành cho bản dựng này. Bạn có thể chỉ định trực tiếp ghi chú phát hành hoặc đường dẫn đến tệp văn bản thuần túy. |
testers hoặc testersFile | Địa chỉ email của người thử nghiệm mà bạn muốn phân phối bản dựng. Bạn có thể chỉ định người kiểm tra dưới dạng danh sách địa chỉ email được phân tách bằng dấu phẩy: testers="ali@example.com, bri@example.com, cal@example.com" Hoặc, bạn có thể chỉ định đường dẫn đến tệp chứa danh sách địa chỉ email được phân tách bằng dấu phẩy: testersFile="/path/to/testers.txt" |
groups hoặc groupsFile | Nhóm người thử nghiệm mà bạn muốn phân phối bản dựng (xem Quản lý người thử nghiệm ). Các nhóm được chỉ định bằng cách sử dụng Bạn có thể chỉ định các nhóm dưới dạng danh sách bí danh nhóm được phân tách bằng dấu phẩy: groups="qa-team, android-testers" Hoặc, bạn có thể chỉ định đường dẫn đến tệp chứa danh sách bí danh nhóm được phân tách bằng dấu phẩy: groupsFile="/path/to/tester-groups.txt" |
stacktrace | In ra stacktrace cho các ngoại lệ của người dùng. Điều này rất hữu ích khi gỡ lỗi các vấn đề. |
Bước 4. Phân phối ứng dụng của bạn cho người thử nghiệm
Cuối cùng, để đóng gói ứng dụng thử nghiệm của bạn và mời người thử nghiệm, hãy xây dựng các mục tiêu
BUILD-VARIANT
vàappDistributionUpload BUILD-VARIANT
bằng trình bao bọc Gradle của dự án, trong đó BUILD-VARIANT là loại bản dựng và phiên bản sản phẩm tùy chọn mà bạn đã định cấu hình ở bước trước. Để biết thêm thông tin về các phiên bản sản phẩm, hãy xem Định cấu hình các biến thể bản dựng .Ví dụ: để phân phối ứng dụng của bạn bằng biến thể bản
release
, hãy chạy lệnh sau:./gradlew assembleRelease appDistributionUploadRelease
Hoặc, nếu bạn đã xác thực bằng Tài khoản Google của mình và không cung cấp thông tin xác thực trong tệp bản dựng Gradle, hãy bao gồm biến
FIREBASE_TOKEN
:export FIREBASE_TOKEN=1/a1b2c3d4e5f67890 ./gradlew --stop // Only needed for environment variable changes ./gradlew assembleRelease appDistributionUploadRelease
Bạn cũng có thể ghi đè các giá trị được đặt trong tệp
build.gradle
của mình bằng cách chuyển các đối số dòng lệnh ở dạng--<property-name>=<property-value>
. Ví dụ:Để tải bản dựng gỡ lỗi lên Phân phối ứng dụng:
./gradlew bundleDebug appDistributionUploadDebug --artifactType="APK"
Để mời những người thử nghiệm bổ sung hoặc xóa những người thử nghiệm hiện có khỏi dự án Firebase của bạn:
./gradlew appDistributionAddTesters --projectNumber=<project_number> --emails="anothertester@email.com, moretesters@email.com"
./gradlew appDistributionRemoveTesters --projectNumber=<project_number> --emails="anothertester@email.com, moretesters@email.com"
Sau khi người thử nghiệm được thêm vào dự án Firebase của bạn, bạn có thể thêm họ vào từng bản phát hành riêng lẻ. Những người thử nghiệm bị loại bỏ sẽ không còn quyền truy cập vào các bản phát hành trong dự án của bạn nhưng vẫn có thể giữ quyền truy cập vào các bản phát hành của bạn trong một khoảng thời gian.
Bạn cũng có thể chỉ định người kiểm tra bằng cách sử dụng
--file="/path/to/testers.txt"
thay vì--emails
.Các tác vụ
appDistributionAddTesters
vàappDistributionRemoveTesters
cũng chấp nhận các đối số sau:projectNumber
: Số dự án Firebase của bạn.serviceCredentialsFile
: Đường dẫn đến tệp thông tin xác thực dịch vụ Google của bạn. Đây là đối số tương tự được sử dụng bởi hành động tải lên.
Plugin Gradle xuất ra các liên kết sau sau khi tải bản phát hành lên. Các liên kết này giúp bạn quản lý các tệp nhị phân và đảm bảo rằng người thử nghiệm và nhà phát triển khác có bản phát hành phù hợp:
-
firebase_console_uri
- Liên kết tới bảng điều khiển Firebase hiển thị một bản phát hành duy nhất. Bạn có thể chia sẻ liên kết này với các nhà phát triển khác trong tổ chức của mình. -
testing_uri
- Liên kết tới bản phát hành trong trải nghiệm của người thử nghiệm (ứng dụng gốc của Android) cho phép người thử nghiệm xem ghi chú phát hành và cài đặt ứng dụng vào thiết bị của họ. Người thử nghiệm cần có quyền truy cập vào bản phát hành để sử dụng liên kết. -
binary_download_uri
- Một liên kết đã ký trực tiếp tải xuống và cài đặt tệp nhị phân của ứng dụng (tệp APK hoặc AAB). Liên kết sẽ hết hạn sau một giờ.
Sau khi bạn phân phối bản dựng của mình, bản dựng đó sẽ có sẵn trong bảng điều khiển Phân phối ứng dụng của bảng điều khiển Firebase trong 150 ngày (năm tháng). Khi bản dựng hết hạn còn 30 ngày, thông báo hết hạn sẽ xuất hiện trong cả bảng điều khiển và danh sách các bản dựng của người thử nghiệm trên thiết bị thử nghiệm của họ.
Những người thử nghiệm chưa được mời thử nghiệm ứng dụng sẽ nhận được lời mời qua email để bắt đầu và những người thử nghiệm hiện tại sẽ nhận được thông báo qua email rằng bản dựng mới đã sẵn sàng để thử nghiệm (đọc hướng dẫn thiết lập dành cho người thử nghiệm để biết hướng dẫn về cách cài đặt ứng dụng thử nghiệm). Bạn có thể theo dõi trạng thái của từng người thử nghiệm - liệu họ có chấp nhận lời mời hay không và liệu họ có tải xuống ứng dụng hay không - trong bảng điều khiển Firebase.
Người thử nghiệm có 30 ngày để chấp nhận lời mời dùng thử ứng dụng trước khi ứng dụng hết hạn. Khi lời mời còn 5 ngày kể từ khi hết hạn, thông báo hết hạn sẽ xuất hiện trong bảng điều khiển Firebase bên cạnh người thử nghiệm trên bản phát hành. Lời mời có thể được gia hạn bằng cách gửi lại bằng menu thả xuống trên hàng người thử nghiệm.
Bước tiếp theo
Triển khai phản hồi trong ứng dụng để giúp người thử nghiệm dễ dàng gửi phản hồi về ứng dụng của bạn (bao gồm cả ảnh chụp màn hình).
Tìm hiểu cách hiển thị cảnh báo trong ứng dụng cho người thử nghiệm khi có bản dựng mới của ứng dụng để cài đặt.
Hãy truy cập lớp học lập trình Android App Bundle để tìm hiểu cách phân phối các bản phát hành gói ứng dụng theo từng bước.
Tìm hiểu các phương pháp hay nhất để phân phối ứng dụng Android cho người kiểm tra QA bằng CI/CD .