Tinjauan Pengujian Perangkat Lunak
Pengujian Perangkat Lunak adalah evaluasi perangkat lunak terhadap persyaratan yang dikumpulkan dari pengguna dan spesifikasi sistem. Pengujian dilakukan pada level fase dalam siklus hidup pengembangan perangkat lunak atau pada level modul dalam kode program. Pengujian perangkat lunak terdiri dari Validasi dan Verifikasi.
Validasi Perangkat Lunak
Validasi adalah proses memeriksa apakah perangkat lunak memenuhi persyaratan pengguna atau tidak. Itu dilakukan di akhir SDLC. Jika perangkat lunak sesuai dengan persyaratan pembuatannya, itu divalidasi.
- Validasi memastikan produk yang sedang dikembangkan sesuai dengan kebutuhan pengguna.
- Validasi menjawab pertanyaan - "Apakah kita mengembangkan produk yang mencoba semua yang dibutuhkan pengguna dari perangkat lunak ini?".
- Validasi menekankan pada kebutuhan pengguna.
Verifikasi Perangkat Lunak
Verifikasi adalah proses untuk memastikan apakah perangkat lunak memenuhi persyaratan bisnis, dan dikembangkan dengan mengikuti spesifikasi dan metodologi yang tepat.
- Verifikasi memastikan produk yang dikembangkan sesuai dengan spesifikasi desain.
- Verifikasi menjawab pertanyaan– "Apakah kita mengembangkan produk ini dengan mengikuti semua spesifikasi desain secara ketat?"
- Verifikasi berkonsentrasi pada desain dan spesifikasi sistem.
Sasaran tes ini adalah -
Errors- Ini adalah kesalahan pengkodean sebenarnya yang dilakukan oleh pengembang. Selain itu, terdapat perbedaan keluaran perangkat lunak dan keluaran yang diinginkan, dianggap sebagai error.
Fault- Ketika ada kesalahan, kesalahan terjadi. Kesalahan, juga dikenal sebagai bug, adalah hasil dari kesalahan yang dapat menyebabkan sistem gagal.
Failure - kegagalan dikatakan ketidakmampuan sistem untuk melakukan tugas yang diinginkan. Kegagalan terjadi jika ada kesalahan dalam sistem.
Pengujian Otomatis Vs Manual
Pengujian dapat dilakukan secara manual atau menggunakan alat pengujian otomatis:
Manual- Pengujian ini dilakukan tanpa bantuan alat pengujian otomatis. Penguji perangkat lunak menyiapkan kasus uji untuk bagian dan level kode yang berbeda, menjalankan pengujian dan melaporkan hasilnya kepada manajer.
Pengujian manual memakan waktu dan sumber daya. Penguji perlu memastikan apakah kasus uji yang benar digunakan atau tidak. Sebagian besar pengujian melibatkan pengujian manual.
AutomatedPengujian ini adalah prosedur pengujian yang dilakukan dengan bantuan alat pengujian otomatis. Batasan dengan pengujian manual dapat diatasi dengan menggunakan alat pengujian otomatis.
Tes perlu memeriksa apakah halaman web dapat dibuka di Internet Explorer. Ini dapat dengan mudah dilakukan dengan pengujian manual. Tetapi untuk memeriksa apakah server web dapat mengambil beban 1 juta pengguna, sangat tidak mungkin untuk menguji secara manual.
Ada perangkat lunak dan perangkat keras yang membantu penguji dalam melakukan pengujian beban, pengujian stres, pengujian regresi.
Pendekatan Pengujian
Tes dapat dilakukan berdasarkan dua pendekatan -
- Pengujian fungsionalitas
- Pengujian implementasi
Ketika fungsionalitas diuji tanpa memperhatikan implementasi aktualnya, ini dikenal sebagai pengujian kotak hitam. Sisi lain dikenal sebagai pengujian kotak putih di mana tidak hanya fungsionalitas yang diuji tetapi cara penerapannya juga dianalisis.
Tes lengkap adalah metode yang paling diinginkan untuk pengujian yang sempurna. Setiap nilai yang mungkin dalam kisaran nilai input dan output diuji. Tidak mungkin menguji setiap nilai dalam skenario dunia nyata jika kisaran nilainya besar.
Pengujian kotak hitam
Ini dilakukan untuk menguji fungsionalitas program. Ini juga disebut pengujian 'Perilaku'. Penguji dalam hal ini, memiliki sekumpulan nilai input dan masing-masing hasil yang diinginkan. Saat memberikan input, jika output sesuai dengan hasil yang diinginkan, program akan diuji 'ok', dan sebaliknya bermasalah.
Dalam metode pengujian ini, desain dan struktur kode tidak diketahui oleh penguji, dan teknisi pengujian serta pengguna akhir melakukan pengujian ini pada perangkat lunak.
Teknik pengujian kotak hitam:
Equivalence class- Input dibagi ke dalam kelas yang serupa. Jika salah satu elemen kelas lulus pengujian, diasumsikan bahwa semua kelas tersebut lulus.
Boundary values- Input dibagi menjadi nilai akhir yang lebih tinggi dan lebih rendah. Jika nilai-nilai ini lulus ujian, diasumsikan bahwa semua nilai di antaranya dapat lulus juga.
Cause-effect graphing- Dalam kedua metode sebelumnya, hanya satu nilai input yang diuji. Penyebab (masukan) - Pengaruh (keluaran) adalah teknik pengujian dimana kombinasi nilai masukan diuji secara sistematis.
Pair-wise Testing- Perilaku perangkat lunak bergantung pada beberapa parameter. Dalam pengujian berpasangan, beberapa parameter diuji secara berpasangan untuk nilai yang berbeda.
State-based testing- Sistem mengubah status pada penyediaan input. Sistem ini diuji berdasarkan status dan masukannya.
Pengujian kotak putih
Ini dilakukan untuk menguji program dan implementasinya, dalam rangka meningkatkan efisiensi atau struktur kode. Ini juga dikenal sebagai pengujian 'Struktural'.
Dalam metode pengujian ini, desain dan struktur kode diketahui oleh penguji. Pemrogram kode melakukan pengujian ini pada kode.
Di bawah ini adalah beberapa teknik pengujian kotak putih:
Control-flow testing- Tujuan dari pengujian aliran kontrol untuk menyiapkan kasus pengujian yang mencakup semua pernyataan dan kondisi cabang. Kondisi cabang diuji apakah benar dan salah, sehingga semua pernyataan dapat ditutupi.
Data-flow testing- Teknik pengujian ini menekankan untuk mencakup semua variabel data yang termasuk dalam program. Ini menguji di mana variabel dideklarasikan dan didefinisikan dan di mana mereka digunakan atau diubah.
Tingkat Pengujian
Pengujian itu sendiri dapat didefinisikan di berbagai tingkat SDLC. Proses pengujian berjalan paralel dengan pengembangan perangkat lunak. Sebelum melompat ke tahap berikutnya, suatu tahap diuji, divalidasi, dan diverifikasi.
Pengujian secara terpisah dilakukan hanya untuk memastikan tidak ada bug atau masalah tersembunyi yang tertinggal di perangkat lunak. Perangkat lunak diuji pada berbagai tingkatan -
Pengujian Unit
Saat pengkodean, pemrogram melakukan beberapa tes pada unit program itu untuk mengetahui apakah itu bebas kesalahan. Pengujian dilakukan dengan pendekatan pengujian kotak putih. Pengujian unit membantu pengembang memutuskan bahwa unit individual dari program berfungsi sesuai kebutuhan dan bebas dari kesalahan.
Tes integrasi
Bahkan jika unit perangkat lunak bekerja dengan baik secara individual, ada kebutuhan untuk mengetahui apakah unit jika terintegrasi juga akan bekerja tanpa kesalahan. Misalnya, penerusan argumen dan pembaruan data dll.
Pengujian Sistem
Perangkat lunak dikompilasi sebagai produk dan kemudian diuji secara keseluruhan. Ini dapat dilakukan dengan menggunakan satu atau lebih tes berikut:
Functionality testing - Menguji semua fungsi perangkat lunak terhadap kebutuhan.
Performance testing- Tes ini membuktikan seberapa efisien perangkat lunak tersebut. Ini menguji keefektifan dan waktu rata-rata yang dibutuhkan oleh perangkat lunak untuk melakukan tugas yang diinginkan. Pengujian kinerja dilakukan dengan cara pengujian beban dan pengujian tegangan di mana perangkat lunak ditempatkan di bawah pengguna yang tinggi dan beban data dalam berbagai kondisi lingkungan.
Security & Portability - Tes ini dilakukan ketika perangkat lunak dimaksudkan untuk bekerja pada berbagai platform dan diakses oleh sejumlah orang.
Ujian penerimaan
Ketika perangkat lunak siap untuk diserahkan kepada pelanggan, itu harus melalui tahap terakhir pengujian di mana itu diuji untuk interaksi dan tanggapan pengguna. Ini penting karena meskipun perangkat lunak cocok dengan semua persyaratan pengguna dan jika pengguna tidak menyukai tampilannya atau bekerja, perangkat lunak tersebut dapat ditolak.
Alpha testing- Tim pengembang sendiri melakukan pengujian alfa dengan menggunakan sistem seolah-olah sedang digunakan di lingkungan kerja. Mereka mencoba mencari tahu bagaimana pengguna akan bereaksi terhadap beberapa tindakan dalam perangkat lunak dan bagaimana sistem harus menanggapi masukan.
Beta testing- Setelah perangkat lunak diuji secara internal, perangkat lunak tersebut diserahkan kepada pengguna untuk digunakan dalam lingkungan produksi mereka hanya untuk tujuan pengujian. Ini belum produk yang dikirim. Pengembang berharap bahwa pengguna pada tahap ini akan membawa masalah kecil, yang dilewati untuk hadir.
Pengujian Regresi
Setiap kali produk perangkat lunak diperbarui dengan kode, fitur, atau fungsionalitas baru, produk itu diuji secara menyeluruh untuk mendeteksi apakah ada dampak negatif dari kode yang ditambahkan. Ini dikenal sebagai pengujian regresi.
Menguji Dokumentasi
Dokumen pengujian disiapkan pada berbagai tahap -
Sebelum Pengujian
Pengujian dimulai dengan pembuatan kasus uji. Dokumen-dokumen berikut diperlukan untuk referensi -
SRS document - Dokumen Persyaratan Fungsional
Test Policy document - Ini menjelaskan seberapa jauh pengujian harus dilakukan sebelum merilis produk.
Test Strategy document - Ini menyebutkan aspek rinci dari tim penguji, matriks tanggung jawab dan hak / tanggung jawab manajer penguji dan insinyur penguji.
Traceability Matrix document- Ini adalah dokumen SDLC, yang terkait dengan proses pengumpulan persyaratan. Saat persyaratan baru datang, mereka ditambahkan ke matriks ini. Matriks ini membantu penguji mengetahui sumber persyaratan. Mereka bisa dilacak maju dan mundur.
Saat Sedang Diuji
Dokumen-dokumen berikut mungkin diperlukan saat pengujian dimulai dan sedang dilakukan:
Test Case document- Dokumen ini berisi daftar tes yang harus dilakukan. Ini mencakup rencana pengujian unit, rencana pengujian integrasi, rencana pengujian sistem dan rencana pengujian penerimaan.
Test description - Dokumen ini adalah penjelasan rinci tentang semua kasus uji dan prosedur untuk melaksanakannya.
Test case report - Dokumen ini berisi laporan kasus uji sebagai hasil dari pengujian tersebut.
Test logs - Dokumen ini berisi log uji untuk setiap laporan kasus uji.
Setelah Pengujian
Dokumen berikut dapat dibuat setelah pengujian:
Test summary- Ringkasan tes ini adalah analisis kolektif dari semua laporan dan log tes. Ini meringkas dan menyimpulkan jika perangkat lunak siap diluncurkan. Perangkat lunak ini dirilis di bawah sistem kontrol versi jika siap diluncurkan.
Pengujian vs. Kontrol Kualitas, Jaminan Kualitas dan Audit
Kita perlu memahami bahwa pengujian perangkat lunak berbeda dari jaminan kualitas perangkat lunak, pengendalian kualitas perangkat lunak, dan audit perangkat lunak.
Software quality assurance- Ini adalah sarana pemantauan proses pengembangan perangkat lunak, yang dengannya dijamin bahwa semua tindakan diambil sesuai standar organisasi. Pemantauan ini dilakukan untuk memastikan bahwa metode pengembangan perangkat lunak yang benar diikuti.
Software quality control- Ini adalah sistem untuk menjaga kualitas produk perangkat lunak. Ini dapat mencakup aspek fungsional dan non-fungsional dari produk perangkat lunak, yang meningkatkan niat baik organisasi. Sistem ini memastikan bahwa pelanggan menerima produk berkualitas untuk kebutuhan mereka dan produk disertifikasi sebagai 'layak untuk digunakan'.
Software audit- Ini adalah tinjauan prosedur yang digunakan oleh organisasi untuk mengembangkan perangkat lunak. Sebuah tim auditor, independen dari tim pengembangan memeriksa proses perangkat lunak, prosedur, persyaratan, dan aspek lain dari SDLC. Tujuan dari audit perangkat lunak adalah untuk memeriksa bahwa perangkat lunak dan proses pengembangannya, sesuai dengan standar, aturan dan regulasi.