Çevik Test - Genel Bakış
Agilehem geliştirme hem de test faaliyetlerinin eşzamanlı olduğu yinelemeli bir geliştirme metodolojisidir. Test ayrı bir aşama değildir; Kodlama ve Test, etkileşimli ve aşamalı olarak yapılır, bu da müşteri gereksinimlerini karşılayan kaliteli son ürün ile sonuçlanır. Dahası, sürekli entegrasyon, kusurların erken giderilmesi ve dolayısıyla zaman, çaba ve maliyet tasarrufu sağlar.
Çevik Manifesto
Çevik Manifesto, 2001 yılında bir yazılım geliştiricileri ekibi tarafından yayınlandı ve geliştirme ekibinin önemini vurgulayarak, değişen gereksinimleri ve müşteri katılımını barındırdı.
The Agile Manifesto is −
Bunu yaparak ve başkalarının yapmasına yardımcı olarak yazılım geliştirmenin daha iyi yollarını ortaya çıkarıyoruz. Bu çalışma sayesinde, değer kazandık -
- Süreçler ve araçlardan ziyade bireyler ve etkileşimler.
- Kapsamlı dokümantasyon yerine çalışan yazılım.
- Sözleşme müzakeresi yerine müşteri işbirliği.
- Bir planı takip etmek yerine değişime yanıt vermek.
Yani sağdaki öğelerde değer varken soldaki öğelere daha çok değer veriyoruz.
Çevik Test nedir?
Çevik Test, çevik yazılım geliştirme ilkelerini takip eden bir yazılım test uygulamasıdır.
Çevik Test, test uzmanlarının katkı sağladığı özel uzmanlığa sahip proje ekibinin tüm üyelerini kapsar. Test, ayrı bir aşama değildir ve gereksinimler, tasarım ve kodlama ve test senaryosu oluşturma gibi tüm geliştirme aşamalarıyla iç içe geçmiştir. Test, Geliştirme Yaşam Döngüsü boyunca eşzamanlı olarak gerçekleşir.
Dahası, test uzmanlarının işlevler arası ekip üyeleriyle birlikte tüm Geliştirme Yaşam Döngüsüne katılmasıyla, test uzmanlarının yazılımı müşteri gereksinimlerine göre, daha iyi tasarım ve kodla oluşturmaya katkısı mümkün olacaktır.
Çevik Test, tüm test seviyelerini ve her tür testi kapsar.
Çevik Test Vs. Şelale Testi
Bir Şelale Geliştirme metodolojisinde, Geliştirme Yaşam Döngüsü etkinlikleri sıralı aşamalar halinde gerçekleşir. Bu nedenle test, ayrı bir aşamadır ve ancak geliştirme aşaması tamamlandıktan sonra başlatılır.
Çevik Test ve Şelale Testi arasındaki farkların önemli noktaları aşağıda verilmiştir -
Çevik Test | Şelale Testi |
---|---|
Test, ayrı bir aşama değildir ve geliştirme ile eşzamanlı olarak gerçekleşir. | Test ayrı bir aşamadır. Tüm test seviyeleri ve türleri ancak geliştirme tamamlandıktan sonra başlayabilir. |
Test uzmanları ve geliştiriciler birlikte çalışır. | Test uzmanları, geliştiricilerden ayrı çalışır. |
Test uzmanları, gereksinimleri belirlemeye dahil olur. Bu, gerçek dünya senaryosundaki davranışların gereksinimlerini eşleştirmeye ve ayrıca kabul kriterlerini çerçevelemeye yardımcı olur. Ayrıca, mantıksal Kabul Testi Durumları, gereksinimlerle birlikte hazır olacaktır. | Test uzmanları, gereksinimler aşamasına dahil olamaz. |
Her yinelemeden sonra Kabul Testi yapılır ve müşteri geri bildirimi alınır. | Kabul Testi sadece proje sonunda yapılır. |
Her yineleme kendi testini tamamlar ve böylece her yeni işlev veya mantık piyasaya sürüldüğünde regresyon testinin uygulanmasına izin verir. | Regresyon Testi ancak geliştirme tamamlandıktan sonra uygulanabilir. |
Kodlama ve test arasında zaman gecikmesi yok. | Kodlama ve test arasındaki olağan gecikme süreleri. |
Çakışan test seviyeleri ile sürekli test. | Test, zamanlanmış bir faaliyettir ve test seviyeleri çakışamaz. |
Test, en iyi uygulamadır. | Test genellikle gözden kaçar. |
Çevik Test İlkeleri
Çevik testin ilkeleri şunlardır:
Testing moves the project forward- Sürekli test, sürekli ilerleme sağlamanın tek yoludur. Çevik Test, sürekli olarak geri bildirim sağlar ve nihai ürün iş taleplerini karşılar.
Testing is not a phase- Çevik ekip, belirli bir yineleme sırasında uygulanan özelliklerin gerçekten yapıldığından emin olmak için geliştirme ekibiyle birlikte test eder. Test daha sonraki bir aşama için tutulmaz.
Everyone tests- Çevik testte, analistler, geliştiriciler ve test uzmanları dahil olmak üzere tüm ekip uygulamayı test eder. Her yinelemeden sonra, müşteri bile Kullanıcı Kabul Testini gerçekleştirir.
Shortening Feedback Loops- Çevik Testte, iş ekibi her bir yineleme için ürün geliştirmeyi öğrenir. Her yinelemede yer alırlar. Sürekli geri bildirim, geri bildirim yanıt süresini kısaltır ve dolayısıyla düzeltmenin maliyeti daha azdır.
Keep the Code Clean- Aynı yinelemede ortaya çıktıkça kusurlar giderilir. Bu, geliştirmenin herhangi bir kilometre taşında temiz kod sağlar.
Lightweight Documentation - Kapsamlı test dokümantasyonu yerine, Çevik test ediciler -
Test önermek için yeniden kullanılabilir kontrol listelerini kullanın.
Tesadüfi ayrıntılardan ziyade testin özüne odaklanın.
Hafif dokümantasyon stillerini / araçlarını kullanın.
Keşif testleri için sözleşmelerde test fikirleri yakalayın.
Belgeleri birden çok amaç için kullanın.
Leveraging one test artifact for manual and automated tests- Aynı test komut dosyası yapısı manuel test için ve otomatik testler için girdi olarak kullanılabilir. Bu, Manuel Test Dokümantasyonu ve ardından eşdeğer bir Otomasyon Test Komut Dosyası gerekliliğini ortadan kaldırır.
“Done Done,” not just done - Agile'da bir özelliğin geliştirildikten sonra değil, geliştirme ve testten sonra yapıldığı söyleniyor.
Test-Last vs. Test Driven- Test Örnekleri gerekliliklerle birlikte yazılır. Bu nedenle geliştirme, testlerle yürütülebilir. Bu yaklaşıma Test Güdümlü Geliştirme (TDD) ve Kabul Testi Güdümlü Geliştirme (ATDD) denir. Bu, Şelale Testinin son aşaması olarak yapılan testin tersidir.
Çevik Test Faaliyetleri
Proje Düzeyindeki Çevik Test Faaliyetleri:
Sürüm Planlama (Test Planı)
Her Yineleme için
Bir Yineleme Sırasında Çevik Test Etkinlikleri
Gerileme testi
Sürüm Etkinlikleri (Testle İlgili)
Bir yineleme sırasında Çevik Test Faaliyetleri şunları içerir:
- Yineleme planlamasına katılmak
- Test açısından görevleri tahmin etme
- Özellik açıklamalarını kullanarak test senaryoları yazma
- Birim Testi
- Entegrasyon Testi
- Özellik Testi
- Kusur Tespiti
- Entegrasyon Testi
- Kabul testleri
- Testin İlerlemesine İlişkin Durum Raporlaması
- Kusur Takibi