Chạy XCTest

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:

  1. Mở dự án của bạn trong Xcode.
  2. Trong thanh trình đơn macOS, hãy chọn File (Tệp) > Project Settings... (Cài đặt dự án…).
  3. 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.
  4. 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:

  1. 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).
  2. 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ử

  1. Đả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.

  2. 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.

  3. 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

  1. 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:

  1. Mở Trình tìm kiếm rồi chuyển đến FOLDER_WITH_TEST_OUTPUT.

  2. 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.

  3. Chọn thư mục Debug-iphoneosYOUR_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.