Hướng dẫn này mô tả cách chuẩn bị XCTest để kiểm thử trong Firebase Test Lab.
Bước 1: Định cấu hình vị trí Dữ liệu phái sinh của dự án
Xcode đặt các cấu phần phần mềm iOS đã biên dịch, bao gồm mọi chương trình kiểm thử bạn tạo, trong thư mục Data (Dữ liệu) phái sinh. Bạn có thể giữ nguyên vị trí mặc định cho thư mục đó nếu muốn, nhưng thường thì bạn nên chọn một vị trí dễ truy cập hơn cho các tệp, đặc biệt là nếu bạn thường xuyên chạy kiểm thử bằng Test Lab:
- Mở dự án của bạn trong Xcode.
- Trong thanh trình đơn macOS, hãy chọn File (Tệp) > Project Settings... (Cài đặt dự án…).
- Thay đổi trình đơn thả xuống Dữ liệu phái sinh từ Vị trí mặc định thành Vị trí tuỳ chỉnh.
- Trong trường bên dưới trình đơn thả xuống, hãy chọn một vị trí để Xcode xuất kết quả kiểm thử. (Đây là FOLDER_WITH_TEST_OUTPUT của bạn)
Bước 2: Tạo tệp kiểm thử chung
Test Lab chạy kiểm thử đơn vị và kiểm thử giao diện người dùng bằng khung XCTest. Để chạy XCTests của ứng dụng trên thiết bị Test Lab, hãy tạo ứng dụng đó để kiểm thử trên Thiết bị iOS chung:
- Trong trình đơn thả xuống về thiết bị ở đầu cửa sổ không gian làm việc Xcode, hãy chọn Generic iOS Device (Thiết bị iOS chung).
- Trong thanh trình đơn macOS, hãy chọn Product (Sản phẩm) > Build For (Tạo cho) > Testing (Kiểm thử).
Ngoài ra, bạn có thể tạo XCTest từ dòng lệnh. Sử dụng lệnh sau trong một cửa sổ dòng lệnh:
dự án
xcodebuild -project PATH/TO/YOUR_WORKSPACE/YOUR_PROJECT.xcodeproj \ -scheme YOUR_SCHEME \ -derivedDataPath FOLDER_WITH_TEST_OUTPUT \ -sdk iphoneos build-for-testing
không gian làm việc
xcodebuild -workspace PATH/TO/YOUR_WORKSPACE.xcworkspace \ -scheme YOUR_SCHEME \ -derivedDataPath FOLDER_WITH_TEST_OUTPUT \ -sdk iphoneos build-for-testing
Bước 3: Ký và xác minh kiểm thử
Đảm bảo tất cả cấu phần phần mềm trong ứng dụng và kiểm thử đều được ký. Ví dụ: bạn có thể thực hiện việc này thông qua Xcode bằng cách chỉ định các chế độ cài đặt ký như hồ sơ cấp phép và danh tính. Để biết thêm thông tin, hãy xem bài viết Ký mã của Apple.
Xác minh chữ ký ứng dụng bằng cách chạy
codesign --verify --deep --verbose /path/to/MyApp.app
, trong đó "MyApp" là tên của ứng dụng bên trong thư mục đã giải nén. Điều này tuỳ thuộc vào từng dự án. Kết quả dự kiến làMyApp.app: valid on disk
.Nếu đang chạy XCUITest, bạn cần xác minh quy trình kiểm thử và trình chạy bằng cách chạy
codesign --verify --deep --verbose /path/to/MyTest-Runner.app
, trong đó "MyTest" là tên của trình chạy bên trong thư mục đã giải nén. Điều này còn tuỳ thuộc vào từng dự án. Kết quả dự kiến làMyTest-Runner.app: valid on disk
.
Bước 4: Đóng gói ứng dụng của bạn và thử nghiệm để tải lên
Sau khi bản kiểm thử của bạn tạo thành công, hãy nén bản kiểm thử đó để tải lên Test Lab:
cd FOLDER_WITH_TEST_OUTPUT/Build/Products : \ zip -r MyTests.zip Debug-iphoneos YOUR_SCHEME_iphoneosDEPLOYMENT_TARGET-arm64.xctestrun
Bạn cũng có thể đóng gói kiểm thử bằng cách nén các tệp kiểm thử theo cách thủ công:
Mở Trình tìm kiếm rồi chuyển đến
FOLDER_WITH_TEST_OUTPUT
.Mở thư mục có tiền tố là tên dự án, sau đó chuyển đến thư mục
Build/Products
bên trong.Chọn thư mục
Debug-iphoneos
vàYOUR_SCHEME_iphoneosDEPLOYMENT_TARGET-arm64.xctestrun
rồi nén các thư mục đó.
Bước 5: (Không bắt buộc) Chạy kiểm thử cục bộ
Trước khi chạy kiểm thử bằng Test Lab, bạn có thể chạy kiểm thử trên thiết bị có kết nối USB để kiểm tra chất lượng hành vi của kiểm thử:
xcodebuild test-without-building \ -xctestrun "Derived Data/Build/Products/YOUR_SCHEME.xctestrun" \ -destination id=your-phone-id
Các bước tiếp theo
Tải lên và chạy thử nghiệm trong bảng điều khiển Firebase hoặc gcloud CLI.