Son yıllarda gelişen teknolojiyle birlikte yazılıma olan ilginin artması, genç neslin bu alanı kariyer olarak seçmesinde büyük rol oynuyor. Hayatımızın her alanına giren teknolojiler ve yazılımlar, yazılım test etme ihtiyacını artırıp, yeni bir kariyer yolunun açılmasını sağlıyor.

Nedir bu Yazılım Testi?

Yazılım testi, yazılımın gereksinimleri karşılayıp karşılamadığını kontrol etme ve doğrulama işlemidir. Bu süreç, yazılımın tasarlandığı gibi çalışmasını ve müşterinin beklediği gereksinimleri karşılamasını sağlamayı amaçlamaktadır.

Bu süreçte hatalar tespit edilip düzeltilmekte, böylece yazılım son kullanıcıya ulaşmadan eksiklikler giderilmekte ve kalite artırılmaktadır. Hataların son kullanıcıya ulaşmadan tespit edilmesi ve düzeltilmesi, uzun vadede maliyetleri azaltır. Bu nedenle yazılım testi, yazılım geliştirme yaşam döngüsünde büyük önem taşımaktadır.

Peki Yazılım Test Mühendisi Kimdir?

Yazılım test mühendisleri, geliştiriciler tarafından geliştirilen yazılımın gereksinimleri karşılayıp karşılamadığını değerlendiren, yazılımın tasarıma uygun olup olmadığını doğrulayan, kusur bulmayı hedefleyen, ‘hiçbir kod hatasız olmaz’ sloganını benimseyen, hata bulana kadar dinlenmeyen kişilerdir.

Bir yazılım test mühendisinin araştırmacı ve sorgulayıcı bir kişiliğe sahip olması gerekir. Bir dedektif gibi böceklerin (bug) izini sürmeli ve onları bulmalıdırlar.

Bir yazılım test mühendisi, yazılım geliştirme yaşam döngüsü boyunca kritik bir rol oynar. Neyin test edilmesi gerektiğini belirleyerek, yazılımın belirlenen gereksinimleri karşıladığından emin olmak için test gereksinimlerini belirleyerek başlarlar. Yazılımın işlevselliğini değerlendirmek ve acil sorunları belirlemek için ilk manuel testler gerçekleştirilir.

Manuel testin kapsamı tamamlandığında, test mühendisi çeşitli teknolojileri kullanarak otomatik testler geliştirmeye ve yürütmeye devam eder. Bu geçiş, yazılımın güvenilirliğini doğrulamak ve test sürecini kolaylaştırmak, daha verimli ve kapsamlı hale getirmek için çok önemlidir.

Test sırasında ortaya çıkan hatalar, ayrıntılı belgelerle birlikte geliştirme ekibine titizlikle rapor edilir ve bir test mühendisi, bu sorunların anında anlaşılmasını ve ele alınmasını sağlamak için sürekli iletişimi sürdürür.

Bir test mühendisi, testleri yürütmenin ve raporlamanın yanı sıra, devam eden sorunları daha ayrıntılı olarak belirlemek ve çözmek için hata ayıklama programlarının çalıştırılmasında da proaktif bir rol oynar. Test planlarını güçlendiren ve yazılımın en yüksek kalite standartlarına uymasını sağlayan otomatik test komut dosyalarının oluşturulmasına katkıda bulunurlar.

Ayrıca test mühendisleri, keşfedilen hata türlerini özetleyen kapsamlı raporların üretilmesinden ve alınan düzeltici önlemlerin belgelenmesinden sorumludur. Bu raporlar, ilerlemenin izlenmesi ve tarihsel referans açısından önemlidir.

Yazılım geliştiricilerle birlikte çalışan test mühendisleri, olası hataları tespit etmek, riskleri değerlendirmek ve sorunları gidermek için ortak bir çaba içindedir. Bu ortaklık, risklerin azaltılması ve yazılım ürününün tamamlanmasından önce ortaya çıkabilecek endişelerin giderilmesi, böylece ürünün bütünlüğünün korunması ve son kullanıcılara sağlam ve güvenilir bir yazılımın sunulmasının sağlanması açısından hayati öneme sahiptir.

Test Mühendisi Olarak Günüm Nasıl Geçiyor?

Bir yazılım test mühendisi olarak sorumluluklarım arasında ofiste gün boyunca çeşitli görevler yer alıyor. Sabah ilk iş, geliştiriciler, analistler ve test mühendisi arkadaşlarımla dün nelerin başarıldığını ve bugünün hedeflerinin neler olduğunu tartıştığımız günlük stand-up toplantılarına katılıyorum.

Toplantı sonrasında üzerinde çalıştığım projelerin analiz raporlarını okuyup tasarımları inceliyorum. İhtiyaçlara göre analizlerimi gerçekleştirip projeleri manuel olarak incelemeye başlamak için gerekli ortamları hazırlıyorum.

Manuel testler sırasında, hatanın oluştuğu ortam, hata türü ve bu hataya ulaşmak için atılan adımlar da dahil olmak üzere karşılaştığım sorunların ayrıntılarını içeren bir rapor hazırlıyorum.

Geliştiriciler hataları düzelttikten sonra, sorunların çözüldüğünden emin olmak için aynı adımları yeniden uyguluyorum.

Manuel testleri tamamladıktan sonra projenin uygunluğuna göre hangi otomasyon çerçevesini kullanacağıma karar verip otomasyon scriptlerimi yazmaya başlıyorum. Bu, her seferinde birçok adımı manuel olarak tekrarlamak zorunda kalmayarak zamandan tasarruf etmeme olanak tanıyor.

Bu döngü tüm sprintler boyunca devam eder.