Pengantar Pengujian di Java
Maria Milusheva
Senior Software Engineer
Pertimbangkan:
List<Integer> newList = new ArrayList<Integer>();
newList.add(10);
newList.add(20);
newList.add(30);
Cara lebih cepat dan singkat:
List<Integer> newList = List.of(10, 20, 30);
Berlaku sama untuk Set dan Map di Java Collections
Objek yang dibuat dengan .of() umumnya immutable (tidak bisa diubah)
Pertimbangkan kelas berikut:
class Person {
String firstName;
String lastName;
public Person(String firstName, String lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
public String fullName(Person person) {
return firstName + " " + lastName;
}
}
Kita menggunakan Arguments untuk meneruskan banyak argumen dari tipe apa pun.
Arguments dapat memuat sejumlah objek apa pun.
Contoh:
Arguments.of(new Person("Monty", "Python"), "Monty Python");
Sekarang kita dapat menggunakannya di tipe @ParameterizedTest berikutnya.
@MethodSource memungkinkan kita meneruskan objek apa pun ke tes.
Tesnya seperti ini:
@ParameterizedTest
@MethodSource("provideNames")
void testFullName(Person person, String expectedFullName) {
assertEquals(person.fullName(person), expectedFullName);
}
Metode untuk @MethodSource:
private static List<Arguments> provideNames() {
List<Arguments> args = new ArrayList<>();
args.add(Arguments.of(new Person("Robert", "Martin"), "Robert Martin"));
args.add(Arguments.of(new Person("Heinz", "Kabutz"), "Heinz Kabutz"));
return args;
}
Catatan: metode harus static
Catatan: banyak tipe nilai balik diizinkan; List<Arguments> yang paling sederhana
Metode untuk @MethodSource:
private static List<Arguments> provideNames() {
return List.of(
Arguments.of(new Person("John", "Doe"), "John Doe"),
Arguments.of(new Person("Jane", "Doe"), "Jane Doe"),
Arguments.of(new Person("Alice", "Bob"), "Alice Bob"));
}
Pertimbangkan pengujian basis data berikut:
@Test void process_savesToInfoStore_whenInfoMessage() { InfoStore infoStore = mock(InfoStore.class); ErrorStore errorStore = mock(ErrorStore.class); MessageProcessor messageProcessor = new MessageProcessor(infoStore, errorStore);messageProcessor.saveMessage("[INFO] Process started.");verify(infoStore).save("[INFO] Process started."); verifyNoInteractions(errorStore); }
Kita dapat memakai anotasi @BeforeEach untuk membuat metode yang dijalankan sebelum tiap tes:
import org.junit.jupiter.api.BeforeEach;
Untuk menggunakannya, deklarasikan objek sebagai field terlebih dahulu:
class MessageProcessorTest {
private InfoStore infoStore;
private ErrorStore errorStore;
private MessageProcessor messageProcessor;
Buat tiap objek di metode terpisah:
@BeforeEach
void setUp() {
this.infoStore = mock(InfoStore.class);
this.errorStore = mock(errorStore.class);
this.messageProcessor = new MessageProcessor(infoStore, errorStore);
}
Kelas tes menjadi:
@Test
void process_savesToInfoStore_whenInfoMessage() {
messageProcessor.process("[INFO] Process started.");
verify(infoStore).save("[INFO] Process started.");
verifyNoInteractions(errorStore);
}
Keseluruhan alur:
class MessageProcessorTest { private InfoStore infoStore; // Deklarasi field@BeforeEach void setUp() { this.infoStore = mock(InfoStore.class); // Inisialisasi field }@Test void process_savesToInfoStore_whenInfoMessage() { // Gunakan field } }
Pengantar Pengujian di Java