ทดสอบ UI ของแอปเพื่อยืนยันว่าลักษณะการทำงานของโค้ด Compose ถูกต้อง ซึ่งจะช่วยให้คุณตรวจพบข้อผิดพลาดได้ตั้งแต่เนิ่นๆ และปรับปรุงคุณภาพของแอป
Compose มีชุด API การทดสอบเพื่อค้นหาองค์ประกอบ ยืนยันแอตทริบิวต์ และดำเนินการของผู้ใช้ นอกจากนี้ API ยังมีฟีเจอร์ขั้นสูง เช่น การจัดการเวลา ใช้ API เหล่านี้เพื่อสร้างการทดสอบที่มีประสิทธิภาพซึ่งจะยืนยันลักษณะการทำงานของแอป
View
หากคุณใช้ View แทน Compose โปรดดูส่วนทดสอบแอปทั่วไปใน Test apps on Android
โดยเฉพาะอย่างยิ่ง จุดเริ่มต้นที่เหมาะสมคือคำแนะนำเกี่ยวกับการทดสอบ UI อัตโนมัติ ซึ่งจะอธิบายวิธีที่คุณสามารถทำการทดสอบอัตโนมัติที่ทำงานในอุปกรณ์ รวมถึงเมื่อใช้ View
แนวคิดหลัก
แนวคิดสำคัญบางประการสำหรับการทดสอบโค้ด Compose มีดังนี้
- Semantics: Semantics ให้ความหมายแก่ UI ซึ่งช่วยให้การทดสอบโต้ตอบกับองค์ประกอบที่เฉพาะเจาะจงได้
- API การทดสอบ: API การทดสอบช่วยให้คุณค้นหาองค์ประกอบ ยืนยัน แอตทริบิวต์ และดำเนินการของผู้ใช้ได้
- การซิงโครไนซ์: การซิงโครไนซ์จะยืนยันว่าการทดสอบรอให้ UI อยู่ในสถานะไม่ได้ใช้งานก่อนที่จะดำเนินการหรือทำการยืนยัน
- ความสามารถในการทำงานร่วมกัน: ความสามารถในการทำงานร่วมกันช่วยให้การทดสอบทำงานได้ทั้งกับ องค์ประกอบที่อิงตาม Compose และ View ในแอปเดียวกัน
ชีตสรุปการทดสอบ
ดูชีตสรุปการทดสอบเพื่อดูภาพรวมของหัวข้อสำคัญทั้งหมดที่คุณควร รู้เกี่ยวกับการทดสอบใน Compose
ตั้งค่า
ตั้งค่าแอปเพื่อให้คุณทดสอบโค้ด Compose ได้
ขั้นแรก ให้เพิ่มทรัพยากร Dependency ต่อไปนี้ลงในไฟล์ build.gradle ของโมดูลที่มีการทดสอบ UI
// Test rules and transitive dependencies:
androidTestImplementation("androidx.compose.ui:ui-test-junit4:$compose_version")
// Needed for createComposeRule(), but not for createAndroidComposeRule<YourActivity>():
debugImplementation("androidx.compose.ui:ui-test-manifest:$compose_version")
โมดูลนี้มี ComposeTestRule และการใช้งานสำหรับ Android
ที่เรียกว่า AndroidComposeTestRule คุณสามารถตั้งค่าเนื้อหา Compose หรือเข้าถึงกิจกรรมผ่านกฎนี้ได้ คุณสร้างกฎโดยใช้ฟังก์ชัน Factory
ไม่ว่าจะเป็น createComposeRule หรือหากต้องการเข้าถึงกิจกรรม
createAndroidComposeRule การทดสอบ UI ทั่วไปสำหรับ Compose มีลักษณะดังนี้
// file: app/src/androidTest/java/com/package/MyComposeTest.kt
class MyComposeTest {
@get:Rule val composeTestRule = createComposeRule()
// use createAndroidComposeRule<YourActivity>() if you need access to
// an activity
@Test
fun myTest() {
// Start the app
composeTestRule.setContent {
MyAppTheme {
MainScreen(uiState = fakeUiState, /*...*/)
}
}
composeTestRule.onNodeWithText("Continue").performClick()
composeTestRule.onNodeWithText("Welcome").assertIsDisplayed()
}
}
แหล่งข้อมูลเพิ่มเติม
- ทดสอบแอปใน Android: หน้า Landing Page หลักของการทดสอบ Android จะให้มุมมองที่กว้างขึ้นเกี่ยวกับหลักพื้นฐานและเทคนิคการทดสอบ
- หลักพื้นฐานของการทดสอบ: ดูข้อมูลเพิ่มเติม เกี่ยวกับแนวคิดหลักเบื้องหลังการทดสอบแอป Android
- การทดสอบในเครื่อง: คุณสามารถทำการทดสอบบางอย่าง ในเครื่องได้ในเวิร์กสเตชันของคุณเอง
- การทดสอบการวัดคุม: คุณควรทำการทดสอบการวัดคุมด้วย นั่นคือการทดสอบที่ทำงานในอุปกรณ์โดยตรง
- การรวมอย่างต่อเนื่อง: การรวมอย่างต่อเนื่องช่วยให้คุณรวมการทดสอบเข้ากับไปป์ไลน์การติดตั้งใช้งานได้
- ทดสอบขนาดหน้าจอต่างๆ: เนื่องจากผู้ใช้มีอุปกรณ์ให้เลือกมากมาย คุณจึงควรทดสอบขนาดหน้าจอต่างๆ
- **Espresso**: แม้ว่า Espresso จะมีไว้สำหรับ UI ที่อิงตาม View แต่ความรู้เกี่ยวกับ Espresso ก็ยังเป็นประโยชน์สำหรับบางแง่มุมของการทดสอบ Compose
Codelab
ลองทำ Codelab การทดสอบ Jetpack Compose เพื่อดูข้อมูลเพิ่มเติม
ตัวอย่าง
แนะนำสำหรับคุณ
- หมายเหตุ: ข้อความลิงก์จะแสดงเมื่อ JavaScript ปิดอยู่
- Semantics ใน Compose
- ระยะขอบหน้าต่างใน Compose
- ปัจจัยอื่นๆ ที่ควรพิจารณา