Protractor - Konsep Pengujian Javascript

Karena pengetahuan JavaScript sangat penting untuk bekerja dengan Busur derajat, dalam bab ini, mari kita pahami konsep pengujian JavaScript secara rinci.

Pengujian dan Otomatisasi JavaScript

JavaScript adalah bahasa skrip yang paling populer diketik dan ditafsirkan secara dinamis, tetapi tugas yang paling menantang adalah menguji kodenya. Itu karena, tidak seperti bahasa terkompilasi lainnya seperti JAVA dan C ++, tidak ada langkah kompilasi dalam JavaScript yang dapat membantu penguji untuk menemukan kesalahan. Selain itu, pengujian berbasis browser sangat memakan waktu; oleh karena itu, diperlukan alat yang mendukung pengujian otomatis untuk JavaScript.

Konsep Pengujian Otomatis

Menulis tes selalu merupakan praktik yang baik karena membuat kode menjadi lebih baik; masalah dengan pengujian manual adalah proses ini memakan waktu sedikit dan rawan kesalahan. Proses pengujian manual juga cukup membosankan bagi programmer karena mereka perlu mengulang proses, menulis spesifikasi pengujian, mengubah kode, dan menyegarkan browser beberapa kali. Selain itu, pengujian manual juga memperlambat proses pengembangan.

Karena alasan di atas, selalu berguna untuk memiliki beberapa alat yang dapat mengotomatiskan pengujian ini dan membantu pemrogram untuk menyingkirkan langkah-langkah berulang dan membosankan ini. Apa yang harus dilakukan pengembang untuk membuat proses pengujian otomatis?

Pada dasarnya, pengembang dapat mengimplementasikan set alat di CLI (Command Line Interpreter) atau di IDE pengembangan (Lingkungan pengembangan terintegrasi). Kemudian, pengujian ini akan terus berjalan dalam proses terpisah meskipun tanpa masukan dari pengembang. Pengujian otomatis JavaScript juga bukanlah hal baru dan banyak alat seperti Karma, Busur derajat, CasperJS, dll. Telah dikembangkan.

Jenis Pengujian JavaScript

Mungkin ada tes yang berbeda untuk tujuan yang berbeda. Misalnya, beberapa pengujian ditulis untuk memeriksa perilaku fungsi dalam program, sementara beberapa pengujian lainnya ditulis untuk menguji aliran modul atau fitur. Jadi, kami memiliki dua jenis pengujian berikut -

Pengujian Unit

Pengujian dilakukan pada bagian terkecil yang dapat diuji dari program yang disebut unit. Unit pada dasarnya diuji secara terpisah tanpa ketergantungan apa pun dari unit itu pada bagian lain. Dalam kasus JavaScript, metode atau fungsi individual yang memiliki perilaku tertentu dapat menjadi unit kode dan unit kode ini harus diuji secara terpisah.

Salah satu keuntungan dari unit testing adalah pengujian unit dapat dilakukan dalam urutan apa pun karena unit tersebut tidak bergantung satu sama lain. Keuntungan lain dari pengujian unit yang benar-benar diperhitungkan adalah dapat menjalankan pengujian kapan saja sebagai berikut -

  • Dari awal proses pengembangan.
  • Setelah menyelesaikan pengembangan modul / fitur apa pun.
  • Setelah memodifikasi modul / fitur apa pun.
  • Setelah menambahkan fitur baru di aplikasi yang ada.

Untuk pengujian unit otomatis aplikasi JavaScript, kita dapat memilih dari banyak alat pengujian dan kerangka kerja seperti Mocha, Jasmine, dan QUnit.

Pengujian End-to-End

Ini dapat didefinisikan sebagai metodologi pengujian yang digunakan untuk menguji apakah aliran aplikasi dari awal hingga akhir (dari satu ujung ke ujung lainnya) berfungsi dengan baik sesuai desain.

Pengujian ujung ke ujung juga disebut pengujian fungsi / aliran. Tidak seperti pengujian unit, pengujian ujung ke ujung menguji bagaimana masing-masing komponen bekerja bersama sebagai sebuah aplikasi. Inilah perbedaan utama antara pengujian unit dan pengujian ujung ke ujung.

Misalnya, jika kita memiliki modul pendaftaran di mana pengguna perlu memberikan beberapa informasi yang valid untuk menyelesaikan pendaftaran, maka pengujian E2E untuk modul tersebut akan mengikuti langkah-langkah berikut untuk menyelesaikan pengujian -

  • Pertama, itu akan memuat / mengkompilasi formulir atau modul.
  • Sekarang, itu akan mendapatkan DOM (Model objek dokumen) dari elemen formulir.
  • Selanjutnya, picu acara klik tombol kirim untuk memeriksa apakah itu berfungsi atau tidak.
  • Sekarang, untuk tujuan validasi, kumpulkan nilai dari kolom input.
  • Selanjutnya, bidang masukan harus divalidasi.
  • Untuk tujuan pengujian, panggil API palsu untuk menyimpan data.

Setiap langkah memberikan hasil masing-masing yang akan dibandingkan dengan hasil yang diharapkan.

Sekarang, pertanyaan yang muncul adalah, sementara E2E atau pengujian fungsional semacam ini juga dapat dilakukan secara manual, mengapa kita membutuhkan otomatisasi untuk ini? Alasan utamanya adalah otomatisasi akan mempermudah proses pengujian ini. Beberapa alat yang tersedia yang dapat dengan mudah diintegrasikan dengan aplikasi apa pun, untuk tujuan ini adalah Selenium, PhantomJS dan Protractor.

Alat & Kerangka Pengujian

Kami memiliki berbagai alat pengujian dan kerangka kerja untuk pengujian Angular. Berikut ini adalah beberapa alat dan kerangka kerja yang terkenal -

Karma

Karma, diciptakan oleh Vojta Jina, adalah pelari uji coba. Awalnya proyek ini disebut Testacular. Ini bukan kerangka kerja pengujian, yang berarti memberi kami kemampuan untuk dengan mudah dan otomatis menjalankan pengujian unit JavaScript di browser nyata. Karma dibangun untuk AngularJS karena sebelum Karma tidak ada alat pengujian otomatis untuk pengembang JavaScript berbasis web. Di sisi lain, dengan otomatisasi yang disediakan oleh Karma, pengembang dapat menjalankan satu perintah sederhana dan menentukan apakah seluruh rangkaian pengujian telah lulus atau gagal.

Kelebihan menggunakan Karma

Berikut ini adalah beberapa kelebihan menggunakan Karma dibandingkan dengan proses manual -

  • Mengotomatiskan pengujian di beberapa browser serta perangkat.
  • Memantau kesalahan file dan memperbaikinya.
  • Memberikan dukungan dan dokumentasi online.
  • Memudahkan integrasi dengan server integrasi berkelanjutan.

Kontra Menggunakan Karma

Berikut ini adalah beberapa kekurangan dalam menggunakan Karma -

Kerugian utama dari penggunaan Karma adalah membutuhkan alat tambahan untuk mengkonfigurasi dan memelihara.

Jika Anda menggunakan runner pengujian Karma dengan Jasmine, maka lebih sedikit dokumentasi yang tersedia untuk menemukan informasi tentang menyiapkan CSS Anda jika memiliki beberapa id untuk satu elemen.

Melati

Jasmine, kerangka kerja pengembangan berbasis perilaku untuk menguji kode JavaScript, dikembangkan di Pivotal Labs. Sebelum framework Jasmine dikembangkan secara aktif, framework pengujian unit serupa bernama JsUnit juga dikembangkan oleh Pivotal Labs, yang memiliki runner pengujian bawaan. Pengujian browser dapat dijalankan melalui pengujian Jasmine dengan menyertakan file SpecRunner.html atau dengan menggunakannya sebagai runner pengujian baris perintah juga. Dapat digunakan dengan atau tanpa Karma juga.

Kelebihan Menggunakan Jasmine

Berikut ini adalah beberapa keuntungan menggunakan Jasmine -

  • Kerangka kerja yang tidak bergantung pada browser, platform, dan bahasa.

  • Mendukung pengembangan yang didorong oleh pengujian (TDD) bersama dengan pengembangan yang didorong perilaku.

  • Memiliki integrasi default dengan Karma.

  • Sintaks yang mudah dipahami.

  • Menyediakan fungsi mata-mata uji, pemalsuan, dan penerusan yang membantu pengujian sebagai fungsi tambahan.

Kontra Menggunakan Jasmine

Berikut ini adalah tipuan menggunakan Jasmine -

  • Pengujian harus dikembalikan oleh pengguna saat berubah karena tidak ada fitur menonton file yang tersedia di Jasmine saat menjalankan pengujian.

Moka

Mocha, ditulis untuk aplikasi Node.js, adalah kerangka kerja pengujian tetapi juga mendukung pengujian browser. Ini sangat mirip dengan Jasmine tetapi perbedaan utama di antara mereka adalah Mocha membutuhkan beberapa plugin dan pustaka karena tidak dapat berjalan mandiri sebagai kerangka kerja pengujian. Di sisi lain, Jasmine berdiri sendiri. Namun, Mocha lebih fleksibel digunakan daripada Jasmine.

Kelebihan menggunakan Mocha

Berikut ini adalah beberapa keuntungan menggunakan Mocha -

  • Mocha sangat mudah dipasang dan dikonfigurasi.
  • Dokumentasi yang ramah pengguna dan sederhana.
  • Berisi plugin dengan beberapa proyek node.

Kontra menggunakan Mocha

Berikut ini adalah beberapa kekurangan penggunaan Mocha -

  • Perlu modul terpisah untuk pernyataan, mata-mata, dll.
  • Ini juga membutuhkan konfigurasi tambahan untuk digunakan dengan Karma.

Hentikan

QUint, awalnya dikembangkan oleh John Resig pada tahun 2008 sebagai bagian dari jQuery, adalah paket pengujian unit JavaScript yang kuat namun mudah digunakan. Ini dapat digunakan untuk menguji kode JavaScript umum apa pun. Meskipun berfokus pada pengujian JavaScript di browser, namun sangat nyaman digunakan oleh pengembang.

Kelebihan menggunakan QUnit

Berikut ini adalah beberapa keuntungan menggunakan QUnit -

  • Mudah dipasang dan dikonfigurasi.
  • Dokumentasi yang ramah pengguna dan sederhana.

Kontra menggunakan QUnit

Berikut ini adalah tipuan menggunakan QUnit -

  • Ini terutama dikembangkan untuk jQuery dan karenanya tidak begitu baik untuk digunakan dengan framework lain.

Selenium

Selenium, awalnya dikembangkan oleh Jason Huggins pada tahun 2004 sebagai alat internal di ThoughtWorks, adalah alat otomatisasi pengujian open source. Selenium mendefinisikan dirinya sebagai “Selenium mengotomatiskan browser. Itu dia!". Otomatisasi browser berarti bahwa pengembang dapat berinteraksi dengan browser dengan sangat mudah.

Kelebihan menggunakan Selenium

Berikut ini adalah beberapa keuntungan menggunakan Selenium -

  • Berisi kumpulan fitur besar.
  • Mendukung pengujian terdistribusi.
  • Memiliki dukungan SaaS melalui layanan seperti Sauce Labs.
  • Mudah digunakan dengan dokumentasi sederhana dan sumber daya yang kaya tersedia.

Kontra menggunakan Selenium

Berikut ini adalah beberapa kekurangan dalam menggunakan Selenium -

  • Kerugian utama menggunakan Selenium adalah harus dijalankan sebagai proses terpisah.
  • Konfigurasi agak rumit karena pengembang perlu mengikuti beberapa langkah.