คู่มือนี้จะอธิบายวิธีเตรียม XCTest สำหรับการทดสอบใน Firebase Test Lab
ขั้นตอนที่ 1: กำหนดค่าตำแหน่งข้อมูลอนุมานของโปรเจ็กต์
Xcode จะวางอาร์ติแฟกต์ iOS ที่คอมไพล์แล้ว รวมถึงการทดสอบที่คุณสร้างไว้ในไดเรกทอรี Derived Data คุณเก็บตำแหน่งเริ่มต้นสำหรับไดเรกทอรีนั้นไว้ได้หากต้องการ แต่การเลือกตำแหน่งที่เข้าถึงได้ง่ายกว่าสำหรับไฟล์มักจะมีประโยชน์มากกว่า โดยเฉพาะในกรณีที่คุณจะต้องทำการทดสอบด้วย Test Lab บ่อยครั้ง
- เปิดโปรเจ็กต์ใน Xcode
- ในแถบเมนูของ macOS ให้เลือกไฟล์ > การตั้งค่าโปรเจ็กต์...
- เปลี่ยนเมนูแบบเลื่อนลงข้อมูลอนุมานจากตำแหน่งเริ่มต้นเป็นตำแหน่งที่กำหนดเอง
- ในช่องด้านล่างเมนูแบบเลื่อนลง ให้เลือกตำแหน่งสำหรับ Xcode เพื่อแสดงผลลัพธ์การทดสอบ (นี่คือ FOLDER_WITH_TEST_OUTPUT ของคุณ)
ขั้นตอนที่ 2: สร้างไฟล์ทดสอบทั่วไป
Test Lab เรียกใช้การทดสอบหน่วยและการทดสอบ UI โดยใช้เฟรมเวิร์ก XCTest หากต้องการเรียกใช้ XCTests ของแอปในอุปกรณ์ Test Lab ให้สร้างแอปเพื่อทดสอบในอุปกรณ์ iOS ทั่วไป โดยทำดังนี้
- จากเมนูแบบเลื่อนลงของอุปกรณ์ที่ด้านบนของหน้าต่างพื้นที่ทํางาน Xcode ให้เลือกอุปกรณ์ iOS ทั่วไป
- ในแถบเมนูของ macOS ให้เลือกผลิตภัณฑ์ > สร้างสำหรับ > การทดสอบ
หรือจะสร้าง XCTest จากบรรทัดคำสั่งก็ได้ ใช้คำสั่งต่อไปนี้ในเทอร์มินัล
โปรเจ็กต์
xcodebuild -project PATH/TO/YOUR_WORKSPACE/YOUR_PROJECT.xcodeproj \ -scheme YOUR_SCHEME \ -derivedDataPath FOLDER_WITH_TEST_OUTPUT \ -sdk iphoneos build-for-testing
พื้นที่ทำงาน
xcodebuild -workspace PATH/TO/YOUR_WORKSPACE.xcworkspace \ -scheme YOUR_SCHEME \ -derivedDataPath FOLDER_WITH_TEST_OUTPUT \ -sdk iphoneos build-for-testing
ขั้นตอนที่ 3: ลงชื่อทดสอบและยืนยัน
ตรวจสอบว่าอาร์ติแฟกต์ทั้งหมดในแอปและการทดสอบได้รับการลงนามแล้ว เช่น คุณจะทำผ่าน Xcode ได้โดยระบุการตั้งค่าการรับรอง เช่น โปรไฟล์การจัดสรรและข้อมูลระบุตัวตน ดูข้อมูลเพิ่มเติมได้ที่การรับรองโค้ดของ Apple
ยืนยันลายเซ็นแอปโดยเรียกใช้
codesign --verify --deep --verbose /path/to/MyApp.app
โดยที่ "MyApp" คือชื่อแอปในโฟลเดอร์ที่แตกไฟล์แล้ว ซึ่งจะแตกต่างกันไปในแต่ละโปรเจ็กต์ ผลลัพธ์ที่คาดหวังคือMyApp.app: valid on disk
หากคุณเรียกใช้ XCUITest คุณต้องยืนยันการทดสอบและโปรแกรมรันโดยเรียกใช้
codesign --verify --deep --verbose /path/to/MyTest-Runner.app
โดยที่ "MyTest" คือชื่อโปรแกรมรันในโฟลเดอร์ที่แตกไฟล์แล้ว ซึ่งจะแตกต่างกันไปตามแต่ละโปรเจ็กต์ ผลลัพธ์ที่คาดหวังคือMyTest-Runner.app: valid on disk
ขั้นตอนที่ 4: แพ็กเกจแอปและทดสอบการอัปโหลด
หลังจากสร้างการทดสอบเรียบร้อยแล้ว ให้ใส่ไฟล์ลงในไฟล์ ZIP เพื่ออัปโหลดไปยัง Test Lab
cd FOLDER_WITH_TEST_OUTPUT/Build/Products : \ zip -r MyTests.zip Debug-iphoneos YOUR_SCHEME_iphoneosDEPLOYMENT_TARGET-arm64.xctestrun
นอกจากนี้ คุณยังแพ็กเกจการทดสอบโดยบีบอัดไฟล์ทดสอบด้วยตนเองได้ ดังนี้
เปิด Finder แล้วไปที่
FOLDER_WITH_TEST_OUTPUT
เปิดโฟลเดอร์ที่มีชื่อโปรเจ็กต์เป็นคำนำหน้า แล้วไปที่โฟลเดอร์
Build/Products
ภายในเลือกโฟลเดอร์
Debug-iphoneos
และYOUR_SCHEME_iphoneosDEPLOYMENT_TARGET-arm64.xctestrun
แล้วบีบอัด
ขั้นตอนที่ 5: (ไม่บังคับ) เรียกใช้การทดสอบในเครื่อง
ก่อนทำการทดสอบด้วย Test Lab คุณสามารถทดสอบในเครื่องด้วยอุปกรณ์ที่เชื่อมต่อ USB เพื่อตรวจสอบคุณภาพของลักษณะการทำงาน ดังนี้
xcodebuild test-without-building \ -xctestrun "Derived Data/Build/Products/YOUR_SCHEME.xctestrun" \ -destination id=your-phone-id
ขั้นตอนถัดไป
อัปโหลดและเรียกใช้การทดสอบในคอนโซล Firebase หรือ gcloud CLI