Menguji Aplikasi Thread
Pada bab ini, kita akan belajar tentang pengujian aplikasi thread. Kami juga akan mempelajari pentingnya pengujian.
Mengapa Menguji?
Sebelum kita menyelami pembahasan tentang pentingnya pengujian, kita perlu mengetahui apa itu pengujian. Secara umum, pengujian adalah teknik untuk mengetahui seberapa baik sesuatu bekerja. Di sisi lain, secara khusus jika kita berbicara tentang program komputer atau perangkat lunak maka pengujian adalah teknik mengakses fungsionalitas program perangkat lunak.
Pada bagian ini, kita akan membahas pentingnya pengujian perangkat lunak. Dalam pengembangan perangkat lunak, harus ada pengecekan ulang sebelum merilis perangkat lunak ke klien. Itulah mengapa sangat penting untuk menguji perangkat lunak oleh tim penguji yang berpengalaman. Pertimbangkan poin-poin berikut untuk memahami pentingnya pengujian perangkat lunak -
Peningkatan kualitas perangkat lunak
Pastinya, tidak ada perusahaan yang ingin memberikan perangkat lunak berkualitas rendah dan tidak ada klien yang ingin membeli perangkat lunak berkualitas rendah. Pengujian meningkatkan kualitas perangkat lunak dengan menemukan dan memperbaiki bug di dalamnya.
Kepuasan pelanggan
Bagian terpenting dari bisnis apa pun adalah kepuasan pelanggan mereka. Dengan menyediakan perangkat lunak bebas bug dan berkualitas baik, perusahaan dapat mencapai kepuasan pelanggan.
Kurangi dampak fitur baru
Misalkan kita telah membuat sistem perangkat lunak sebanyak 10.000 baris dan kita perlu menambahkan fitur baru maka tim pengembang akan memiliki perhatian tentang dampak fitur baru ini pada keseluruhan perangkat lunak. Di sini, pengujian juga memainkan peran penting karena jika tim penguji telah membuat rangkaian pengujian yang baik, maka hal itu dapat menyelamatkan kita dari potensi jeda bencana.
Pengalaman pengguna
Bagian terpenting lainnya dari bisnis apa pun adalah pengalaman pengguna produk itu. Hanya pengujian yang dapat memastikan bahwa pengguna akhir menganggapnya sederhana dan mudah untuk menggunakan produk.
Mengurangi biaya
Pengujian dapat mengurangi biaya total perangkat lunak dengan menemukan dan memperbaiki bug dalam tahap pengujian pengembangannya daripada memperbaikinya setelah pengiriman. Jika ada bug besar setelah pengiriman perangkat lunak maka itu akan meningkatkan biaya berwujud katakan dalam hal biaya dan biaya tidak berwujud katakan dalam hal ketidakpuasan pelanggan, reputasi negatif perusahaan dll.
Apa yang Harus Diuji?
Selalu disarankan untuk memiliki pengetahuan yang sesuai tentang apa yang akan diuji. Pada bagian ini, pertama-tama kita akan memahami motif utama penguji saat menguji perangkat lunak apa pun. Cakupan kode, yaitu, berapa banyak baris kode yang ditemukan oleh rangkaian pengujian kami, saat pengujian, harus dihindari. Itu karena, saat menguji, fokus hanya pada jumlah baris kode tidak menambah nilai nyata ke sistem kami. Mungkin masih ada beberapa bug, yang terlihat nanti di tahap selanjutnya bahkan setelah penerapan.
Pertimbangkan poin penting berikut terkait dengan apa yang akan diuji -
Kita perlu fokus pada pengujian fungsionalitas kode daripada cakupan kode.
Kita perlu menguji bagian paling penting dari kode terlebih dahulu dan kemudian beralih ke bagian kode yang kurang penting. Ini pasti akan menghemat waktu.
Penguji harus memiliki banyak pengujian berbeda yang dapat mendorong perangkat lunak hingga batasnya.
Pendekatan untuk menguji program perangkat lunak bersamaan
Karena kemampuan memanfaatkan kemampuan sebenarnya dari arsitektur multi-inti, sistem perangkat lunak bersamaan menggantikan sistem sekuensial. Belakangan ini, program sistem konkuren digunakan dalam segala hal mulai dari ponsel hingga mesin cuci, dari mobil hingga pesawat terbang, dll. Kita perlu lebih berhati-hati dalam menguji program perangkat lunak bersamaan karena jika kita telah menambahkan beberapa utas ke aplikasi utas tunggal yang memiliki sudah bug, maka kami akan berakhir dengan banyak bug.
Teknik pengujian untuk program perangkat lunak bersamaan secara ekstensif berfokus pada pemilihan interleaving yang mengekspos pola yang berpotensi berbahaya seperti kondisi balapan, jalan buntu, dan pelanggaran atomisitas. Berikut adalah dua pendekatan untuk menguji program perangkat lunak bersamaan -
Eksplorasi sistematis
Pendekatan ini bertujuan untuk mengeksplorasi ruang interleavings seluas mungkin. Pendekatan semacam itu dapat mengadopsi teknik brute-force dan yang lain mengadopsi teknik pengurangan urutan parsial atau teknik heuristik untuk menjelajahi ruang interleavings.
Didorong oleh properti
Pendekatan berbasis properti bergantung pada pengamatan bahwa kesalahan konkurensi lebih mungkin terjadi di bawah interleavings yang mengekspos properti tertentu seperti pola akses memori yang mencurigakan. Pendekatan berbasis properti yang berbeda menargetkan kesalahan yang berbeda seperti kondisi balapan, kebuntuan, dan pelanggaran atomisitas, yang selanjutnya bergantung pada satu atau properti spesifik lainnya.
Strategi Pengujian
Strategi Tes juga dikenal sebagai pendekatan tes. Strategi tersebut menentukan bagaimana pengujian akan dilakukan. Pendekatan tes memiliki dua teknik -
Proaktif
Pendekatan di mana proses desain pengujian dimulai sedini mungkin untuk menemukan dan memperbaiki cacat sebelum build dibuat.
Reaktif
Pendekatan di mana pengujian tidak dimulai hingga proses pengembangan selesai.
Sebelum menerapkan strategi atau pendekatan pengujian apa pun pada program python, kita harus memiliki gagasan dasar tentang jenis kesalahan yang mungkin dimiliki program perangkat lunak. Kesalahannya adalah sebagai berikut -
Kesalahan sintaksis
Selama pengembangan program, mungkin ada banyak kesalahan kecil. Kesalahan tersebut sebagian besar disebabkan oleh kesalahan pengetikan. Misalnya, titik dua yang hilang atau ejaan kata kunci yang salah, dll. Kesalahan tersebut disebabkan oleh kesalahan dalam sintaksis program dan bukan dalam logika. Oleh karena itu, kesalahan ini disebut kesalahan sintaksis.
Kesalahan semantik
Kesalahan semantik juga disebut kesalahan logika. Jika ada kesalahan logika atau semantik pada program perangkat lunak maka pernyataan akan terkompilasi dan berjalan dengan benar tetapi tidak akan memberikan keluaran yang diinginkan karena logikanya tidak benar.
Pengujian Unit
Ini adalah salah satu strategi pengujian yang paling banyak digunakan untuk menguji program python. Strategi ini digunakan untuk menguji unit atau komponen kode. Yang kami maksud dengan unit atau komponen adalah kelas atau fungsi kode. Pengujian unit menyederhanakan pengujian sistem pemrograman besar dengan menguji unit "kecil". Dengan bantuan konsep di atas, pengujian unit dapat didefinisikan sebagai metode di mana unit individu kode sumber diuji untuk menentukan apakah mereka mengembalikan keluaran yang diinginkan.
Di bagian selanjutnya, kita akan belajar tentang modul Python yang berbeda untuk pengujian unit.
modul unittest
Modul pertama untuk pengujian unit adalah modul unittest. Ini terinspirasi oleh JUnit dan secara default disertakan dalam Python3.6. Ini mendukung otomatisasi pengujian, berbagi pengaturan dan kode shutdown untuk pengujian, agregasi pengujian ke dalam koleksi, dan independensi pengujian dari kerangka pelaporan.
Berikut adalah beberapa konsep penting yang didukung oleh modul unittest
Perlengkapan teks
Ini digunakan untuk menyiapkan pengujian agar dapat dijalankan sebelum memulai pengujian dan dihancurkan setelah pengujian selesai. Ini mungkin melibatkan pembuatan database sementara, direktori, dll. Yang diperlukan sebelum memulai pengujian.
Kasus cobaan
Kasus pengujian memeriksa apakah respons yang diperlukan berasal dari rangkaian input tertentu atau tidak. Modul unittest menyertakan kelas dasar bernama TestCase yang dapat digunakan untuk membuat kasus uji baru. Ini mencakup dua metode default -
setUp()- metode hook untuk menyiapkan perlengkapan tes sebelum melatihnya. Ini dipanggil sebelum memanggil metode pengujian yang diimplementasikan.
tearDown( - metode hook untuk mendekonstruksi perlengkapan kelas setelah menjalankan semua tes di kelas.
Rangkaian pengujian
Ini adalah kumpulan rangkaian pengujian, kasus pengujian, atau keduanya.
Pelari uji
Ini mengontrol jalannya kasus uji atau setelan dan memberikan hasilnya kepada pengguna. Ini mungkin menggunakan GUI atau antarmuka teks sederhana untuk memberikan hasilnya.
Example
Program Python berikut menggunakan modul unittest untuk menguji modul bernama Fibonacci. Program ini membantu dalam menghitung deret Fibonacci dari suatu angka. Dalam contoh ini, kami telah membuat kelas bernama Fibo_test, untuk menentukan kasus uji dengan menggunakan metode yang berbeda. Metode ini diwarisi dari unittest.TestCase. Kami menggunakan dua metode default - setUp () dan tearDown (). Kami juga mendefinisikan metode testfibocal. Nama tes harus dimulai dengan tes huruf. Di blok terakhir, unittest.main () menyediakan antarmuka baris perintah ke skrip pengujian.
import unittest
def fibonacci(n):
a, b = 0, 1
for i in range(n):
a, b = b, a + b
return a
class Fibo_Test(unittest.TestCase):
def setUp(self):
print("This is run before our tests would be executed")
def tearDown(self):
print("This is run after the completion of execution of our tests")
def testfibocal(self):
self.assertEqual(fib(0), 0)
self.assertEqual(fib(1), 1)
self.assertEqual(fib(5), 5)
self.assertEqual(fib(10), 55)
self.assertEqual(fib(20), 6765)
if __name__ == "__main__":
unittest.main()
Saat dijalankan dari baris perintah, skrip di atas menghasilkan keluaran yang terlihat seperti ini -
Keluaran
This runs before our tests would be executed.
This runs after the completion of execution of our tests.
.
----------------------------------------------------------------------
Ran 1 test in 0.006s
OK
Sekarang, untuk membuatnya lebih jelas, kami mengubah kode kami yang membantu dalam mendefinisikan modul Fibonacci.
Pertimbangkan blok kode berikut sebagai contoh -
def fibonacci(n):
a, b = 0, 1
for i in range(n):
a, b = b, a + b
return a
Beberapa perubahan pada blok kode dilakukan seperti yang ditunjukkan di bawah ini -
def fibonacci(n):
a, b = 1, 1
for i in range(n):
a, b = b, a + b
return a
Sekarang, setelah menjalankan skrip dengan kode yang diubah, kita akan mendapatkan output berikut -
This runs before our tests would be executed.
This runs after the completion of execution of our tests.
F
======================================================================
FAIL: testCalculation (__main__.Fibo_Test)
----------------------------------------------------------------------
Traceback (most recent call last):
File "unitg.py", line 15, in testCalculation
self.assertEqual(fib(0), 0)
AssertionError: 1 != 0
----------------------------------------------------------------------
Ran 1 test in 0.007s
FAILED (failures = 1)
Keluaran di atas menunjukkan bahwa modul gagal memberikan keluaran yang diinginkan.
Modul Docktest
Modul docktest juga membantu dalam pengujian unit. Itu juga datang dikemas dengan python. Ini lebih mudah digunakan daripada modul unittest. Modul unittest lebih cocok untuk pengujian yang kompleks. Untuk menggunakan modul doctest, kita perlu mengimpornya. Docstring untuk fungsi yang sesuai harus memiliki sesi python interaktif bersama dengan keluarannya.
Jika semuanya baik-baik saja di kode kita maka tidak akan ada keluaran dari modul docktest; jika tidak, itu akan memberikan hasil.
Contoh
Contoh Python berikut menggunakan modul docktest untuk menguji modul bernama Fibonacci, yang membantu dalam menghitung deret Fibonacci dari suatu angka.
import doctest
def fibonacci(n):
"""
Calculates the Fibonacci number
>>> fibonacci(0)
0
>>> fibonacci(1)
1
>>> fibonacci(10)
55
>>> fibonacci(20)
6765
>>>
"""
a, b = 1, 1
for i in range(n):
a, b = b, a + b
return a
if __name__ == "__main__":
doctest.testmod()
Kita dapat melihat bahwa docstring dari fungsi yang sesuai bernama fib memiliki sesi python interaktif bersama dengan outputnya. Jika kode kita baik-baik saja maka tidak akan ada keluaran dari modul doctest. Tapi untuk melihat cara kerjanya kita bisa menjalankannya dengan opsi –v.
(base) D:\ProgramData>python dock_test.py -v
Trying:
fibonacci(0)
Expecting:
0
ok
Trying:
fibonacci(1)
Expecting:
1
ok
Trying:
fibonacci(10)
Expecting:
55
ok
Trying:
fibonacci(20)
Expecting:
6765
ok
1 items had no tests:
__main__
1 items passed all tests:
4 tests in __main__.fibonacci
4 tests in 2 items.
4 passed and 0 failed.
Test passed.
Sekarang, kita akan mengubah kode yang membantu dalam mendefinisikan modul Fibonacci
Pertimbangkan blok kode berikut sebagai contoh -
def fibonacci(n):
a, b = 0, 1
for i in range(n):
a, b = b, a + b
return a
Blok kode berikut membantu dengan perubahan -
def fibonacci(n):
a, b = 1, 1
for i in range(n):
a, b = b, a + b
return a
Setelah menjalankan skrip bahkan tanpa opsi –v, dengan kode yang diubah, kita akan mendapatkan output seperti yang ditunjukkan di bawah ini.
Keluaran
(base) D:\ProgramData>python dock_test.py
**********************************************************************
File "unitg.py", line 6, in __main__.fibonacci
Failed example:
fibonacci(0)
Expected:
0
Got:
1
**********************************************************************
File "unitg.py", line 10, in __main__.fibonacci
Failed example:
fibonacci(10)
Expected:
55
Got:
89
**********************************************************************
File "unitg.py", line 12, in __main__.fibonacci
Failed example:
fibonacci(20)
Expected:
6765
Got:
10946
**********************************************************************
1 items had failures:
3 of 4 in __main__.fibonacci
***Test Failed*** 3 failures.
Kita dapat melihat pada keluaran di atas bahwa tiga pengujian telah gagal.