Pengujian Perangkat Lunak - Level
Ada level yang berbeda selama proses pengujian. Dalam bab ini, penjelasan singkat diberikan tentang level-level ini.
Tingkat pengujian mencakup berbagai metodologi yang dapat digunakan saat melakukan pengujian perangkat lunak. Tingkat utama pengujian perangkat lunak adalah -
Pengujian Fungsional
Pengujian Non-fungsional
Pengujian Fungsional
Ini adalah jenis pengujian kotak hitam yang didasarkan pada spesifikasi perangkat lunak yang akan diuji. Aplikasi diuji dengan memberikan masukan dan kemudian hasilnya diperiksa yang harus sesuai dengan fungsionalitas yang dimaksudkan. Pengujian fungsional perangkat lunak dilakukan pada sistem yang lengkap dan terintegrasi untuk mengevaluasi kepatuhan sistem dengan persyaratan yang ditentukan.
Ada lima langkah yang terlibat saat menguji fungsionalitas aplikasi.
Langkah | Deskripsi |
---|---|
saya | Penentuan fungsionalitas yang dimaksudkan untuk dilakukan oleh aplikasi yang dimaksudkan. |
II | Pembuatan data uji berdasarkan spesifikasi aplikasi. |
AKU AKU AKU | Keluarannya berdasarkan data uji dan spesifikasi aplikasi. |
IV | Penulisan skenario pengujian dan pelaksanaan kasus pengujian. |
V. | Perbandingan hasil aktual dan yang diharapkan berdasarkan kasus uji yang dijalankan. |
Praktik pengujian yang efektif akan melihat langkah-langkah di atas diterapkan pada kebijakan pengujian setiap organisasi dan karenanya akan memastikan bahwa organisasi mempertahankan standar yang paling ketat dalam hal kualitas perangkat lunak.
Pengujian Unit
Jenis pengujian ini dilakukan oleh pengembang sebelum penyiapan diserahkan ke tim pengujian untuk secara resmi menjalankan kasus pengujian. Pengujian unit dilakukan oleh pengembang masing-masing pada unit individu dari area kode sumber yang ditetapkan. Pengembang menggunakan data pengujian yang berbeda dari data pengujian tim jaminan kualitas.
Tujuan pengujian unit adalah untuk mengisolasi setiap bagian dari program dan menunjukkan bahwa setiap bagian sudah benar dalam hal persyaratan dan fungsionalitas.
Batasan Pengujian Unit
Pengujian tidak dapat menangkap setiap bug dalam aplikasi. Tidak mungkin untuk mengevaluasi setiap jalur eksekusi di setiap aplikasi perangkat lunak. Hal yang sama terjadi pada pengujian unit.
Ada batasan jumlah skenario dan data pengujian yang dapat digunakan pengembang untuk memverifikasi kode sumber. Setelah menghabiskan semua opsi, tidak ada pilihan selain menghentikan pengujian unit dan menggabungkan segmen kode dengan unit lain.
Tes integrasi
Pengujian integrasi didefinisikan sebagai pengujian bagian gabungan dari suatu aplikasi untuk menentukan apakah mereka berfungsi dengan benar. Pengujian integrasi dapat dilakukan dengan dua cara: Pengujian integrasi bottom-up dan pengujian integrasi Top-down.
Sr.No. | Metode Pengujian Integrasi |
---|---|
1 | Bottom-up integration Pengujian ini dimulai dengan pengujian unit, diikuti dengan pengujian kombinasi tingkat yang lebih tinggi dari unit yang disebut modul atau build. |
2 | Top-down integration Dalam pengujian ini, modul tingkat tertinggi diuji terlebih dahulu dan secara bertahap, modul tingkat yang lebih rendah diuji setelahnya. |
Dalam lingkungan pengembangan perangkat lunak yang komprehensif, pengujian bottom-up biasanya dilakukan terlebih dahulu, diikuti oleh pengujian top-down. Proses ini diakhiri dengan beberapa tes dari aplikasi yang lengkap, sebaiknya dalam skenario yang dirancang untuk meniru situasi sebenarnya.
Pengujian Sistem
Pengujian sistem menguji sistem secara keseluruhan. Setelah semua komponen diintegrasikan, aplikasi secara keseluruhan diuji secara ketat untuk melihat apakah memenuhi Standar Kualitas yang ditentukan. Jenis pengujian ini dilakukan oleh tim pengujian khusus.
Pengujian sistem penting karena alasan berikut -
Pengujian sistem adalah langkah pertama dalam Siklus Hidup Pengembangan Perangkat Lunak, di mana aplikasi diuji secara keseluruhan.
Aplikasi diuji secara menyeluruh untuk memverifikasi bahwa aplikasi memenuhi spesifikasi fungsional dan teknis.
Aplikasi diuji dalam lingkungan yang sangat dekat dengan lingkungan produksi tempat aplikasi akan diterapkan.
Pengujian sistem memungkinkan kami untuk menguji, memverifikasi, dan memvalidasi persyaratan bisnis serta arsitektur aplikasi.
Pengujian Regresi
Setiap kali perubahan dalam aplikasi perangkat lunak dilakukan, sangat mungkin bahwa area lain dalam aplikasi telah terpengaruh oleh perubahan ini. Pengujian regresi dilakukan untuk memverifikasi bahwa bug tetap tidak mengakibatkan fungsionalitas lain atau pelanggaran aturan bisnis. Maksud dari pengujian regresi adalah untuk memastikan bahwa perubahan, seperti perbaikan bug tidak akan mengakibatkan kesalahan lain terungkap dalam aplikasi.
Pengujian regresi penting karena alasan berikut -
Minimalkan celah dalam pengujian ketika aplikasi dengan perubahan yang dibuat harus diuji.
Menguji perubahan baru untuk memverifikasi bahwa perubahan yang dibuat tidak mempengaruhi area aplikasi lainnya.
Mengurangi risiko saat pengujian regresi dilakukan pada aplikasi.
Cakupan tes ditingkatkan tanpa mengorbankan jadwal.
Tingkatkan kecepatan untuk memasarkan produk.
Ujian penerimaan
Ini bisa dibilang jenis pengujian yang paling penting, karena dilakukan oleh Tim Penjaminan Mutu yang akan mengukur apakah aplikasi memenuhi spesifikasi yang dimaksudkan dan memenuhi persyaratan klien. Tim QA akan memiliki serangkaian skenario yang telah ditulis sebelumnya dan kasus uji yang akan digunakan untuk menguji aplikasi.
Lebih banyak ide akan dibagikan tentang aplikasi dan lebih banyak tes dapat dilakukan untuk mengukur keakuratannya dan alasan mengapa proyek dimulai. Tes penerimaan tidak hanya dimaksudkan untuk menunjukkan kesalahan ejaan sederhana, kesalahan kosmetik, atau celah antarmuka, tetapi juga untuk menunjukkan setiap bug dalam aplikasi yang akan mengakibatkan sistem crash atau kesalahan besar dalam aplikasi.
Dengan melakukan uji penerimaan pada suatu aplikasi, tim penguji akan mengurangi bagaimana aplikasi tersebut akan tampil dalam produksi. Ada juga persyaratan hukum dan kontrak untuk penerimaan sistem.
Pengujian Alfa
Tes ini adalah tahap pengujian pertama dan akan dilakukan di antara tim (tim pengembang dan QA). Pengujian unit, pengujian integrasi, dan pengujian sistem bila digabungkan bersama-sama dikenal sebagai pengujian alfa. Selama fase ini, aspek-aspek berikut akan diuji dalam aplikasi -
Kesalahan pengejaan
Tautan Rusak
Arah Berawan
Aplikasi akan diuji pada mesin dengan spesifikasi terendah untuk menguji waktu pemuatan dan masalah latensi apa pun.
Pengujian Beta
Tes ini dilakukan setelah pengujian alpha berhasil dilakukan. Dalam pengujian beta, sampel audiens yang dituju menguji aplikasi. Pengujian beta juga dikenal sebagaipre-release testing. Versi uji beta dari perangkat lunak idealnya didistribusikan ke khalayak luas di Web, sebagian untuk memberikan program tes "dunia nyata" dan sebagian untuk memberikan pratinjau rilis berikutnya. Pada fase ini, penonton akan menguji hal-hal berikut -
Pengguna akan menginstal, menjalankan aplikasi, dan mengirimkan umpan balik mereka ke tim proyek.
Kesalahan tipografi, aliran aplikasi yang membingungkan, dan bahkan crash.
Mendapatkan umpan balik, tim proyek dapat memperbaiki masalah sebelum merilis perangkat lunak ke pengguna sebenarnya.
Semakin banyak masalah yang Anda perbaiki yang menyelesaikan masalah pengguna nyata, semakin tinggi kualitas aplikasi Anda.
Memiliki aplikasi berkualitas lebih tinggi saat Anda merilisnya ke masyarakat umum akan meningkatkan kepuasan pelanggan.
Pengujian Non-Fungsional
Bagian ini didasarkan pada pengujian aplikasi dari atribut non-fungsionalnya. Pengujian non-fungsional melibatkan pengujian perangkat lunak dari persyaratan yang sifatnya nonfungsional tetapi penting seperti kinerja, keamanan, antarmuka pengguna, dll.
Beberapa jenis pengujian non-fungsional yang penting dan umum digunakan dibahas di bawah ini.
Pengujian Kinerja
Ini sebagian besar digunakan untuk mengidentifikasi kemacetan atau masalah kinerja daripada menemukan bug dalam perangkat lunak. Ada penyebab berbeda yang berkontribusi dalam menurunkan kinerja perangkat lunak -
Penundaan jaringan
Pemrosesan sisi klien
Pemrosesan transaksi database
Load balancing antar server
Rendering data
Pengujian kinerja dianggap sebagai salah satu jenis pengujian penting dan wajib dalam hal aspek berikut -
Kecepatan (yaitu Waktu Respons, rendering dan akses data)
Capacity
Stability
Scalability
Pengujian kinerja dapat berupa kualitatif atau kuantitatif dan dapat dibagi menjadi sub-jenis yang berbeda seperti Load testing dan Stress testing.
Pengujian Beban
Ini adalah proses pengujian perilaku perangkat lunak dengan menerapkan beban maksimum dalam hal perangkat lunak mengakses dan memanipulasi data masukan yang besar. Ini dapat dilakukan pada kondisi beban normal dan puncak. Jenis pengujian ini mengidentifikasi kapasitas maksimum perangkat lunak dan perilakunya pada waktu puncak.
Sebagian besar waktu, pengujian beban dilakukan dengan bantuan alat otomatis seperti Load Runner, AppLoader, IBM Rational Performance Tester, Apache JMeter, Silk Performer, Visual Studio Load Test, dll.
Pengguna virtual (VUsers) ditentukan dalam alat pengujian otomatis dan skrip dijalankan untuk memverifikasi pengujian beban untuk perangkat lunak. Jumlah pengguna dapat ditambah atau dikurangi secara bersamaan atau bertahap berdasarkan kebutuhan.
Pengujian Stres
Pengujian stres meliputi pengujian perilaku perangkat lunak dalam kondisi tidak normal. Misalnya, ini mungkin termasuk mengambil beberapa sumber daya atau menerapkan beban di luar batas beban sebenarnya.
Tujuan pengujian stres adalah untuk menguji perangkat lunak dengan menerapkan beban ke sistem dan mengambil alih sumber daya yang digunakan oleh perangkat lunak untuk mengidentifikasi titik putusnya. Pengujian ini dapat dilakukan dengan menguji berbagai skenario seperti -
Matikan atau mulai ulang port jaringan secara acak
Mengaktifkan atau menonaktifkan database
Menjalankan berbagai proses yang menghabiskan sumber daya seperti CPU, memori, server, dll.
Pengujian Kegunaan
Pengujian kegunaan adalah teknik kotak hitam dan digunakan untuk mengidentifikasi kesalahan dan peningkatan dalam perangkat lunak dengan mengamati pengguna melalui penggunaan dan pengoperasiannya.
Menurut Nielsen, usability dapat didefinisikan dalam lima faktor, yaitu efisiensi penggunaan, kemampuan belajar, kemampuan memori, kesalahan / keamanan, dan kepuasan. Menurutnya, kegunaan suatu produk akan baik dan sistem dapat digunakan jika memiliki faktor-faktor di atas.
Nigel Bevan dan Macleod menilai bahwa usability merupakan persyaratan kualitas yang dapat diukur sebagai hasil interaksi dengan sistem komputer. Persyaratan ini dapat dipenuhi dan pengguna akhir akan puas jika tujuan yang diinginkan tercapai secara efektif dengan penggunaan sumber daya yang tepat.
Molich pada tahun 2000 menyatakan bahwa sistem yang ramah pengguna harus memenuhi lima tujuan berikut, yaitu mudah dipelajari, mudah diingat, efisien digunakan, memuaskan untuk digunakan, dan mudah dipahami.
Selain perbedaan definisi usability, terdapat beberapa standar dan kualitas model dan metode yang mendefinisikan usability berupa atribut dan sub atribut seperti ISO-9126, ISO-9241-11, ISO-13407, dan IEEE std. 610.12, dll.
Pengujian UI vs Kegunaan
Pengujian UI melibatkan pengujian Antarmuka Pengguna Grafis dari Perangkat Lunak. Pengujian UI memastikan bahwa GUI berfungsi sesuai dengan persyaratan dan diuji dalam hal warna, kesejajaran, ukuran, dan properti lainnya.
Di sisi lain, pengujian kegunaan memastikan GUI yang baik dan ramah pengguna yang dapat dengan mudah ditangani. Pengujian UI dapat dianggap sebagai sub-bagian dari pengujian kegunaan.
Pengujian Keamanan
Pengujian keamanan melibatkan pengujian perangkat lunak untuk mengidentifikasi setiap kekurangan dan celah dari sudut pandang keamanan dan kerentanan. Di bawah ini adalah aspek utama yang harus dipastikan oleh pengujian keamanan -
Confidentiality
Integrity
Authentication
Availability
Authorization
Non-repudiation
Perangkat lunak aman dari kerentanan yang diketahui dan tidak diketahui
Data perangkat lunak aman
Perangkat lunak sesuai dengan semua peraturan keamanan
Pemeriksaan dan validasi input
Serangan penyisipan SQL
Cacat injeksi
Masalah manajemen sesi
Serangan skrip lintas situs
Buffer overflows kerentanan
Serangan traversal direktori
Pengujian Portabilitas
Pengujian portabilitas mencakup pengujian perangkat lunak dengan tujuan untuk memastikan dapat digunakan kembali dan dapat dipindahkan dari perangkat lunak lain juga. Berikut adalah strategi yang dapat digunakan untuk pengujian portabilitas -
Mentransfer perangkat lunak yang diinstal dari satu komputer ke komputer lainnya.
Membangun executable (.exe) untuk menjalankan perangkat lunak pada platform yang berbeda.
Pengujian portabilitas dapat dianggap sebagai salah satu sub-bagian dari pengujian sistem, karena jenis pengujian ini mencakup pengujian perangkat lunak secara keseluruhan sehubungan dengan penggunaannya di lingkungan yang berbeda. Perangkat keras komputer, sistem operasi, dan browser adalah fokus utama pengujian portabilitas. Beberapa prasyarat untuk pengujian portabilitas adalah sebagai berikut -
Perangkat lunak harus dirancang dan diberi kode, dengan memperhatikan persyaratan portabilitas.
Pengujian unit telah dilakukan pada komponen terkait.
Pengujian integrasi telah dilakukan.
Lingkungan pengujian telah ditetapkan.