Intro
Aku sudah menjelajahi pengujian unit dan menguji cakupan untuk JavaScript ketika bekerja pada sebuah aplikasi SharePoint baru untuk SharePoint online di kantor 365 Suite. Jalur penelitian jelas mendorong saya untuk Qunit.js dan kanan setelah itu, untuk Blanket.js.
Kebun buah-buahan biarkan aku membuat unit test dan mengelompokkan mereka ke dalam modul. Module adalah cara yang mudah untuk mengatur tes terkait. (Saya tidak yakin saya menggunakan sebagaimana dimaksud, Tapi itu bekerja bagi saya begitu jauh dengan set kecil tes saya sejauh ini telah didefinisikan).
Blanket.js terintegrasi dengan kebun buah-buahan dan ia akan menampilkan jalur sebenarnya JavaScript yang itu- dan lebih penting-tidak benar-benar dilaksanakan dalam menjalankan tes. Ini adalah "cakupan"-baris yang dieksekusi dilindungi oleh tes sementara yang lain tidak.
Antara pengaturan kasus uji yang baik dan melihat cakupan, kita dapat mengurangi risiko bahwa kode kita telah tersembunyi Cacat. Baik kali.
Kebun buah-buahan
Dengan asumsi Anda memiliki Visual Studio proyek mengatur, Mulailah dengan men-download paket JavaScript dari http://qunitjs.com. Menambahkan JavaScript dan CSS yang sesuai untuk solusi Anda. Tambang terlihat seperti ini:
Gambar 1
Seperti Anda dapat melihat, Saya menggunakan 1.13.0 pada saat saya menulis posting blog ini. Jangan lupa untuk men-download dan menambahkan CSS file.
Yang keluar dari jalan, langkah berikutnya adalah untuk menciptakan semacam harness tes dan referensi bit kebun buah-buahan. Saya menguji banyak fungsi dalam file skrip bernama "QuizUtil.js" Jadi saya membuat halaman HTML yang disebut "QuizUtil_test.html" seperti yang ditunjukkan:
Gambar 2
Berikut adalah kode:
<!DOCTYPE HTML>
<HTML xmlns= "http://www.w3.org/ 1999/xhtml">
<kepala>
<judul>QuizUtil tes dengan kebun buah-buahan</judul>
<link rel= "stylesheet" href="../CSS/qunit-1.13.0.CSS" />
<script jenis= text/javascript"" src="QuizUtil.js" data-cover></script>
<script type ="text/javascript" src ="kebun buah-buahan-1.13.0.js"></script>
<script type ="text/javascript" src ="blanket.min.js"></script>
<script>
modul("getIDFromLookup");
tes("QuizUtil getIDFromLookupField", fungsi () {
var goodValue = "1;#Paul Galvin";
sama(getIDFromLookupField(goodValue) + 1, 2), "ID [" + goodValue + "] + 1 harus menjadi 2";
sama(getIDFromLookupField(terdefinisi), terdefinisi, "Undefined masukan argumen harus kembali undefined hasil.");
sama(getIDFromLookupField(""), terdefinisi, "Kosong masukan argumen harus mengembalikan nilai undefined.");
sama(getIDFromLookupField("gobbledigood3-thq;dkvn ada;skfja sdjfbvubvqrubqer0873407t534piutheqw;VN"), terdefinisi,"Harus selalu kembali hasil konversi ke Integer");
sama(getIDFromLookupField("2;#beberapa orang lain"), "2", "Memeriksa [2;#beberapa orang lain].");
sama(getIDFromLookupField("9834524;#nilai panjang"), "9834524", "Nilai besar ujian.");
notEqual(getIDFromLookupField("5;#siapa pun", 6), 6, "Pengujian notEqual (5 tidak sama dengan 6 untuk contoh ini: [5;#siapa pun]");
});
modul("htmlEscape");
tes("QuizUtil htmlEscape()", fungsi () {
sama(htmlEscape("<"), "<", "Escaping kurang dari operator ('<')");
sama(htmlEscape("<div kelas = "someclass">Beberapa teks</div>"), "<div kelas ="someclass">Beberapa teks</div>", "Lebih kompleks tes string.");
});
modul("getDateAsCaml");
tes("QuizUtil getDateAsCaml()", fungsi () {
sama(getDateAsCaml(baru Tanggal("12/31/2013")), "2013-12-31T:00:00:00", "Pengujian kode keras tanggal: [12/31/2013]");
sama(getDateAsCaml(baru Tanggal("01/05/2014")), "2014-01-05T:00:00:00", "Pengujian kode keras tanggal: [01/05/2014]");
sama(getDateAsCaml(baru Tanggal("01/31/2014")), "2014-01-31T:00:00:00", "Pengujian kode keras tanggal: [01/31/2014]");
sama(getTodayAsCaml(), getDateAsCaml(baru Tanggal()), "getTodayAsCaml() harus sama dengan getDateAsCaml(Tanggal baru())");
sama(getDateAsCaml("nilai omong kosong"), terdefinisi, "Mencoba untuk mendapatkan tanggal nilai omong kosong.");
sama(getDateAsCaml(terdefinisi), terdefinisi, "Mencoba untuk mendapatkan tanggal [terdefinisi] tanggal.");
});
modul("getParameterByName");
tes("QuizUtil getParameterByName (dari string kueri)", fungsi () {
sama(getParameterByName(terdefinisi), terdefinisi, "Mencoba untuk mendapatkan parameter terdefinisi harus kembali undefined.");
sama(getParameterByName("tidak ada"), terdefinisi, "Cobalah untuk mendapatkan nilai parameter ketika kita tahu parameter yang tidak ada.");
});
modul("Cookies");
tes("QuizUtil berbagai fungsi kuki.", fungsi () {
sama(setCookie("ujian", "1", -1), getCookieValue("ujian"), "Dapatkan saya menetapkan cookie harus bekerja.");
sama(setCookie("anycookie", "1", -1), benar, "Pengaturan memasak sah harus kembali 'benar'.");
sama(setCookie("nama cookie gila !@#$%"%\^&*(()?/><.,", "1", -1), benar, "Menetapkan nama buruk cookie harus kembali 'palsu'.");
sama(setCookie(terdefinisi, "1", -1), terdefinisi, "Lewat undefined sebagai nama cookie.");
sama(getCookieValue("tidak ada"), "", "Cookie tidak ada tes.");
});
</script>
</kepala>
<bodyHTMLan >>< kuat > pesan yang kuat.</strong> </body> </html> ">
<div id= "kebun buah-buahan"></div>
<div id= "kebun buah-buahan-fixture"></div>
</bodyHTMLan >>< kuat > pesan yang kuat.</strong> </body> </html> ">
</HTML>
Ada beberapa hal yang terjadi di sini:
- Kode saya referensi (QuizUtil.js)
- Referensi Qunity.js
- Mendefinisikan beberapa modul (getIDFromLookup, Cookie, dan lain-lain)
- Menempatkan <div> ID Apakah "kebun buah-buahan".
Kemudian, Aku hanya menarik Halaman ini dan Anda mendapatkan sesuatu seperti ini:
Gambar 3
Jika Anda melihat di atas, Anda memiliki beberapa pilihan, dua di antaranya menarik:
- Sembunyikan lulus tes: Cukup jelas. Dapat membantu mata Anda hanya melihat area masalah dan tidak banyak kekacauan.
- Modul: (drop-down): Ini akan menyaring tes ke kelompok-kelompok tersebut hanya tes yang Anda inginkan.
Untuk tes sendiri – beberapa komentar:
- Tak usah dikatakan bahwa Anda perlu untuk menulis kode Anda sedemikian rupa sehingga hal ini dapat diuji di tempat pertama. Menggunakan alat dapat membantu menegakkan disiplin. Misalnya, Aku punya fungsi yang disebut "getTodayAsCaml()”. Ini bukan sangat diuji karena ini membutuhkan tidak ada argumen masukan dan mengujinya untuk kesetaraan, kita perlu terus-menerus memperbarui kode tes untuk mencerminkan tanggal saat ini. Saya direfractor dengan menambahkan data input parameter kemudian melewati tanggal saat ini ketika aku ingin tanggal dalam CAML format.
- Dokumen-dokumen kerangka kerja kebun buah-buahan tes sendiri, dan tampaknya cukup kuat. Ini dapat melakukan hal-hal sederhana seperti pengujian untuk kesetaraan dan juga memiliki dukungan untuk panggilan gaya ajax ("nyata" atau diejek menggunakan mocker favorit Anda).
- Melalui proses juga memaksa Anda untuk memikirkan edge kasus-apa yang terjadi dengan "undefined" atau null dilewatkan ke dalam fungsi. Itu membuatnya mati sederhana untuk menguji skenario ini keluar. Bagus.
Cakupan dengan Blanket.js
Blanket.js melengkapi kebun buah-buahan pelacakan sebenarnya baris kode yang mengeksekusi selama menjalankan tes Anda. Ini mengintegrasikan kanan ke kebun buah-buahan jadi meskipun itu adalah sebuah aplikasi seluruh terpisah, It memutar baik-itu benar-benar tampak seperti satu app mulus.
Ini adalah blanket.js dalam aksi:
Gambar 4
Gambar 5
(Anda benar-benar harus klik pada kotak centang "Aktifkan cakupan" di bagian atas [Lihat gambar 3] untuk mengaktifkan ini.)
Baris yang disorot dalam gambar 5 belum dilaksanakan oleh salah satu tes, Jadi saya perlu menyusun tes yang menyebabkan mereka untuk melaksanakan jika saya ingin cakupan penuh.
Dapatkan blanket.js bekerja dengan mengikuti langkah-langkah:
- Men-download dari http://blanketjs.org/.
- Tambahkan ke proyek Anda
- Memperbarui halaman percobaan Anda memanfaatkan (QuizUtil_test.html dalam kasus saya) sebagai berikut:
- Referensi kode
- Menghias Anda <script> referensi seperti ini:
<script jenis= text/javascript"" src="QuizUtil.js" data-cover></script>
Blanket.js mengambil atribut "data-penutup" dan melakukan keajaiban. Kait ke kebun buah-buahan, Update UI untuk menambahkan opsi "Aktifkan cakupan" dan voila!
Ringkasan (TL; DR)
Menggunakan kebun buah-buahan untuk menulis Anda uji kasus.
- Men-download
- Tambahkan ke proyek Anda
- Menulis sebuah halaman harness tes
- Membuat tes Anda
- Refactor beberapa kode Anda harus diuji
- Menjadi kreatif! Pikirkan gila, mungkin skenario dan menguji mereka tetap.
Gunakan blanket.js untuk memastikan cakupan
- Memastikan kebun buah-buahan bekerja
- Download blanket.js dan menambahkannya ke proyek Anda
- Tambahkan ke halaman Anda baju zirah tes:
- Menambahkan referensi ke blanket.js
- Menambahkan atribut "data-penutup" untuk Anda <script> Tag
- Menjalankan tes kebun buah-buahan Anda.
Saya tidak pernah melakukan hal ini sebelum dan memiliki beberapa hal dasar yang bekerja dalam beberapa jam.
Pengujian bahagia!
</akhir>
Berlangganan ke blog saya.
Ikuti saya di kegugupan di http://www.twitter.com/pagalvin