Menyesuaikan Nilai Pulangan Mockito untuk Panggilan Kaedah Berulang
Apabila menguji senario yang melibatkan respons bukan penentu, ia berguna untuk mensimulasikan kaedah mengembalikan nilai yang berbeza pada seruan berikutnya. Mockito, rangka kerja mengejek Java yang popular, menyediakan penyelesaian yang elegan untuk teka-teki ini.
Pertimbangkan contoh kod yang disediakan, di mana ExecutorCompletionService digunakan untuk mengumpulkan tugasan dan mengumpul hasilnya. Untuk menguji logik dengan berkesan tanpa mengira susunan pelaksanaan tugas, kami perlu memastikan kaedah completionService.take() mengembalikan nilai yang berbeza pada masa yang berbeza.
Mockito menyediakan kaedah thenReturn untuk mengawal nilai pulangan kaedah stubbed . Terutama, anda boleh menentukan berbilang nilai dalam kurungan thenReturn. Selepas setiap penyembahan kaedah, Mockito akan mengembalikan nilai dalam susunan yang ditentukan. Contohnya:
<code class="java">when(completionService.take()).thenReturn(value1, value2, value3);</code>
Dalam contoh ini, panggilan pertama ke completionService.take() akan mengembalikan nilai1, panggilan kedua akan mengembalikan nilai2 dan panggilan ketiga akan mengembalikan nilai3. Setelah semua nilai yang ditentukan telah dikembalikan, Mockito akan terus mengembalikan nilai terakhir untuk panggilan berikutnya.
Dengan menggunakan teknik ini, anda boleh mensimulasikan respons bukan penentu dengan berkesan dan memastikan logik ujian anda kekal teguh tanpa mengira susunan tugasan menyelesaikan pelaksanaannya.
Atas ialah kandungan terperinci Bagaimanakah saya boleh mensimulasikan nilai pulangan yang berbeza untuk panggilan kaedah berulang dengan Mockito?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!