Bạn có thể sử dụng Firebase Test Lab khi phát triển ứng dụng bằng bất kỳ hệ thống tích hợp liên tục (CI) nào. Hệ thống tích hợp liên tục cho phép bạn tự động tạo và kiểm thử ứng dụng mỗi lần bạn kiểm tra bản cập nhật cho mã nguồn ứng dụng.
Sử dụng Firebase Test Lab với Jenkins CI
Phần này mô tả cách sử dụng Test Lab với Jenkins CI.
Yêu cầu
Để có thể sử dụng Firebase Test Lab với Jenkins, bạn cần hoàn tất các bước sau:
Thiết lập gcloud. Làm theo hướng dẫn trong phần Sử dụng Firebase Test Lab từ dòng lệnh gcloud để tạo một dự án Firebase và định cấu hình môi trường SDK Google Cloud cục bộ.
Tạo và uỷ quyền cho tài khoản dịch vụ. Tài khoản dịch vụ không phải chịu các quy trình kiểm tra thư rác hoặc lời nhắc nhập mã xác thực, nếu không, các quy trình này có thể chặn các bản dựng CI của bạn. Tạo một tài khoản dịch vụ có vai trò Người chỉnh sửa trong bảng điều khiển Google Cloud, sau đó kích hoạt tài khoản đó (xem tài liệu gcloud auth activate-service-account để tìm hiểu cách thực hiện).
Bật các API bắt buộc. Sau khi đăng nhập bằng tài khoản dịch vụ: Trên trang Thư viện API Google Developers Console, hãy bật Google Cloud Testing API và Cloud Tool Results API. Để bật các API này, hãy nhập tên của các API này vào hộp tìm kiếm ở đầu bảng điều khiển, rồi nhấp vào Bật API trên trang tổng quan của API đó.
Cài đặt và thiết lập Jenkins
Bạn có thể cài đặt và thiết lập Jenkins CI trên Linux hoặc Windows. Một số thông tin chi tiết trong hướng dẫn này dành riêng cho việc cài đặt và chạy Jenkins CI trên Linux, bao gồm cả việc sử dụng dấu gạch chéo (/
) trong đường dẫn tệp.
Để tải và cài đặt Jenkins trên máy tính chạy Linux hoặc Windows, hãy làm theo hướng dẫn trong phần Cài đặt Jenkins. Sau khi cài đặt Jenkins, hãy làm theo hướng dẫn về cách Bắt đầu và truy cập vào Jenkins để hoàn tất quá trình thiết lập và truy cập vào trang tổng quan của Jenkins.
Định cấu hình chế độ cài đặt bảo mật chung
Jenkins không có tính năng xác thực người dùng và kiểm soát quyền truy cập được định cấu hình khi được cài đặt lần đầu. Trước khi sử dụng Jenkins với Firebase Test Lab, hãy định cấu hình chế độ cài đặt bảo mật chung để thực thi quyền kiểm soát truy cập và xác thực người dùng.
Cách định cấu hình chế độ cài đặt bảo mật chung
- Chuyển đến trang tổng quan Jenkins trên máy chủ của bạn. Để thực hiện việc này, hãy duyệt đến http://<servername>:8080, trong đó <servername> là tên của máy tính mà bạn đã cài đặt Jenkins.
- Trên trang tổng quan của Jenkins, hãy nhấp vào Manage Jenkins (Quản lý Jenkins), rồi nhấp vào Configure Global Security (Định cấu hình bảo mật chung).
- Trên trang Định cấu hình bảo mật chung, hãy nhấp vào Bật bảo mật, rồi nhấp vào Lưu.
Để biết thêm thông tin về cách định cấu hình chế độ cài đặt bảo mật cho Jenkins, hãy xem phần Bảo mật nhanh chóng và đơn giản, Thiết lập bảo mật tiêu chuẩn và Bảo mật Jenkins.
Tạo một dự án Jenkins
Tiếp theo, hãy tạo một dự án để chạy kiểm thử tích hợp liên tục cho ứng dụng của bạn bằng Firebase Test Lab.
Cách tạo dự án Jenkins
- Chuyển đến trang tổng quan Jenkins trên máy chủ của bạn. Để thực hiện việc này, hãy duyệt đến http://<servername>:8080, trong đó <servername> là tên của máy tính mà bạn đã cài đặt Jenkins.
- Trên trang tổng quan của Jenkins, hãy nhấp vào New Item (Mục mới).
- Nhập tên cho dự án của bạn trong trường Tên mục:
- Chọn Dự án tuỳ ý để tạo một dự án sử dụng một cấu hình bản dựng duy nhất.
- Chọn Build multi-configuration project (Tạo dự án có nhiều cấu hình) để tạo một dự án chạy trên nhiều cấu hình bản dựng khác nhau. Nếu bạn dự định tạo ứng dụng của mình bằng nhiều cấu hình bản dựng (nhiều ngôn ngữ, nhiều cấp độ API Android, v.v.), thì dự án có nhiều cấu hình là lựa chọn tốt nhất.
- Nhấp vào Lưu.
Sau khi dự án của bạn được tạo, trình duyệt web sẽ hiển thị trang chính cho dự án của bạn.
Thêm chế độ kiểm soát phiên bản và các bước tạo bản dựng Gradle
Phần này mô tả cách tích hợp Jenkins với các hệ thống kiểm soát phiên bản như GitHub và cách thêm các bước tạo Gradle để tạo gói APK từ mã nguồn.
Tích hợp với GitHub và các hệ thống kiểm soát phiên bản khác
Nếu sử dụng GitHub hoặc một hệ thống kiểm soát phiên bản khác để quản lý mã nguồn cho ứng dụng, bạn có thể định cấu hình Jenkins để chạy các bản dựng tự động và chạy các kiểm thử mỗi khi các bản cập nhật cho ứng dụng được kiểm tra. Bạn cũng có thể định cấu hình Jenkins để chạy các bản dựng định kỳ.
Để tìm hiểu về cách định cấu hình bản dựng trong Jenkins, hãy xem phần Định cấu hình bản dựng tự động.
Thêm các bước tạo Gradle để tạo lại các gói APK
Nếu sử dụng hệ thống kiểm soát phiên bản để quản lý mã nguồn cho ứng dụng, bạn cần thêm một bước tạo bản dựng Gradle để tạo tệp nhị phân APK mới mỗi khi Jenkins tải mã nguồn xuống từ hệ thống kiểm soát phiên bản.
Thêm một bước tạo để chạy các lệnh sau trong thư mục chính của ứng dụng:
./gradlew :app:assembleDebug ./gradlew :app:assembleDebugAndroidTest
Thêm một bước tạo để sử dụng(các) gói APK do Gradle tạo khi kiểm thử bằng Test Lab. Bạn có thể dùng đường dẫn này làm <local_server_path> trong ví dụ về tập lệnh shell được cung cấp bên dưới, trong đó <AppFolder> là thư mục dự án Android Studio cho ứng dụng của bạn:
<AppFolder>/app/build/outputs/apk
Thêm các bước tạo Test Lab vào Jenkins
Giờ đây, bạn đã sẵn sàng thêm một bước tạo vào Jenkins để chạy Test Lab bằng dòng lệnh gcloud.
Cách thêm bước tạo gcloud
- Trên trang chính của dự án, hãy nhấp vào Configure (Định cấu hình).
Trên trang cấu hình dự án, hãy di chuyển xuống phần Build (Tạo), rồi chọn Execute shell (Chạy shell) trong trình đơn Add build step (Thêm bước tạo).
Trong cửa sổ Jenkins Execute shell command (Jenkins thực thi lệnh shell), hãy nhập nội dung sau, thay thế <local_server_path> bằng đường dẫn đến ứng dụng mẫu trên máy chủ, <app_apk> bằng APK của ứng dụng và <app_test_apk> bằng APK kiểm thử của ứng dụng:
gcloud firebase test android run --app <local_server_path>/<app_apk>.apk --test <local_server_path>/<app_test_apk>.apk
Phân tích kết quả kiểm thử
Sau khi Test Lab hoàn tất kiểm thử ứng dụng, bạn có thể xem kết quả kiểm thử trong bảng điều khiển Firebase hoặc trong một nhóm Google Cloud Storage trong dự án của bạn. Bạn cũng có thể thêm lệnh gsutil
vào lệnh shell nêu trên để sao chép dữ liệu kết quả kiểm thử vào máy tính cục bộ.
Để tìm hiểu thêm, hãy xem phần Phân tích kết quả Firebase Test Lab.
Tích hợp liên tục với các hệ thống CI khác
Để tìm hiểu cách sử dụng Firebase Test Lab với các hệ thống CI khác, hãy xem tài liệu của các hệ thống đó: