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() }
আপনার জন্য প্রস্তাবিত
- দ্রষ্টব্য: জাভাস্ক্রিপ্ট বন্ধ থাকলেও লিঙ্কের লেখা প্রদর্শিত হয়।
- আপনার কম্পোজ লেআউট পরীক্ষা করা হচ্ছে
- অন্যান্য বিবেচ্য বিষয়
- অ্যানিমেশন কাস্টমাইজ করুন {:#customize-animations}