QUnit - Panduan Cepat
Pengujian adalah proses memeriksa fungsionalitas aplikasi apakah berfungsi sesuai persyaratan dan untuk memastikan bahwa di tingkat pengembang, pengujian unit muncul. Pengujian unit adalah pengujian entitas tunggal (kelas atau metode). Pengujian unit sangat penting bagi setiap organisasi perangkat lunak untuk menawarkan produk berkualitas kepada klien mereka.
Pengujian unit dapat dilakukan dengan dua cara seperti yang disebutkan pada tabel berikut.
Pengujian manual | Pengujian otomatis |
---|---|
Menjalankan kasus uji secara manual tanpa dukungan alat apa pun yang dikenal sebagai pengujian manual. | Mengambil dukungan alat dan menjalankan kasus uji menggunakan alat otomatisasi dikenal sebagai pengujian otomatisasi. |
Memakan waktu dan membosankan. Karena kasus uji dijalankan oleh sumber daya manusia, ini sangat lambat dan membosankan. | Otomatisasi Cepat. Menjalankan kasus uji secara signifikan lebih cepat daripada sumber daya manusia. |
Investasi besar dalam sumber daya manusia. Karena kasus uji perlu dijalankan secara manual, diperlukan lebih banyak jumlah penguji. | Lebih sedikit investasi dalam sumber daya manusia. Kasus uji dijalankan menggunakan alat otomatisasi, sehingga jumlah penguji yang diperlukan lebih sedikit. |
Kurang dapat diandalkan, karena pengujian mungkin tidak dilakukan dengan tepat setiap kali karena kesalahan manusia. | Lebih terpercaya. Tes otomasi melakukan operasi yang persis sama setiap kali dijalankan. |
Tidak dapat diprogram. Tidak ada pemrograman yang dapat dilakukan untuk menulis pengujian canggih, yang mengambil informasi tersembunyi. | Dapat diprogram. Penguji dapat memprogram pengujian canggih untuk menampilkan informasi tersembunyi. |
Apa itu QUnit?
QUnit adalah kerangka pengujian unit untuk bahasa pemrograman JavaScript. Ini penting dalam pengembangan yang didorong oleh pengujian, dan digunakan oleh proyek jQuery, jQuery UI, dan jQuery Mobile. QUnit mampu menguji basis kode JavaScript umum apa pun.
QUnit mempromosikan gagasan "pengujian pertama kemudian pengkodean", yang menekankan pada pengaturan data pengujian untuk sepotong kode, yang dapat diuji terlebih dahulu dan kemudian diimplementasikan. Pendekatan ini seperti "uji sedikit, buat kode sedikit, uji sedikit, buat kode sedikit ..." yang meningkatkan produktivitas pemrogram dan stabilitas kode program mengurangi stres pemrogram dan waktu yang dihabiskan untuk debugging.
Fitur QUnit
QUnit adalah kerangka kerja sumber terbuka yang digunakan untuk menulis dan menjalankan tes. Berikut ini adalah fitur-fiturnya yang paling menonjol -
QUnit memberikan Assertion untuk menguji hasil yang diharapkan.
QUnit menyediakan perlengkapan Tes untuk tes berjalan.
Tes QUnit memungkinkan untuk menulis kode lebih cepat, yang meningkatkan kualitas.
QUnit sederhana dan elegan. Ini tidak terlalu rumit dan membutuhkan lebih sedikit waktu.
Tes QUnit dapat dijalankan secara otomatis dan mereka memeriksa hasilnya sendiri dan memberikan umpan balik langsung. Tidak perlu menyisir laporan hasil tes secara manual.
Pengujian QUnit dapat diatur ke dalam rangkaian pengujian yang berisi kasus pengujian dan bahkan rangkaian pengujian lainnya.
QUnit menunjukkan kemajuan tes dalam bilah yang berwarna hijau jika tes berjalan dengan baik, dan berubah menjadi merah ketika tes gagal.
Apa itu Kasus Uji Unit?
Kasus Uji Unit adalah bagian dari kode yang memastikan bahwa bagian lain dari kode (metode) berfungsi seperti yang diharapkan. Untuk mencapai hasil yang diinginkan dengan cepat, diperlukan kerangka pengujian. QUnit adalah kerangka pengujian unit yang sempurna untuk bahasa pemrograman JavaScript.
Kasus uji unit tertulis formal ditandai dengan masukan yang diketahui dan keluaran yang diharapkan, yang dikerjakan sebelum pengujian dijalankan. Input yang diketahui harus menguji prasyarat dan keluaran yang diharapkan harus menguji kondisi pasca.
Harus ada setidaknya dua kasus uji unit untuk setiap persyaratan: satu tes positif dan satu tes negatif. Jika persyaratan memiliki sub-persyaratan, setiap sub-persyaratan harus memiliki setidaknya dua kasus uji sebagai positif dan negatif.
Ada dua cara untuk menggunakan QUnit.
Local Installation - Anda dapat mengunduh pustaka QUnit di komputer lokal Anda dan memasukkannya ke dalam kode HTML Anda.
CDN Based Version - Anda dapat menyertakan pustaka QUnit ke dalam kode HTML Anda langsung dari Jaringan Pengiriman Konten (CDN).
Instalasi Lokal
Pergi ke https://code.jquery.com/qunit/ untuk mengunduh versi terbaru yang tersedia.
Tempatkan file qunit-git.js dan qunit-git.css file di direktori situs Anda, misalnya / jquery.
Contoh
Anda bisa memasukkan qunit-git.js dan qunit-git.css file dalam file HTML Anda sebagai berikut -
<html>
<head>
<meta charset = "utf-8">
<title>QUnit basic example</title>
<link rel = "stylesheet" href = "/jquery/qunit-git.css">
<script src = "/jquery/qunit-git.js"></script>
</head>
<body>
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
<script>
QUnit.test( "My First Test", function( assert ) {
var value = "1";
assert.equal( value, "1", "Value should be 1" );
});
</script>
</body>
</html>
Ini akan menghasilkan hasil sebagai berikut -
Versi Berbasis CDN
Anda dapat menyertakan pustaka QUnit ke dalam kode HTML Anda langsung dari Jaringan Pengiriman Konten (CDN).
Kami menggunakan versi jQuery CDN pustaka sepanjang tutorial ini.
Contoh
Mari kita tulis ulang contoh di atas menggunakan pustaka QUnit dari jQuery CDN.
<html>
<head>
<meta charset = "utf-8">
<title>QUnit basic example</title>
<link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-1.22.0.css">
<script src = "https://code.jquery.com/qunit/qunit-1.22.0.js"></script>
</head>
<body>
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
<script>
QUnit.test( "My First Test", function( assert ) {
var value = "1";
assert.equal( value, "1", "Value should be 1" );
});
</script>
</body>
</html>
Ini akan menghasilkan hasil sebagai berikut -
Sekarang kami akan menunjukkan kepada Anda proses langkah demi langkah untuk memulai di QUnit menggunakan contoh dasar.
Impor qunit.js
qunit.js dari pustaka Qunit mewakili runner pengujian dan kerangka kerja pengujian.
<script src = "https://code.jquery.com/qunit/qunit-1.22.0.js"></script>
Impor qunit.css
qunit.css dari pustaka Qunit mengatur gaya halaman rangkaian pengujian untuk menampilkan hasil pengujian.
<link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-1.22.0.css">
Tambahkan Perlengkapan
Tambahkan dua elemen div dengan id = "qunit" dan "qunit-fixture". Elemen div ini diperlukan dan menyediakan perlengkapan untuk pengujian.
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
Buat Fungsi untuk Diuji
function square(x) {
return x * x;
}
Buat Kasus Uji
Lakukan panggilan ke fungsi QUnit.test, dengan dua argumen.
Name - Nama tes untuk menampilkan hasil tes.
Function - Kode pengujian fungsi, memiliki satu atau lebih pernyataan.
QUnit.test( "TestSquare", function( assert ) {
var result = square(2);
assert.equal( result, "4", "square(2) should be 4." );
});
Jalankan Tes
Sekarang mari kita lihat kode lengkap beraksi.
<html>
<head>
<meta charset = "utf-8">
<title>QUnit basic example</title>
<link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-1.22.0.css">
<script src = "https://code.jquery.com/qunit/qunit-1.22.0.js"></script>
</head>
<body>
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
<script>
function square(x) {
return x * x;
}
QUnit.test( "TestSquare", function( assert ) {
var result = square(2);
assert.equal( result, "4", "square(2) should be 4." );
});
</script>
</body>
</html>
Muat halaman di browser. Pelari pengujian memanggilQUnit.test()saat halaman dimuat dan menambahkan pengujian ke antrean. Eksekusi kasus uji ditangguhkan dan dikontrol oleh runner uji.
Verifikasi Output
Anda harus melihat hasil berikut -
Header- Test suite header menampilkan judul halaman, bilah hijau ketika semua pengujian telah lulus. Jika tidak, bilah merah saat setidaknya satu pengujian gagal, bilah dengan tiga kotak centang untuk memfilter hasil tes, dan bilah biru dengan teks navigator.userAgent untuk menampilkan detail browser.
Hide passed tests checkbox - Untuk menyembunyikan kasus uji yang lulus dan hanya menampilkan kasus uji yang gagal.
Check for globals checkbox- Untuk menampilkan daftar semua properti pada objek jendela, sebelum dan sesudah setiap pengujian, kemudian periksa perbedaannya. Modifikasi pada properti akan gagal dalam pengujian.
No try-catch checkbox - Untuk menjalankan kasus pengujian di luar blok coba-tangkap sehingga dalam kasus pengujian melempar pengecualian, testrunner akan mati dan menampilkan pengecualian asli.
Summary- Menunjukkan total waktu yang dibutuhkan untuk menjalankan kasus uji. Total kasus pengujian yang dijalankan dan pernyataan yang gagal.
Contents- Menunjukkan hasil tes. Setiap hasil tes memiliki nama tes yang diikuti dengan pernyataan gagal, lulus, dan total. Setiap entri dapat diklik untuk mendapatkan detail lebih lanjut.
API Penting dari QUnit
Beberapa dari Kategori penting QUnit adalah -
Sr.No. | Kategori | Kegunaan |
---|---|---|
1 | Menegaskan | Satu set metode assert. |
2 | Kontrol Asinkron | Untuk operasi asinkron. |
3 | Panggilan balik | Saat mengintegrasikan QUnit ke alat lain seperti server CI, callback ini dapat digunakan sebagai API untuk membaca hasil pengujian. |
4 | Konfigurasi dan Utilitas | Metode dan properti ini digunakan sebagai pembantu utilitas dan untuk mengkonfigurasi QUnit. Misalnya, untuk menyesuaikan perilaku waktu proses secara langsung, perluas QUnit API melalui pernyataan khusus, dll. |
5 | Uji | Untuk operasi pengujian. |
Kategori: Tegaskan
Ini menyediakan satu set metode assert.
Sr.No. | Metode & Deskripsi |
---|---|
1 | async() Perintahkan QUnit untuk menunggu operasi asinkron. |
2 | deepEqual() Perbandingan rekursif yang dalam, mengerjakan tipe primitif, array, objek, ekspresi reguler, tanggal, dan fungsi. |
3 | equal() Perbandingan yang tidak ketat, secara kasar setara dengan assertEquals JUnit. |
4 | expect() Tentukan berapa banyak pernyataan yang diharapkan untuk dijalankan dalam pengujian. |
5 | notDeepEqual() Perbandingan rekursif dalam terbalik, mengerjakan tipe primitif, array, objek, ekspresi reguler, tanggal, dan fungsi. |
6 | notEqual() Perbandingan yang tidak ketat, memeriksa ketidaksetaraan. |
7 | notOk() Pemeriksaan boolean, kebalikan dari ok () dan assert.ok () CommonJS, dan setara dengan assertFalse () JUnit. Lulus jika argumen pertama salah. |
8 | notPropEqual() Perbandingan ketat dari properti objek sendiri, memeriksa ketidaksamaan. |
9 | notStrictEqual() Perbandingan yang ketat, memeriksa ketidaksetaraan. |
10 | ok() Pemeriksaan boolean, setara dengan assert.ok () CommonJS dan assertTrue () JUnit. Lulus jika argumen pertama benar. |
11 | propEqual() Perbandingan tipe dan nilai yang ketat dari properti objek itu sendiri. |
12 | push() Laporkan hasil pernyataan kustom. |
13 | strictEqual() Perbandingan tipe dan nilai yang ketat. |
14 | throws() Uji apakah callback melontarkan pengecualian, dan secara opsional bandingkan kesalahan yang muncul. |
Kategori: Kontrol Asinkron
Ini menyediakan satu set operasi asynchronous.
Sr.No. | Metode & Deskripsi |
---|---|
1 | async() Perintahkan QUnit untuk menunggu operasi asinkron. |
2 | QUnit.asyncTest() TIDAK DIGUNAKAN LAGI: Tambahkan tes asinkron untuk dijalankan. Tes harus menyertakan panggilan ke QUnit.start (). |
3 | QUnit.start() TIDAK BERLAKU SEBAGIAN: Mulai jalankan pengujian lagi setelah testrunner dihentikan. Lihat QUnit.stop () dan QUnit.config.autostart. |
4 | QUnit.stop() TIDAK DIGUNAKAN LAGI: Tingkatkan jumlah panggilan QUnit.start () yang harus ditunggu oleh testrunner sebelum melanjutkan. |
5 | QUnit.test() Tambahkan tes untuk dijalankan. |
Kategori: Telepon balik
Saat mengintegrasikan QUnit ke alat lain seperti server CI, callback ini dapat digunakan sebagai API untuk membaca hasil pengujian.
Sr.No. | Metode & Deskripsi |
---|---|
1 | QUnit.begin() Daftarkan callback untuk diaktifkan setiap kali rangkaian pengujian dimulai. |
2 | QUnit.done() Daftarkan callback untuk diaktifkan setiap kali rangkaian pengujian berakhir. |
3 | QUnit.log() Daftarkan callback untuk diaktifkan setiap kali pernyataan selesai. |
4 | QUnit.moduleDone() Daftarkan callback untuk diaktifkan setiap kali modul berakhir. |
5 | QUnit.moduleStart() Daftarkan callback untuk diaktifkan setiap kali modul dimulai. |
6 | QUnit.testDone() Daftarkan callback untuk diaktifkan setiap kali pengujian berakhir. |
7 | QUnit.testStart() Daftarkan callback untuk diaktifkan setiap kali pengujian dimulai. |
Kategori: Konfigurasi dan Utilitas
Metode dan properti ini digunakan sebagai pembantu utilitas dan untuk mengkonfigurasi QUnit. Misalnya, untuk menyesuaikan perilaku waktu proses secara langsung, perluas QUnit API melalui pernyataan khusus, dll.
Sr.No. | Metode & Deskripsi |
---|---|
1 | QUnit.assert Ruang nama untuk pernyataan QUnit. |
2 | QUnit.config Konfigurasi untuk QUnit. |
3 | QUnit.dump.parse() Pembuangan data tingkat lanjut dan dapat diperluas untuk JavaScript. |
4 | QUnit.extend() Salin properti yang ditentukan oleh objek mixin ke objek target. |
5 | QUnit.init() TIDAK DIGUNAKAN LAGI: Inisialisasi ulang runner pengujian. |
6 | QUnit.push() TIDAK DIGUNAKAN LAGI: Laporkan hasil pernyataan kustom. |
7 | QUnit.reset() TIDAK DIGUNAKAN LAGI: Setel ulang perlengkapan uji di DOM. |
8 | QUnit.stack() Mengembalikan satu baris string yang mewakili stacktrace (call stack). |
Kategori: Tes
Ini menyediakan satu set operasi pengujian.
Sr.No. | Metode & Deskripsi |
---|---|
1 | QUnit.assert Ruang nama untuk pernyataan QUnit. |
2 | QUnit.asyncTest() TIDAK DIGUNAKAN LAGI: Tambahkan tes asinkron untuk dijalankan. Tes harus menyertakan panggilan ke QUnit.start (). |
3 | QUnit.module() Kelompokkan pengujian terkait di bawah satu label. |
4 | QUnit.only() Menambahkan pengujian untuk dijalankan secara eksklusif, mencegah semua pengujian lainnya berjalan. |
5 | QUnit.skip() Menambahkan tes seperti objek yang akan dilewati. |
6 | QUnit.test() Menambahkan tes untuk dijalankan. |
Semua pernyataan ada di Kategori Assert.
Kategori ini menyediakan sekumpulan metode pernyataan yang berguna untuk menulis tes. Hanya pernyataan yang gagal dicatat.
Sr.No. | Metode & Deskripsi |
---|---|
1 | async() Perintahkan QUnit untuk menunggu operasi asinkron. |
2 | deepEqual() Perbandingan rekursif yang dalam, mengerjakan tipe primitif, array, objek, ekspresi reguler, tanggal, dan fungsi. |
3 | equal() Perbandingan yang tidak ketat, secara kasar setara dengan assertEquals JUnit. |
4 | expect() Tentukan berapa banyak pernyataan yang diharapkan untuk dijalankan dalam pengujian. |
5 | notDeepEqual() Perbandingan rekursif dalam terbalik, mengerjakan tipe primitif, array, objek, ekspresi reguler, tanggal, dan fungsi. |
6 | notEqual() Perbandingan yang tidak ketat, memeriksa ketidaksetaraan. |
7 | notOk() Pemeriksaan boolean, kebalikan dari ok () dan assert.ok () CommonJS, dan setara dengan assertFalse () JUnit. Lulus jika argumen pertama salah. |
8 | notPropEqual() Perbandingan ketat dari properti objek sendiri, memeriksa ketidaksamaan. |
9 | notStrictEqual() Perbandingan yang ketat, memeriksa ketidaksetaraan. |
10 | ok() Pemeriksaan boolean, setara dengan assert.ok () CommonJS dan assertTrue () JUnit. Lulus jika argumen pertama benar. |
11 | propEqual() Perbandingan tipe dan nilai yang ketat dari properti objek itu sendiri. |
12 | push() Laporkan hasil pernyataan kustom. |
13 | strictEqual() Perbandingan tipe dan nilai yang ketat. |
14 | throws() Uji apakah callback melontarkan pengecualian, dan secara opsional bandingkan kesalahan yang muncul. |
Mari kita coba untuk mencakup sebagian besar metode yang disebutkan di atas dalam sebuah contoh.
<html>
<head>
<meta charset = "utf-8">
<title>QUnit basic example</title>
<link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-1.22.0.css">
<script src = "https://code.jquery.com/qunit/qunit-1.22.0.js"></script>
</head>
<body>
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
<script>
QUnit.test( "TestSuite", function( assert ) {
//test data
var str1 = "abc";
var str2 = "abc";
var str3 = null;
var val1 = 5;
var val2 = 6;
var expectedArray = ["one", "two", "three"];
var resultArray = ["one", "two", "three"];
//Check that two objects are equal
assert.equal(str1, str2, "Strings passed are equal.");
//Check that two objects are not equal
assert.notEqual(str1,str3, "Strings passed are not equal.");
//Check that a condition is true
assert.ok(val1 < val2, val1 + " is less than " + val2);
//Check that a condition is false
assert.notOk(val1 > val2, val2 + " is not less than " + val1);
//Check whether two arrays are equal to each other.
assert.deepEqual(expectedArray, resultArray ,"Arrays passed are equal.");
//Check whether two arrays are equal to each other.
assert.notDeepEqual(expectedArray, ["one", "two"],
"Arrays passed are not equal.");
});
</script>
</body>
</html>
Verifikasi Output
Anda harus melihat hasil berikut -
Bab ini menjelaskan prosedur pelaksanaan metode dalam QUnit, yang menyatakan metode mana yang dipanggil pertama kali dan setelah itu. Berikut adalah prosedur pelaksanaan metode API uji QUnit dengan sebuah contoh.
<html>
<head>
<meta charset = "utf-8">
<title>QUnit basic example</title>
<link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-1.22.0.css">
<script src = "https://code.jquery.com/qunit/qunit-1.22.0.js"></script>
</head>
<body>
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
<script>
QUnit.module( "Module A", {
beforeEach: function( assert ) {
assert.ok( true, "before test case" );
}, afterEach: function( assert ) {
assert.ok( true, "after test case" );
}
});
QUnit.test( "test case 1", function( assert ) {
assert.ok( true, "Module A: in test case 1" );
});
QUnit.test( "test case 2", function( assert ) {
assert.ok( true, "Module A: in test case 2" );
});
QUnit.module( "Module B" );
QUnit.test( "test case 1", function( assert ) {
assert.ok( true, "Module B: in test case 1" );
});
QUnit.test( "test case 2", function( assert ) {
assert.ok( true, "Module B: in test case 2" );
});
</script>
</body>
</html>
Verifikasi Output
Anda harus melihat hasil berikut -
Beginilah prosedur eksekusi QUnit.
Modul ini digunakan untuk mengelompokkan kasus uji.
beforeEach() metode dijalankan untuk setiap kasus uji namun sebelum menjalankan kasus uji.
afterEach() metode dijalankan untuk setiap kasus uji namun setelah eksekusi kasus uji.
Diantara beforeEach() dan afterEach() setiap kasus uji dijalankan.
Panggilan QUnit.module() sekali lagi, cukup setel ulang fungsi beforeEach / afterEach yang ditentukan oleh modul lain sebelumnya.
Terkadang kode kita belum siap dan kasus uji yang ditulis untuk menguji metode / kode tersebut gagal jika dijalankan. QUnit.skipmembantu dalam hal ini. Metode pengujian yang ditulis menggunakan metode Skip tidak akan dijalankan. Mari kita lihat metode Skip beraksi.
<html>
<head>
<meta charset = "utf-8">
<title>QUnit basic example</title>
<link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-1.22.0.css">
<script src = "https://code.jquery.com/qunit/qunit-1.22.0.js"></script>
</head>
<body>
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
<script>
QUnit.module( "Module A", {
beforeEach: function( assert ) {
assert.ok( true, "before test case" );
}, afterEach: function( assert ) {
assert.ok( true, "after test case" );
}
});
QUnit.test( "test case 1", function( assert ) {
assert.ok( true, "Module A: in test case 1" );
});
QUnit.skip( "test case 2", function( assert ) {
assert.ok( true, "Module A: in test case 2" );
});
QUnit.module( "Module B" );
QUnit.test( "test case 1", function( assert ) {
assert.ok( true, "Module B: in test case 1" );
});
QUnit.skip( "test case 2", function( assert ) {
assert.ok( true, "Module B: in test case 2" );
});
</script>
</body>
</html>
Verifikasi Output
Anda harus melihat hasil berikut -
Terkadang kode kita belum siap dan kasus uji yang ditulis untuk menguji metode / kode tersebut gagal, jika dijalankan. QUnit.onlymembantu dalam hal ini. Metode pengujian yang ditulis hanya dengan metode akan dijalankan sementara pengujian lainnya tidak akan berjalan. Jika lebih dari satu metode saja yang ditentukan, maka hanya metode pertama yang akan dijalankan. Mari kita lihat hanya metode dalam tindakan.
<html>
<head>
<meta charset = "utf-8">
<title>QUnit basic example</title>
<link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-1.22.0.css">
<script src = "https://code.jquery.com/qunit/qunit-1.22.0.js"></script>
</head>
<body>
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
<script>
QUnit.module( "Module A", {
beforeEach: function( assert ) {
assert.ok( true, "before test case" );
}, afterEach: function( assert ) {
assert.ok( true, "after test case" );
}
});
QUnit.test( "test case 1", function( assert ) {
assert.ok( true, "Module A: in test case 1" );
});
QUnit.only( "test case 2", function( assert ) {
assert.ok( true, "Module A: in test case 2" );
});
QUnit.test( "test case 3", function( assert ) {
assert.ok( true, "Module A: in test case 3" );
});
QUnit.test( "test case 4", function( assert ) {
assert.ok( true, "Module A: in test case 4" );
});
</script>
</body>
</html>
Verifikasi Output
Anda harus melihat hasil berikut -
Untuk setiap operasi asinkron di QUnit.test() panggilan balik, gunakan assert.async(), yang mengembalikan fungsi "selesai" yang harus dipanggil saat operasi telah selesai. assert.async () menerima jumlah panggilan sebagai parameter. Callback yang dikembalikan dari assert.async () akan memunculkan Error, jika dipanggil lebih dari jumlah panggilan yang diterima, jika tersedia. Setiapdone()panggilan menambahkan hingga jumlah panggilan. Setelah setiap panggilan selesai, pengujian selesai.
<html>
<head>
<meta charset = "utf-8">
<title>QUnit basic example</title>
<link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-1.22.0.css">
<script src = "https://code.jquery.com/qunit/qunit-1.22.0.js"></script>
</head>
<body>
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
<script>
QUnit.test( "multiple call test()", function( assert ) {
var done = assert.async( 3 );
setTimeout(function() {
assert.ok( true, "first callback." );
done();
}, 500 );
setTimeout(function() {
assert.ok( true, "second callback." );
done();
}, 500 );
setTimeout(function() {
assert.ok( true, "third callback." );
done();
}, 500 );
});
</script>
</body>
</html>
Verifikasi Output
Anda harus melihat hasil berikut -
Kita bisa gunakan assert.expect()berfungsi untuk memeriksa jumlah pernyataan yang dibuat dalam pengujian. Dalam contoh berikut, kami mengharapkan tiga pernyataan dibuat dalam pengujian.
<html>
<head>
<meta charset = "utf-8">
<title>QUnit basic example</title>
<link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-1.22.0.css">
<script src = "https://code.jquery.com/qunit/qunit-1.22.0.js"></script>
</head>
<body>
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
<script>
QUnit.test( "multiple call test()", function( assert ) {
assert.expect( 3 );
var done = assert.async( 3 );
setTimeout(function() {
assert.ok( true, "first callback." );
done();
}, 500 );
setTimeout(function() {
assert.ok( true, "second callback." );
done();
}, 500 );
setTimeout(function() {
assert.ok( true, "third callback." );
done();
}, 500 );
});
</script>
</body>
</html>
Verifikasi Output
Anda harus melihat hasil berikut -
Saat mengintegrasikan QUnit ke alat lain seperti server CI, callback ini dapat digunakan sebagai API untuk membaca hasil pengujian. Berikut adalah prosedur eksekusi metode API panggilan balik QUnit dengan sebuah contoh.
<html>
<head>
<meta charset = "utf-8">
<title>QUnit basic example</title>
<link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-1.22.0.css">
<script src = "https://code.jquery.com/qunit/qunit-1.22.0.js"></script>
</head>
<body>
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
<script>
//Register a callback to fire whenever a testsuite starts.
QUnit.begin(function( details ) {
var data = document.getElementById("console").innerHTML;
document.getElementById("console").innerHTML = "<br/>" +
"QUnit.begin- Test Suite Begins " + "<br/>" +
"Total Test: " + details.totalTests;
});
//Register a callback to fire whenever a test suite ends.
QUnit.done(function( details ) {
var data = document.getElementById("console").innerHTML;
document.getElementById("console").innerHTML = data + "<br/><br/>" +
"QUnit.done - Test Suite Finised" + "<br/>" + "Total: " +
details.total + " Failed: " + details.failed + " Passed:
" + details.passed;
});
//Register a callback to fire whenever a module starts.
QUnit.moduleStart(function( details ) {
var data = document.getElementById("console").innerHTML;
document.getElementById("console").innerHTML = data + "<br/><br/>" +
"QUnit.moduleStart - Module Begins " + "<br/>" + details.name;
});
//Register a callback to fire whenever a module ends.
QUnit.moduleDone(function( details ) {
var data = document.getElementById("console").innerHTML;
document.getElementById("console").innerHTML = data + "<br/><br/>" +
"QUnit.moduleDone - Module Finished " + "<br/>" + details.name +
" Failed/total: " + details.failed +"/" + details.total ;
});
//Register a callback to fire whenever a test starts.
QUnit.testStart(function( details ) {
var data = document.getElementById("console").innerHTML;
document.getElementById("console").innerHTML = data + "<br/><br/>" +
"QUnit.testStart - Test Begins " + "<br/>" + details.module +"
" + details.name;
});
//Register a callback to fire whenever a test ends.
QUnit.testDone(function( details ) {
var data = document.getElementById("console").innerHTML;
document.getElementById("console").innerHTML = data + "<br/><br/>" +
"QUnit.testDone - Test Finished " + "<br/>" + details.module +" "
+ details.name + "Failed/total: " + details.failed +" " + details.total+
" "+ details.duration;
});
QUnit.module( "Module A", {
beforeEach: function( assert ) {
assert.ok( true, "before test case" );
}, afterEach: function( assert ) {
assert.ok( true, "after test case" );
}
});
QUnit.test( "test case 1", function( assert ) {
assert.ok( true, "Module A: in test case 1" );
});
QUnit.test( "test case 2", function( assert ) {
assert.ok( true, "Module A: in test case 2" );
});
QUnit.module( "Module B" );
QUnit.test( "test case 1", function( assert ) {
assert.ok( true, "Module B: in test case 1" );
});
QUnit.test( "test case 2", function( assert ) {
assert.ok( true, "Module B: in test case 2" );
});
</script>
<div id = "console" ></div>
</body>
</html>
Verifikasi Output
Anda harus melihat hasil berikut -
Modul dengan fungsi pengujian yang dikelompokkan digunakan untuk menentukan modul bersarang. QUnit menjalankan pengujian pada modul induk sebelum membahas lebih dalam yang bersarang, meskipun mereka dideklarasikan terlebih dahulu. ItubeforeEach dan afterEachcallback pada panggilan modul bersarang akan menumpuk dalam Mode LIFO (Last In, First Out) ke hook induk. Anda dapat menentukan kode untuk dijalankan sebelum dan sesudah setiap pengujian menggunakan argumen dan kait.
Hooks juga dapat digunakan untuk membuat properti yang akan dibagikan pada konteks setiap pengujian. Properti tambahan apa pun pada objek hooks akan ditambahkan ke konteks itu. Argumen hooks bersifat opsional jika Anda memanggil QUnit.module dengan argumen callback.
Callback modul dipanggil dengan konteks sebagai lingkungan pengujian, dengan properti lingkungan disalin ke modul tes, hook, dan bersarang.
<html>
<head>
<meta charset = "utf-8">
<title>QUnit basic example</title>
<link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-1.22.0.css">
<script src = "https://code.jquery.com/qunit/qunit-1.22.0.js"></script>
</head>
<body>
<div id = "qunit"></div>
<div id = "qunit-fixture"></div>
<script>
QUnit.module( "parent module", function( hooks ) {
hooks.beforeEach( function( assert ) {
assert.ok( true, "beforeEach called" );
});
hooks.afterEach( function( assert ) {
assert.ok( true, "afterEach called" );
});
QUnit.test( "hook test 1", function( assert ) {
assert.expect( 2 );
});
QUnit.module( "nested hook module", function( hooks ) {
// This will run after the parent module's beforeEach hook
hooks.beforeEach( function( assert ) {
assert.ok( true, "nested beforeEach called" );
});
// This will run before the parent module's afterEach
hooks.afterEach( function( assert ) {
assert.ok( true, "nested afterEach called" );
});
QUnit.test( "hook test 2", function( assert ) {
assert.expect( 4 );
});
});
});
</script>
<div id = "console" ></div>
</body>
</html>
Verifikasi Output
Anda harus melihat hasil berikut -