860 likes | 1.41k Views
TESTING & IMPLEMENTASI SISTEM. Pengkodean Perangkat Lunak , Dasar & Strategi pengujian perangkat lunak Diema HS, S.Kom. PENGKODEAN PERANGKAT LUNAK. Perbedaan bahasa generasi ke-4 dengan bahasa generasi ke3. 4GL Jalur kode yang lebih sedikit
E N D
TESTING & IMPLEMENTASI SISTEM PengkodeanPerangkatLunak, Dasar & Strategipengujianperangkatlunak Diema HS, S.Kom
Perbedaanbahasagenerasi ke-4 denganbahasagenerasi ke3 • 4GL • Jalurkode yang lebihsedikit • Memberikan potensi dilakukannya pemrograman oleh end user untuk aplikasi mereka sendiri • Metodologipengembangan • Produktivitas yang meningkat • Layanan yang meningkat • Partisipasipemakai
Perbedaanbahasagenerasi ke-4 denganbahasagenerasi ke3 • 3GL • Kepadatan • Efisiensimesin • Fungsionalitas • Kompatibilitas • Produktivitaspengkodean • Pengujiandanpemeliharaan
Bahasapemrogramanberorientasiobjek • Jenisbahasa OOP • Murni • Smalltalk • Hybrid • w C++ • C • Cobol
Perangkatbahasapenggunaankhusus • Alatbahasaberorientasipemakaiinteraktif • DBMS • Alat bahasa hypertext dan multimedia
Memilihbahasa yang tepat • Mencocokanbahasadenganaplikasirancanganperangkatlunak • Tingkat penggunaandalamduniabisnis • Keekspresifan • Kemudahan • Maintainability
(IEEE – Institute of Electrical and Electronics Engineering, ANSI – American National Standards Institute) • Menurutstandar ANSI/IEEE 1059 Testing adalahprosesmenganalisasuatuentitas software untukmendeteksiperbedaanantarakondisi yang adadengankondisi yang diinginkan(defect/errors/bugs) danmengevaluasifitur-fiturdarientitas software
DefinisiSederhanaKualitas • Menurut CROSBY: Kualitasadalahpemenuhanterhadapkebutuhan. • Menurut ISO-8402: Kualitasadalahkeseluruhandarifitur yang menjadikanprodukdapatmemuaskanataudipakaisesuaikebutuhandenganharga yang terjangkau. • Menurut W.E. Perry: Kualitasadalahpemenuhanterhadapstandar. • Menurut R. Glass: Kualitasadalahtingkatkesempurnaan. • Menurut J. Juran: Kualitasadalahtepatguna.
Hubungan testing dankualitas Software yang berkualitasadalah software yang bebas error dan bug secaraobjektif, tepatwaktudandana, sesuaidengankebutuhanataukeinginandandapatdirawat (maintainable) Definisiobjektif : Suatuprosespembuktian yang terstruktur, terencanadanterdokumentasidenganbaik
Hubungan Testing Dan Kualitas Testing membuatkualitasdapatdilihatsecaraobjektif, karena testing merupakanpengukurandarikualitas software Testing tidakdapatmemastikankualitas software, namundapatmemberikanjaminanterhadap software padasuatutingkattertentu Jaminankualitas (Quality Assurance – QA) mengukurkualitasproses yang digunakanuntukmembuatprodukberkualitas Testing merupakanbagiandariaktifitas QA
Hubungan Testing DenganKualitas Proyekpengembangan software memilikikecenderunganuntukmengalamikegagalan Proyek yang gagal ??? Salahsatuusahamenurunkantingkatresikoterjadinyakegagalanadalahdenganberorientasipadakualitas
Tujuan testing Adalahmenemukansebanyakmungkinmasalah (error) Tujuandarimenemukanmasalahadalahmemperbaikinya Tanganimasalah yang bersifatpenting, karenatidaksemuapermasalahandapat.
Misitim testing Tidakhanyauntukmelakukan testing, tetapijugamembantumeminimalkanresikokegagalanproyek Mencarimasalahdariproduk Mencarimasalahpotensial Mencarikehadiranmasalah Intinyaadalahmencaridanmelaporkansehinggatim lain dapatmembuatkeputusanterhadappengembanganproduk
Cont'd Perludiingat, tester hanyamenginformasikan Tidakmelakukanpembenahankode Tester adalahindividu yang memberikanhasil pengukurandarikualitasproduk
Psikologi testing Jika pengembangan dilakukan secara konstruktif, maka testing dilakukan secara destruktif Tester harus mempunyai keinginan yang mendasar untuk membuktikan kode gagal dan akan melakukan apa saja untuk membuatnya gagal Bila seorang tester hanya ingin membuktikan bahwa kode beraksi sesuai dengan fungsi bisnisnya, maka tester tersebut telah gagal dalam menjalankan tugasnya sebagai tester
Prinsip-prinsip testingprinsip pertama Testing yang komplit (dilakukansecaramenyeluruh) tidakmemungkinkandilakukan. Kemungkinanjumlahkombinasitestcase yang amatbesar Pertimbangan domain masukan yang mungkinsangatbesarjumlahnya (masukan yang valid, tdk valid, masukanygdieditdll) Kompleksitas user interface dandesain.
Cont'd Jalur program yang mungkindapatdilewatisangatbanyak Harusdilakukan test ulang, setiapadaperbaikanpadamasing-masing bug
Prinsip kedua Testing merupakanpekerjaan yang kreatifdansulit mitos-mitos yang salahtentang testing : Testing itumudah Tiaporangakandapatmelakukan testing dengansendirinya padahal
Cont'd Testing bukanlahhal yang sederhana, karena Untukdapatmelakukan testing yang efektifharusmengetahuikeseluruhansistem Sistemsendiritidaksederhana (mudahdipahami)
Prinsipketiga Testing berbasispadaresiko walaupun testing secarakeseluruhantidakdapatdilakukan, tidakberartibahwa testing yang efektiftidakdapatdilakukan testing merupakanhasilpertimbangandariresikodanekonomi
Cont'd Secararingkas, testing dipengaruhiolehpertimbangan : Sumberdayadanbiaya yang dibutuhkanuntukmelakukan testing menurutskalaprioritas, kompleksitasdankesulitan testing Biayadariketerlambatanpengirimanproduk (kemungkinanbesardisebabkan testing) Kemungkinanadanyasuatu defect Biaya yang disebabkanoleh defect, bilamana defect tsbmenyebabkan error yang membawakerugianlangsungmaupuntaklangsungbagi customer
Prinsip keempat Testing harusdirencanakan butuhpemikirandgnpendekatansecarakeseluruhan, desaintesdanpenetapanhasilygdiinginkanutksetiapkasustes (test case) ygdipilih test plan : dokumenygmencakupkeseluruhtujuan testing danpendekatan testing test design : dokumenygmendefinisikanapaygtelahdipilihutkditesdanhasilygdiharapkan “test direncanakandandidesainsebelumkodedibuat”
Cont'd Perencanaantessangatpenting, yaitu : Utkdptmenjagaarahpelaksanaantes agar tidakmenyimpangdaritujuantesitusendiri (mengukurkualitas SW) Menjagakesesuaianpenggunaansumberdayadanjadualproyekdenganmenetapkanapa yang akanditesdankapanberhenti Membantu tester fokusterhadapapa yang akandites (membuat test case)
Prinsip kelima Testing butuhindependensi testing yang paling efektifadalah yang dilakukanolehpihakketiga (tidak bias)
Dasar-dasar testing Testing dikatakan baik, jika : Kemungkinan mendapatkan error tinggi Tidak redundan --> resource terbatas, tiap tes yang dilakukan HARUS memiliki tujuan yang berbeda Tidak terlalu simpel atau kompleks
Cont'd Kode untuk kondisi khusus mendapatkan porsi tes yang sama dengan kode yang umum Kode untuk kondisi khusus --> peluang memp. bug tinggi Testing untuk kode yang dijalankan dalam kondisi normal tidak mengeksekusi error handling code Testing yang sukses adalah testing yang berhasil menemukan error yang tidak diketahui
Strategiujicoba PL memudahkanparaperancanguntukmenentukankeberhasilan system ygtelahdikerjakan. Hal ygharusdiperhatikanadalah langkah-langkah perencanaan dan pelaksanaan harus direncanakan denganbaikdanberapa lama waktu, upayadansumberdayaygdiperlukan. • Strategiujicobamempunyaikarakteristiksbb : • Pengujianmulaipadatingkatmodulyg paling bawah, dilanjutkandgnmoduldiatasnyakemudianhasilnyadipadukan. • Teknikpengujian yang berbedamungkinmenghasilaknsedikit perbedaan (dalamhalwaktu)
Pengujiandilakukanolehpengembangperangkatlunakdan (untukproyek yang besar) suatukelompokpengujian yang independen. • Pengujiandan debugging merupakanaktivitas yang berbeda, tetapi debugging termasukdalamstrategipengujian. • Pengujian PL adalahsatuelemendaritopik yang lebihluas yang sering diacusebagaiverifikasidanvalidasi (V& V). • Verifikasi : Kumpulan aktifitasygmenjaminpenerapan PL benar-benarsesuaidgnfungsinya. • Validasi : Kumpulan aktivitas yang berbeda yang memastikanbahwa PL yang dibangundapatmemenuhikeperluanpelanggan. • Dgnkata lain : • Verifikasi : “ Apakahkitamembuatprodukdgnbenar?” • Validasi : “ Apakahkitamembuatbenar-benarsuatuproduk?”
PendekatanStrategiskepengujianperangkatlunak • Pengujian Unit • PengujianIntegrasi • PengujianValidasi • PengujianSistem
1. Pengujian Unit • Berfokuspadaintiterkecildaridesainperangkatlunakyaitumodul • Biasanyaberorientasipada white box
Pengujian Unit • Checklist untukpengujian interface (Myers) • Apakahjumlah parameter input samadenganjumlahargumen? • Apakah antara atribut dan parameter argumen sudahcocok? • Apakah antara sistem satuan parameter dan argumensudahcocok? • Apakahjumlahargumen yang ditransmisikankemodul yang dipanggilsamadenganatribut parameter?
Pengujian Unit • Apakahatributdariargumen yang ditransmisikankemodul yang dipanggilsamadenganatribut parameter? • Apakahsistem unit dariargumen yang ditransmisikankemodul yang dipanggilsamadengansistemsatuan parameter? • Apakahjumlahatributdanurutanargumenkefungsi-fungsi built-in sudahbenar? • Adakahreferensike parameter yang tidaksesuaidengan poin entri yang ada? • Apakahargumen input only diubah? • Apakahdefinisivariabel global konsistendenganmodul ? • Apakahbatasan yang dilaluimerupakanargumen?
Pengujian Unit • Test case harusdidesainuntukmengungkapkesalahandalamkategori • pengetikan yang tidakteraturdantidakkonsisten • inisialisasi yang salahataunilai-nilai default • Namavariabel yang tidakbenar • Tipe data yang tidakkonsisten
Seberapabaiksistem yang sudahdibangun ? • DuaAspek yang dipertimbangkan: • Apakahimplementasisudahsesuaidenganspesifikasi ? • Apakah spesifikasi sesuai dengan kebutuhan user ? • Validasi • “Apakahsistem yang dikembangkansudahbenar?” • Pengujiandimanasistemketikadiimplementasikansesuaidengan yang diharapkan • Verifikasi • “Apakahsistemdikembangkandengancara yang benar ?” • Pengujianapakahsistemsudahsesuaidenganspesifikasi
2. Integration testing • Menjelaskankecacatandalamantarmukadaninteraksiantarkomponenterpadu (modul). • Semakinbesarkelompokkomponenperangkatlunak yang diujiterkaitdenganelemen-elemendaridesainarsitekturnyaakandipadukandandiujisampaiperangkatlunakbekerjasebagaisistem.
3. PengujianValidasi • Setelahsemuakesalahandiperbaikimakalangkahselanjutnyaadalahvalidasi testing. • Pengujianvalidasidikatakanberhasilbilafungsiygadapada PL sesuaidgnygdiharapkanpemakai. • Validasi PL merupakankumpulanseriujicoba black box ygmenunjukkansesuaidgnygdiperlukan. • Kemungkinankondisisetelahpengujian: 1. Karakteristikperformansifungsisesuaidgnspesifikasidandapat diterima. 2. Penyimpangandarispesifikasiditemukandandibuatkandaftar penyimpangan.
Pengujian Alpha dan Beta • Apabila PL dibuatuntukpelangganmakadapatdilakukanaceeptance test sehinggamemungkinkanpelangganuntukmemvalidasiseluruhkeperluan. • Test ini dilakukan karena memungkinkan pelanggan menemukan kesalahan yglebihrincidanmembiasakanpelangganmemahami PL ygtelahdibuat.
Pengujian Alpha Dilakukanpadasisipengembangolehseorangpelanggan. PL digunakanpada setting yg natural dgnpengembang “ygmemandang” melaluibahupemakaidanmerekamsemuakesalahandanmasalahpemakaian. • Pengujian Beta Dilakukanpadasatuataulebihpelangganolehpemakaiakhir PL dalamlingkunganygsebenarnya, pengembangbiasanyatidakadapadapengujianini. Pelangganmerekansemuamasalah (real atauimajiner) ygditemuiselamapengujiandanmelaporkanpadapengembangpada interval waktutertentu.
4. PengujianSistem • Padaakhirnya PL digabungkandgnelemen system lainnyadanrentetanperpaduan system danvalidasitesdilakukan. Jikaujicobagagalataudiluarskopedariprosesdaursikluspengembangan system, langkahygdiambilselamaperancangandanpengujiandapatdiperbaiki. Keberhasilan perpaduan PL dan system ygbesarmerupakankuncinya. • Sistem testing merupakanrentetanpengujianygberbeda-bedadgntujuanutamamengerjakankeseluruhanelemen system ygdikembangkan.
PengujianSistem (lanjutan) • Recovery/perbaikan Testing Adalah system testing ygmemaksa PL mengalamikegagalandalam bermacam-macamcaradanmemeriksaapakahperbaikandilakukandgn tepat. • Security Testing Adalahpengujianygakanmelalukanverifikasidarimekanisme perlindunganygakandibuatoleh system, melindungidarihal-halyg mungkinterjadi. • Strees Testing Dirancanguntukmenghadapisituasiygtidak normal padasaat program diuji. Testing inidilakukanoleh system untukkondisiseperti volume data ygtidak normal (melebihiataukurangdaribatasan) ataufrkkuensi.
Menjalankan test • Testing aplikasi desktop • Testing aplikasi server • Testing aplikasi web
1.Testing aplikasi desktop • Jenis : • Functionality : • Aplikasiharusterlihatdanberfungsisebagaimanamestinyaterhadap end-user ataupenggunaakhir. Testing dilakukandenganmenggunakan data yang menggambarkan data yang digunakanolehpenggunasesungguhnya. • Data yang dimasukkantersimpandenganbenarpada database. • Pengujiandilakukansekelompokpenggunadengankemampuan yang berbeda. • Configuration • JikaaplikasiAndadi-develop untuklingkungan yang besar, testing harusdilakukanpadakomputerkhusus. Komputer yang digunakansebagaikomputer testing harusterlebihdahuludikonfigurasihanyadengan: a. Operating system yang dibutuhkan. b. Software pendukung/add on untukaplikasiDriver yang diperlukanolehaplikasi, jikaada. c. Aplikasi yang dites.
Compatibility • Hardware • OS • Diimplementasikanpadakonfigurasi yang berbedadiujicompatibilitasnya. Misalnyajikamembuatdi IE, cobadi Firefox, Opera, Safari • HTML validation
2. PengujianAplikasi Server • Volume Testing • Stress Testing • Performance Testing • Data Recovery Testing • Data Backup and Restore Testing • Data Security Testing
Volume Testing • Menemukankelemahansistemselamamelakukan pemrosesan data dalam jumlah yang besardalamperiodewaktu yang singkat. • Tujuan: meyakinkan bahwa sistem tetap melakukanpemrosesan data antarabatasanfisikdanbatasanlogik. • Contoh: • Mengujikanprosesantar server danantarpartisihardisik pd satu server.
Stress Testing • Tujuan: mengetahuikemampuansistemdalam melakukan transaksi selama periode waktupuncakproses. Contohperiodepuncak: ketika penolakan proses login on-line setelahsistem down ataupadakasus batch, pengiriman batch prosesdalamjumlahygbesardilakukansetelahsistem down. • Contoh: Melakukan login ke server ketikasejumlahbesar workstation melakukanproses menjalankan perintah sql database.
Performance Testing • Dilakukan secara paraleldenganVolume dan Stress testing untukmengetahuiunjukkerjasistem (wakturespon, throughput rate) padabeberapakondisiprosesdankonfigurasi. • Dilakukan pada semua konfigurasi sistem perangkat kerasdanlunak. • Mis.: pd aplikasi Client-Server diujikan pd kondisikorporate ataupunlingkungansendiri (LAN vs. WAN, Laptop vs. Desktop) • Mengujisistemdenganhubungannyasistemke lain pada server ygsama. • Load Balancing Monitor • Network Monitor