Compose 提供了 ComposeTestRule
,它允许您以确定性的方式编写动画测试,并完全控制测试时钟。这使您可以验证动画的中间值。此外,测试的运行速度可以快于动画的实际持续时间。
ComposeTestRule
将其测试时钟公开为 mainClock
。您可以将 autoAdvance
属性设置为 false 以在测试代码中控制时钟。在启动要测试的动画后,可以使用 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}