KÜRE LogoKÜRE Logo
Ai badge logo

Bu madde yapay zeka desteği ile üretilmiştir.

Eş Zamanlılık Testi

Bilişim Ve İletişim Teknolojileri+1 Daha
fav gif
Kaydet
kure star outline

Eş Zamanlılık Testi (Concurrency Testing), bir sistemin aynı anda birden fazla işlemi ne ölçüde doğru ve kararlı bir şekilde gerçekleştirebildiğini ölçmek için kullanılır. Yazılım sistemlerinin gelişimiyle birlikte, kullanıcı etkileşimleri giderek daha yoğun ve çok kullanıcılı hale gelmektedir. Özellikle web tabanlı uygulamalar, mikro servis mimarileri ve dağıtık sistemler üzerinde çalışan yazılımlar; aynı anda birçok işlemin gerçekleştiği, eş zamanlı (concurrent) etkileşimlerin yoğun olduğu ortamlarda faaliyet göstermektedir.


Bu noktada eş zamanlılık testi, yazılım sistemlerinin birden fazla işlemci, kullanıcı veya thread tarafından aynı anda erişildiğinde nasıl davrandığını değerlendirmeyi amaçlar. Bu testin amacı; yarış durumları (race conditions), kilitlenmeler (deadlocks), veri bozulmaları (data corruption), senkronizasyon problemleri gibi sorunları tespit ederek yazılımın güvenilirliğini ve ölçeklenebilirliğini sağlamaktır.


Eş zamanlılık testi, bir yazılım sisteminin veya uygulamanın, aynı anda birden fazla işlemin veya kullanıcının belirli eylemleri gerçekleştirmesi durumundaki davranışını ölçen performans testi türüdür. Genellikle çok kullanıcı (multi-user) testi olarak da adlandırılır çünkü bu testlerde birçok kullanıcı benzer işlemleri aynı anda yapmaya çalışır.


Bu testler, arka plan görevleri, veritabanı güncellemeleri, aynı anda işlem yapan kullanıcılar, dağıtık sistem bileşenlerinin etkileşimi gibi durumlar göz önünde bulundurularak yürütülür. Özellikle mikro servis mimarilerinde, bulut sistemlerinde, yüksek trafikli e-ticaret platformlarında eş zamanlılık testi büyük öneme sahiptir.

Eş Zamanlılık Testinin Amaçları

Eş zamanlılık testi, yazılım sistemlerinin aynı anda birden fazla işlem, kullanıcı ya da thread tarafından erişilmesi durumunda nasıl tepki verdiğini test eden önemli bir yöntemdir. Bu testin temel amacı, sistemin güvenilirlik, kararlılık, performans ve veri bütünlüğü açısından ne derece dayanıklı olduğunu ölçmektir. Aşağıda eş zamanlılık testinin temel hedefleri alt başlıklar hâlinde detaylandırılmıştır:

Yarış Durumlarının (Race Conditions) Tespiti

Yarış durumu, iki veya daha fazla thread'in aynı veriye aynı anda erişmeye çalıştığı durumlarda ortaya çıkar ve işlem sırası sonuç üzerinde etkili hale gelir. Bu durum, çoğu zaman sistemin beklenmedik davranışlar sergilemesine ya da veri bozulmalarına yol açar. Eş zamanlılık testinin en kritik amaçlarından biri, bu tür eş zamanlı veri çakışmalarını erken aşamada tespit ederek önlemektir.

Deadlock (Kilitlenme) ve Starvation Problemlerini Belirleme

Birden fazla işlemin birbirini bekleyerek sonsuz döngüye girmesi, sistemin tamamen durmasına sebep olan deadlock sorunudur. Benzer şekilde, bazı işlemlerin sürekli kaynak bekleyip işlem alamaması da starvation olarak tanımlanır. Bu problemler genellikle sıradan testlerle ortaya çıkmaz; ancak eş zamanlılık testi sırasında sistemin kaynak erişim stratejileri detaylıca incelendiği için bu tür hatalar daha net biçimde görünür hale gelir.

Veri Bütünlüğünün Sağlandığını Doğrulamak

Çok sayıda kullanıcının aynı veri üzerinde işlem yaptığı sistemlerde, örneğin banka sistemlerinde veya e-ticaret uygulamalarında, verilerin doğru güncellenmesi ve bozulmadan saklanması son derece önemlidir. Eş zamanlılık testi sayesinde sistemin atomik, tutarlı, izole ve dayanıklı (ACID özellikleri) biçimde çalışıp çalışmadığı test edilir.

Kaynak Paylaşımında Senkronizasyonun Doğruluğunu Test Etmek

Birden fazla iş parçacığının aynı anda işlemci, bellek, dosya, socket, kuyruk gibi ortak kaynaklara erişmesi senkronizasyon gerektirir. Eş zamanlılık testi, kilitleme (locking), semaphore ve mutex gibi senkronizasyon araçlarının doğru şekilde çalışıp çalışmadığını ortaya koyar.

Sistem Performansının Eş Zamanlı Yük Altında Değerlendirilmesi

Testin bir diğer amacı, sistemin yüksek eş zamanlı kullanıcı ya da işlem yükü altında nasıl davrandığını anlamaktır. Yanıt sürelerinde artış, kaynak tüketiminde anormallikler veya hata oranlarındaki yükselmeler bu testler sırasında ölçülerek sistemin ölçeklenebilirliği analiz edilir.

Sistem Kararlılığını Sağlamak

Uygulama, belirli sayıda eş zamanlı kullanıcıyı destekliyor olabilir; fakat artan kullanıcı sayısıyla birlikte kararlılığını yitiriyorsa bu ciddi bir sorundur. Eş zamanlılık testleri, sistemin normal koşullarda kararlı çalışıp çalışmadığını, kaynak tüketiminin artışa nasıl tepki verdiğini, sistem çökmesi yaşanıp yaşanmadığını test eder.

Gerçek Kullanıcı Senaryolarını Simüle Etmek

Eş zamanlılık testi, gerçek dünyadaki kullanıcı davranışlarını canlandırarak uygulamanın gerçekçi koşullarda ne derece güvenilir olduğunu anlamaya yardımcı olur. Özellikle kampanya dönemleri, canlı yayın sistemleri, banka işlemleri gibi alanlarda yüzlerce kullanıcının aynı anda işlem yaptığı anlar test edilir.

Ölçekleme ve Altyapı Planlamasına Katkı Sağlamak

Sistem hangi eş zamanlı kullanıcı sayısına kadar sorunsuz çalışıyor? Kritik eşik nedir? Ne zaman ek kaynak (sunucu, iş parçacığı, veri tabanı replikası vb.) gerekecek? Bu soruların yanıtı, doğru yapılmış eş zamanlılık testleri ile elde edilir. Böylece altyapı yatırımları ve sistem planlamaları somut verilere dayalı olarak yapılabilir.

Arka Plan İşlemleri ile Kullanıcı İşlemlerinin Etkileşimini Test Etmek

Birçok sistemde kullanıcı işlemleriyle birlikte arka planda çalışan cron job'lar, batch işlemler ya da senkronizasyon görevleri vardır. Eş zamanlılık testleri sırasında bu görevlerin kullanıcı işlemleriyle nasıl etkileşime girdiği, çakışma veya bekleme oluşturup oluşturmadığı incelenir.

Mikroservis ve Dağıtık Sistemler Arası Senkronizasyonun Değerlendirilmesi

Modern sistemlerin çoğu artık tek bir monolitik yapıdan değil, mikroservisler ve dağıtık servislerden oluşmaktadır. Her bir servisin diğerleriyle eş zamanlı etkileşimi sırasında oluşabilecek veri tutarsızlığı, zamanlama hatası ya da mesaj kuyruğu blokajları gibi sorunlar ancak eş zamanlılık testleriyle ortaya çıkar.


Bu amaçların her biri, yazılımın yalnızca işlevsel olarak değil, aynı zamanda yüksek trafik, eş zamanlı işlem ve karmaşık senkronizasyon koşulları altında da güvenli ve kararlı çalışmasını sağlamak için hayati önemdedir. Bu nedenle eş zamanlılık testleri, yük testleri, stres testleri ve performans analizleri ile entegre şekilde uygulanmalı ve sürekli iyileştirme sürecine dahil edilmelidir.

Eş Zamanlılık Testinin Uygulanma Nedenleri

Eş zamanlılık (concurrency) modern yazılımların vazgeçilmez bir gerçeğidir. Özellikle çok kullanıcılı sistemlerde, yüksek trafikli web uygulamalarında, dağıtık mimarilerde ve mikro servis temelli yapılarda eş zamanlı işlemler kaçınılmazdır. Eş zamanlılık testi, bu gibi sistemlerin doğru, güvenilir ve kararlı biçimde çalışmasını sağlamak için hayati öneme sahiptir. Bu test türünün uygulanmasının nedenleri başlıca aşağıdaki gibidir.

Çok Kullanıcılı Ortamlarda Güvenilirlik Sağlamak

Web siteleri, mobil uygulamalar, e-ticaret platformları veya finansal sistemler gibi uygulamalarda, aynı anda binlerce kullanıcı sisteme erişebilir. Bu kullanıcıların aynı veriye veya aynı işleme eş zamanlı olarak erişmesi durumunda sistemin tutarlı kalması ve çökmeden çalışması gerekir. Eş zamanlılık testi, yazılımın bu tür yükleri güvenle kaldırıp kaldıramayacağını değerlendirir. Örneğin, aynı anda birden fazla kullanıcının aynı ürünü sepetine ekleyip sipariş vermesi, stok kontrolünün nasıl yapıldığını test etmek açısından kritik bir senaryodur.

Yarış Durumu ve Kilitlenme Gibi Kritik Hataların Erken Tespiti

Yarış durumu (race condition), sistemin iki iş parçacığı tarafından aynı anda erişilen bir kaynağa doğru sırayla erişememesiyle oluşur. Bu tür hatalar, zamanlama farklılıkları nedeniyle test ortamında sürekli ortaya çıkmayabilir, ancak üretimde çok ciddi sorunlara yol açabilir. Eş zamanlılık testleri, bu gibi zamanlama hatalarını tekrarlanabilir senaryolarla tespit etmenin en etkili yoludur.

Veri Tutarlılığını ve Bütünlüğünü Sağlamak

Aynı anda birçok işlemin aynı veriyi okuması veya yazması, veri tutarsızlığına neden olabilir. Bu, kullanıcıların yanlış bakiye görmesi, çifte sipariş verilmesi, yanlış hesaplama yapılması gibi ciddi sonuçlara yol açabilir. Eş zamanlılık testi, bu gibi senaryolarda veri tutarlılığı ve güvenilirliğini garanti altına almak için yapılır.

Gerçekçi Trafik Senaryolarını Simüle Etmek

Tek kullanıcıyla yapılan testler, sistemin gerçek dünyadaki davranışlarını yansıtmaz. Eş zamanlılık testi ile sistem, gerçek kullanıcı davranışlarına yakın senaryolar altında denenir. Bu sayede yazılım, canlıya alındığında sürpriz sorunlarla karşılaşmaz.

Performans Sınırlarını ve Darboğazları Belirlemek

Her yazılımın ve altyapının belirli bir kapasitesi vardır. Eş zamanlı testler sayesinde sistemin kaç eş zamanlı kullanıcıya kadar verimli çalıştığı, hangi noktada yanıt süresinin arttığı ya da sistemin çöktüğü gözlemlenir. Bu bilgiler, ölçeklenebilirlik analizlerinde, altyapı planlamalarında ve yük dengeleme çözümlerinin belirlenmesinde kritik rol oynar.

Arka Plan İşlemleri ile Kullanıcı İşlemleri Arasındaki Etkileşimi Test Etmek

Modern yazılımlar çoğu zaman arka plan görevleri (örneğin cron job’lar, veri senkronizasyon işlemleri) yürütürken ön planda kullanıcı etkileşimlerini de sürdürmek zorundadır. Bu iki işlem türü çakıştığında hatalar meydana gelebilir. Eş zamanlılık testi, arka plan görevlerinin kullanıcı deneyimini olumsuz etkileyip etkilemediğini kontrol etme imkânı sunar.

Dağıtık Sistemlerde Eş Zamanlı Etkileşimleri Değerlendirmek

Mikro servisler, API ağları ve mesajlaşma kuyrukları gibi yapılar içeren sistemlerde, bileşenler eş zamanlı biçimde çalışır. Servisler arası haberleşmede yaşanabilecek gecikmeler, veri senkronizasyon sorunları veya kaynak yarışları ancak eş zamanlılık testi ile görünür hâle gelir. Bu nedenle bu tür mimarilerde, eş zamanlılık testleri entegrasyon testi kadar kritik hale gelmiştir.

Kod ve Mimari Optimizasyonu için Geri Bildirim Sağlamak

Eş zamanlılık testinden elde edilen sonuçlar, geliştiricilere sistemin hangi noktalarında optimizasyona ihtiyaç olduğunu açıkça gösterir. Kodda iyileştirme gereken bölümler, senkronizasyon hataları, sorgu performansı sorunları bu testler sırasında ortaya çıkar. Bu da sistem genelinde kalite artışı ve teknik borcun azaltılması anlamına gelir.

Önleyici Bakım Stratejilerine Katkı Sunmak

Yazılım sistemlerinde reaktif olmak yerine proaktif yaklaşım tercih edilmelidir. Eş zamanlılık testleri, sistemde oluşabilecek performans sorunlarını ve çökme risklerini önceden fark ederek, bunlara yönelik bakım stratejilerinin geliştirilmesini sağlar.

Maliyetleri ve Sonradan Ortaya Çıkabilecek Sorunları Azaltmak

Yayına alındıktan sonra karşılaşılan eş zamanlılık problemleri; kullanıcı memnuniyetsizliği, veri kaybı, sistem çökmesi, prestij ve gelir kaybı gibi yüksek maliyetli sonuçlar doğurabilir. Eş zamanlılık testinin yazılım geliştirme sürecine erken entegre edilmesi, bu maliyetlerin önemli ölçüde önlenmesini sağlar.

SLA ve Uyum Gereksinimlerini Karşılamak

Birçok sistemde servis seviyesi anlaşmaları (SLA) veya düzenleyici kurumların performans gereksinimleri vardır. Eş zamanlılık testleri ile sistemin bu kriterleri sağlayıp sağlamadığı ölçülür.

Eş Zamanlılık Testinde Karşılaşılan Zorluklar

Eş zamanlılık testi, yazılım kalitesini artırmak açısından kritik bir yere sahip olsa da uygulanması son derece karmaşık ve zahmetlidir. Bu test türünde karşılaşılan başlıca zorluklar şunlardır:


  • Zamanlama ile İlgili Sorunların Tespiti Zordur: Eş zamanlılık hataları genellikle zamanlama temelli ve düzensizdir. Aynı test senaryosu her çalıştırıldığında aynı sonuçları vermeyebilir. Bu da hataların tekrarlanabilirliğini düşürür.
  • Test Senaryosu Üretmek Karmaşıktır: Gerçekçi eş zamanlı senaryoların modellenmesi, özellikle kullanıcı etkileşimlerinin yoğun olduğu sistemlerde zorlaşır. Testlerin farklı senaryoları kapsaması için geniş bir varyasyon gerekir.
  • Donanım ve Ortam Kısıtlamaları: Eş zamanlılığı test etmek için genellikle yüksek sayıda paralel işlem ya da kullanıcı simülasyonu gerekir. Bu da daha güçlü test altyapısı, çok çekirdekli işlemciler veya bulut ortamları gerektirir.
  • Senaryo Çakışmaları ve Test Verisi Problemleri: Aynı test verisine eş zamanlı erişim, test sonuçlarının doğruluğunu etkileyebilir. Uygun veri izolasyonu ve çevresel senkronizasyon sağlanmadığında testler birbiriyle çakışabilir.
  • Kod ve Hataların Analizi Zordur: Ortaya çıkan hatalar loglara yansımayabilir. Örneğin, bir deadlock ya da yarış durumu sadece belirli zaman dilimlerinde, belirli thread’lerde ortaya çıkar ve doğrudan görünmez. Bu durum, hata ayıklamayı ve kök neden analizini zorlaştırır.

Eş Zamanlılık Testi Uygulama Adımları

Eş zamanlılık testinin başarılı olabilmesi için belirli adımları sistemli bir şekilde izlemek gerekir. Bu süreç, hem manuel hem de otomasyon destekli test planlaması açısından önem taşır.


  1. Adım - Test Kapsamının Belirlenmesi: Test edilecek eş zamanlı işlem noktaları belirlenir: örneğin, veritabanı yazma işlemleri, oturum yönetimi, stok güncelleme, kayıt oluşturma.
  2. Adım - Performans ve Tutarlılık Kriterlerinin Tanımlanması: Yanıt süresi, işlem başına düşen kaynak kullanımı, hata oranı gibi metrikler ölçüm kriteri olarak tanımlanır.
  3. Adım - Test Ortamının Hazırlanması: Testler mümkünse üretim ortamına benzer koşullarda yapılmalıdır. Aynı donanım konfigürasyonu, aynı veri seti ve kullanıcı profili tercih edilir.
  4. Adım - Test Senaryolarının Yazılması: Kritik yollar ve eş zamanlı davranışları tetikleyecek test senaryoları hazırlanır. Aynı veriye eş zamanlı erişim, işlem çakışması, kaynak kilidi gibi senaryolar özellikle çalıştırılır.
  5. Adım - Test Araçlarının Seçilmesi ve Kurulumu: Eş zamanlılık testi araçlarından uygun olanı seçilerek yapılandırılır.
  6. Adım - Testin Artan Yük ile Çalıştırılması: Kademeli olarak eş zamanlı kullanıcı sayısı artırılır. Sistem yanıtları, hata oranları ve performans düşüşleri gözlemlenir.
  7. Adım - Sonuçların Analizi ve Raporlama: Toplanan veriler analiz edilerek performans darboğazları, senkronizasyon sorunları, veri bozulmaları tespit edilir. İlgili geliştirici ekiplerle paylaşılır.

Eş Zamanlılık Testi Yöntemleri

  • Bulanıklık Testi (Fuzz Testing): Rastgele, beklenmeyen veya geçersiz verilerin sisteme gönderilerek sistemin bu veriler karşısındaki davranışı gözlemlenir. Eş zamanlı veri paylaşımı olan sistemlerde özellikle etkilidir.
  • Rastgele Test (Random Testing): Çeşitli kullanıcı senaryoları rastgele sırayla eş zamanlı çalıştırılır. Bu sayede zamanlama-tabanlı hatalar ve senkronizasyon problemleri ortaya çıkartılır.
  • Kod İnceleme (Code Review): Geliştiriciler, çoklu iş parçacığı kullanan kod bölümlerini detaylı biçimde gözden geçirir. Bu yöntem özellikle lock, mutex, semaphore gibi yapılar içeren kodlar için etkilidir.
  • Statik Analiz: Kod çalıştırılmadan önce analiz edilir. Statik analiz araçları, potansiyel yarış durumu, kilitlenme riski, uygunsuz thread erişimleri gibi sorunları önceden tespit eder.

Eş Zamanlılık Testinin Avantajları

  • Kritik hata tiplerini (race condition, deadlock) erkenden tespit etme imkânı sunar.
  • Gerçek kullanıcı davranışlarıyla uyumlu senaryoları test ederek kullanıcı deneyimini güçlendirir.
  • Performans darboğazlarını önceden ortaya çıkartarak sistemin ölçeklenebilirliğini artırır.
  • Kaynak yönetimini optimize eder, sistem altyapısının doğru kullanıldığını garanti eder.
  • Geliştirici ve test ekipleri için erken geri bildirim sağlayarak maliyetli hata düzeltmelerini azaltır.
  • Servis seviyesi anlaşmalarının (SLA) karşılanmasını kolaylaştırır.
  • Otomasyon ile entegre edilerek CI/CD süreçlerine dahil edilebilir.

Eş Zamanlılık Testinin Dezavantajları

  • Yüksek düzeyde altyapı, donanım ve ağ kaynaklarına ihtiyaç duyar.
  • Test senaryolarının doğru yazılması ve yönetilmesi uzmanlık ister.
  • Hataların tespiti ve tekrarlanabilirliği genellikle düşüktür.
  • Testler arası veri çakışmaları ve ortam karışıklıkları sıkça görülür.
  • Bireysel test senaryoları gözden kaçabilir, ayrıntılı gözlem zorlaşır.
  • Kod karmaşıklığına bağlı olarak analiz süresi uzar.
  • Yanıltıcı pozitif/negatif sonuçlara yol açabilecek etkileşimler yaşanabilir.

Gerçek Dünya Senaryoları

  • E-Ticaret Kampanya Yoğunluğu: Black Friday veya benzeri kampanya dönemlerinde binlerce kullanıcı aynı anda sepete ürün ekler ve ödeme yapar. Aynı stok, aynı kullanıcı oturumu veya kupon kodu eş zamanlı erişimle test edilir.
  • Banka İşlemleri: Bir kullanıcı para transferi yaparken başka bir kullanıcı bakiye sorgulaması yapıyor olabilir. Bu tür eş zamanlı işlemler veri tutarlılığı açısından test edilmelidir.
  • Üniversite Kayıt Sistemleri: Kısıtlı kontenjanlı dersler için çok sayıda öğrencinin aynı anda başvuru yapması senaryosunda kilitlenme ve çifte kayıt gibi sorunlar ortaya çıkabilir.
  • Uçuş Rezervasyonları: Son kalan koltuk için eş zamanlı yapılan rezervasyonlar, sistemin en son geçerli başvuruyu işleyip işlemediğini kontrol etmek için test edilir.
  • Mikroservis Mimarisi İçin API Testleri: Farklı servislerin aynı veri kümesine aynı anda yazma işlemi gerçekleştirdiği durumlarda oluşabilecek veri bozulmaları ve mesaj kuyruğu sorunları test edilir.

Kaynakça

Souza, Simone RS, Maria AS Brito, Rodolfo A. Silva, Paulo SL Souza, and Ed Zaluska. "Research in concurrent software testing: a systematic review." In Proceedings of the workshop on parallel and distributed systems: Testing, analysis, and debugging, pp. 1-5. 2011. Erişim Adresi.

Tai, Kuo-Chung. "Testing of concurrent software." In [1989] Proceedings of the Thirteenth Annual International Computer Software & Applications Conference, pp. 62-64. IEEE, 1989. Erişim Adresi.

Geeksforgeeks. "What is Concurrency Testing in Software Testing?". (2024). Erişim Tarihi: 2 Temmuz 2025. Erişim Adresi.

Bianchi, Francesco Adalberto, Alessandro Margara, and Mauro Pezzè. "A survey of recent trends in testing concurrent software systems." IEEE Transactions on Software Engineering 44, no. 8 (2017): 747-783. Erişim Adresi.

Melo, Silvana M., Simone RS Souza, Rodolfo A. Silva, and Paulo SL Souza. "Concurrent software testing in practice: a catalog of tools." In Proceedings of the 6th International Workshop on Automating Test Case Design, Selection and Evaluation, pp. 31-40. 2015. Erişim Adresi.

Ayrıca Bakınız

Yazarın Önerileri

Yazılım Testi: Kalite Güvencesinin Temel Taşı
Kabul Testi (Acceptance Testing)

Kabul Testi (Acceptance Testing)

Bilişim Ve İletişim Teknolojileri +1
Erişilebilirlik Testi (Accessibility Testing)

Erişilebilirlik Testi (Accessibility Testing)

Bilişim Ve İletişim Teknolojileri +1
Kurgusuz Test (Ad Hoc Testing)

Kurgusuz Test (Ad Hoc Testing)

Bilişim Ve İletişim Teknolojileri +1
Alfa Testi (Alpha Testing)

Alfa Testi (Alpha Testing)

Bilişim Ve İletişim Teknolojileri +1
A/B Testi (A/B Testing)

A/B Testi (A/B Testing)

Bilişim Ve İletişim Teknolojileri +1
Siyah Kutu Testi (Black Box Testing)Si

Siyah Kutu Testi (Black Box Testing)

Bilişim Ve İletişim Teknolojileri +1
Uyumluluk Testi (Compatibility Testing)

Uyumluluk Testi (Compatibility Testing)

Bilişim Ve İletişim Teknolojileri +1
Sürekli Entegrasyon Testi (Continuous Integration Testing)

Sürekli Entegrasyon Testi (Continuous Integration Testing)

Bilişim Ve İletişim Teknolojileri +1
Uygunluk Testi (Conformance Testing)

Uygunluk Testi (Conformance Testing)

Bilişim Ve İletişim Teknolojileri +1
Uçtan Uca Test (End-to-End Testing)

Uçtan Uca Test (End-to-End Testing)

Bilişim Ve İletişim Teknolojileri +1
Dumansal Test (Smoke Testing)Du

Dumansal Test (Smoke Testing)

Bilişim Ve İletişim Teknolojileri +1

Sen de Değerlendir!

0 Değerlendirme

Yazar Bilgileri

Avatar
Ana YazarBeyza Nur Türkü2 Temmuz 2025 16:32
KÜRE'ye Sor