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 xây dựng và kiểm thử ứng dụng mỗi khi 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
Trước khi 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 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 xác minh qua hình ảnh (captcha). 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 về 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ác API này vào hộp tìm kiếm ở đầu bảng điều khiển, sau đó 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ố chi tiết nhất định của 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 xuống 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 về 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 việc 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ó chế độ 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ài đặt lần đầu. Trước khi sử dụng Jenkins với Firebase Test Lab, hãy định cấu hình các chế độ cài đặt bảo mật chung để thực thi kiểm soát quyền 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 truy cập vào 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 Quản lý Jenkins, rồi nhấp vào Định cấu hình bảo mật chung.
- Trên trang Định cấu hình bảo mật toàn cầu, hãy nhấp vào Bật tính năng bảo mật, sau đó 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 bài viết Bảo mật nhanh và đơn giản, Thiết lập bảo mật tiêu chuẩn và Bảo mật Jenkins.
Tạo 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 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 truy cập vào 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 Item name (Tên mặt hàng):
- Chọn Freestyle project (Dự án Freestyle) để 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 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 xây dựng ứng dụng với 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 nhiều cấu hình là lựa chọn tốt nhất.
- Nhấp vào Lưu.
Sau khi tạo dự án, trình duyệt web sẽ hiển thị trang chính của dự án.
Thêm tính năng kiểm soát bản sửa đổi 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 bản sửa đổi như GitHub và cách thêm các bước bản dựng 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 bản sửa đổi khác
Nếu sử dụng GitHub hoặc một hệ thống kiểm soát bản sửa đổi 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 kiểm thử mỗi khi kiểm tra bản cập nhật cho ứng dụng. 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 bài viết Định cấu hình bản dựng tự động.
Thêm các bước xây dựng Gradle để tạo lại gói APK
Nếu sử dụng hệ thống kiểm soát bản sửa đổi để quản lý mã nguồn cho ứng dụng, bạn cần thêm 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 bản sửa đổi.
Thêm một bước bản dựng để 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 bản dựng để sử dụng(các) gói APK do Gradle tạo khi kiểm thử bằng Test Lab. Bạn có thể sử 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 bản dựng Test Lab vào Jenkins
Bây giờ, bạn đã sẵn sàng thêm một bước xây dựng vào Jenkins để chạy Test Lab bằng dòng lệnh gcloud.
Cách thêm bước tạo bản dựng gcloud
- Trên trang chính của dự án, hãy nhấp vào Định cấu hình.
Trên trang project configuration (cấu hình dự án), hãy di chuyển xuống phần Build (Tạo), sau đó chọn Execute shell (Thực thi shell) trong trình đơn Add build step (Thêm bước tạo).
Trong cửa sổ Jenkins Execute shell command (Thực thi lệnh shell của Jenkins), hãy nhập nội dung sau, thay thế <local_server_path> cho đường dẫn đến ứng dụng mẫu trên máy chủ, <app_apk> cho tệp APK của ứng dụng và <app_test_apk> cho tệp 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 quá trình kiểm thử ứng dụng, bạn có thể xem lại kết quả kiểm thử trong bảng điều khiển Firebase hoặc trong bộ chứa Google Cloud Storage trong dự án. Bạn cũng có thể thêm lệnh gsutil
vào lệnh shell hiển thị ở 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 đó: