Bắt đầu kiểm thử bằng các hệ thống tích hợp liên tục (CI)

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 lầ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

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:

  1. Thiết lập gcloud. Làm theo hướng dẫn trong bài viết 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 Google Cloud SDK cục bộ.

  2. Tạo và cấp quyền cho một 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 captcha, nếu không, các quy trình này có thể chặn bản dựng CI của bạn. Tạo một tài khoản dịch vụ có vai trò Editor trong Google Cloud console rồi 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).

  3. 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 APICloud 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 Enable API (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 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 trong bài viết Cài đặt Jenkins. Sau khi cài đặt Jenkins, hãy làm theo hướng dẫn trong bài viết 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 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 mới cài đặt. 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 tính năng 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

  1. Chuyển đến trang tổng quan Jenkins trên máy chủ. Để 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.
  2. Trên trang tổng quan 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 chế độ bảo mật chung).
  3. Trên trang Configure Global Security (Định cấu hình chế độ bảo mật chung), hãy nhấp vào Enable security (Bật chế độ bảo mật), rồi nhấp vào Save (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ả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 hoạt động 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 một dự án Jenkins

  1. Chuyển đến trang tổng quan Jenkins trên máy chủ. Để 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.
  2. Trên trang tổng quan Jenkins, hãy nhấp vào New Item (Mục mới).
  3. Nhập tên cho dự án của bạn vào trường Item name (Tên mục):
    • Chọn Freestyle project (Dự án tự do) để tạo một dự án sử dụng một cấu hình bản dựng.
    • 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 tạo ứng dụng 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 nhiều cấu hình là lựa chọn tốt nhất.
  4. Nhấp vào Save (Lưu).

Sau khi bạn tạo dự án, trình duyệt web sẽ hiển thị trang chính cho dự án của bạn.

Thêm các bước kiểm soát bản sửa đổi và 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 các 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 các bản cập nhật cho ứng dụng của bạn đượ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 bài viết Định cấu hình bản dựng tự động.

Thêm các bước bản dựng Gradle để tạo lại các gói APK

Nếu sử dụng một 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 một bước bản dựng Gradle để tạo các 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.

  1. Thêm một bước bản dựng để chạy các lệnh sau trong thư mục chính cho ứng dụng của bạn:

    ./gradlew :app:assembleDebug
    ./gradlew :app:assembleDebugAndroidTest
    

  2. 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 bản dựng Test Lab vào Jenkins

Giờ đây, bạn đã sẵn sàng thêm một bước bản dựng vào Jenkins để chạy Test Lab bằng dòng lệnh gcloud.

Cách thêm một bước bản dựng gcloud

  1. Trên trang chính cho dự án của bạn, hãy nhấp vào Configure (Định cấu hình).
  2. Trên trang project configuration (cấu hình dự án), hãy di chuyển xuống phần Build (Bản dựng), rồi chọn Execute shell (Chạy shell) trong trình đơn Add build step (Thêm bước bản dựng).

  3. Trong cửa sổ Jenkins Execute shell command (Lệnh chạy shell 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 APK của ứng dụng và <app_test_apk> cho 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 việc kiểm thử ứng dụng, bạn có thể xem kết quả kiểm thử trong Firebase console hoặc trong một vùng chứa Google Cloud Storage trong dự án của mình. Bạn cũng có thể thêm lệnh gsutil vào lệnh shell được 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 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 đó: