تتضمّن مكتبة Compose قاعدة ComposeTestRule التي تتيح لك كتابة اختبارات للصور المتحركة بطريقة محدّدة مع التحكّم الكامل في ساعة الاختبار. ويسمح لك ذلك بالتحقّق من القيم الوسيطة للصور المتحركة. بالإضافة إلى ذلك، يمكن تشغيل الاختبار بشكل أسرع من المدة الفعلية للصورة المتحركة.
تعرض ComposeTestRule ساعة الاختبار الخاصة بها على أنّها mainClock. يمكنك ضبط السمة autoAdvance على "خطأ" للتحكّم في الساعة في رمز الاختبار. بعد بدء الصورة المتحركة التي تريد اختبارها، يمكن تقديم الساعة باستخدام advanceTimeBy.
يُرجى العِلم أنّ advanceTimeBy لا تقدّم الساعة بالمدة المحدّدة بالضبط. بل يتم تقريبها إلى أقرب مدة تكون مضاعفًا لمدة الإطار.
@get:Rule val rule = createComposeRule() @Test fun testAnimationWithClock() { // Pause animations rule.mainClock.autoAdvance = false var enabled by mutableStateOf(false) rule.setContent { val color by animateColorAsState( targetValue = if (enabled) Color.Red else Color.Green, animationSpec = tween(durationMillis = 250) ) Box(Modifier.size(64.dp).background(color)) } // Initiate the animation. enabled = true // Let the animation proceed. rule.mainClock.advanceTimeBy(50L) // Compare the result with the image showing the expected result. // `assertAgainGolden` needs to be implemented in your code. rule.onRoot().captureToImage().assertAgainstGolden() }
اقتراحات مخصصة لك
- ملاحظة: يتم عرض نص الرابط عندما تكون JavaScript غير مفعّلة
- اختبار تنسيق Compose
- اعتبارات أخرى
- تخصيص الصور المتحركة {:#customize-animations}