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.