Bolehkah MySQL Digunakan Dalam Memori untuk Pengujian JUnit?
Dalam pembangunan perisian, menguji interaksi pangkalan data adalah penting, tetapi ia boleh memerlukan persediaan dan pengurusan pangkalan data sepenuhnya. Untuk memudahkan proses ini, sesetengah pembangun menggunakan pangkalan data SQLite atau H2 untuk ujian dalam memori. Walau bagaimanapun, adakah terdapat pilihan untuk menggunakan MySQL sendiri dalam konteks ini?
Penyelesaian: MariaDB4j
Jawapannya terletak pada MariaDB4j, kebergantungan Gradle/Maven yang menyediakan sepenuhnya pangkalan data MySQL dalam memori yang serasi untuk ujian JUnit. Ia memerlukan persediaan minimum:
DB database = DB.newEmbeddedDB(3306); database.start(); Connection connection = DriverManager.getConnection("jdbc:mysql://localhost/test", "root", "");
Untuk permulaan tambahan, skrip permulaan boleh disertakan:
database.source("path/to/resource.sql");
Pertimbangan
Sementara MariaDB4j menyediakan penyelesaian MySQL tertanam, ia tidak beroperasi dalam ingatan semata-mata. Ia mencipta fail sementara dalam folder sementara sistem. Akibatnya, ia bukanlah penyelesaian dalam ingatan yang sebenar, dan ujian yang bergantung padanya mungkin tersasar daripada definisi ujian unit tradisional, yang menentukan kebebasan daripada sumber luaran.
Atas ialah kandungan terperinci Adakah MariaDB4j Penyelesaian untuk Ujian MySQL Dalam Memori dengan JUnit?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!