Files
everything-claude-code/docs/tr/commands/test-coverage.md
Berkcan Gümüşışık fd2a8edb53 Add Turkish (tr) docs and update README (#744)
* Add Turkish (tr) docs and update README

Add a full set of Turkish documentation under docs/tr (agents, changelog, CLAUDE guide, contributing, code of conduct, and many agents/commands/skills/rules files). Update README to include a link to the Turkish docs and increment the supported language count from 5 to 6. This commit adds localized guidance and references to help Turkish-speaking contributors and users.

* Update docs/tr/TROUBLESHOOTING.md

Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com>

* Update docs/tr/README.md

Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com>

* docs(tr): fix license link and update readmes

Update Turkish docs: change license badge link to point to repository root (../../LICENSE), increment displayed language count from 5 to 6, and remove two outdated related links from docs/tr/examples/README.md to keep references accurate.

* Update docs/tr/commands/instinct-import.md

Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com>

* Update docs/tr/commands/checkpoint.md

Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com>

---------

Co-authored-by: cubic-dev-ai[bot] <191113872+cubic-dev-ai[bot]@users.noreply.github.com>
2026-03-22 15:37:04 -07:00

70 lines
2.9 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
# Test Coverage
Test coverage'ını analiz et, eksiklikleri tanımla ve 80%+ coverage'a ulaşmak için eksik test'leri oluştur.
## Adım 1: Test Framework'ünü Tespit Et
| Gösterge | Coverage Komutu |
|-----------|-----------------|
| `jest.config.*` veya `package.json` jest | `npx jest --coverage --coverageReporters=json-summary` |
| `vitest.config.*` | `npx vitest run --coverage` |
| `pytest.ini` / `pyproject.toml` pytest | `pytest --cov=src --cov-report=json` |
| `Cargo.toml` | `cargo llvm-cov --json` |
| `pom.xml` JaCoCo ile | `mvn test jacoco:report` |
| `go.mod` | `go test -coverprofile=coverage.out ./...` |
## Adım 2: Coverage Raporunu Analiz Et
1. Coverage komutunu çalıştır
2. Çıktıyı ayrıştır (JSON summary veya terminal çıktısı)
3. **80% coverage'ın altındaki** dosyaları listele, en kötüden başlayarak sırala
4. Her yetersiz coverage'lı dosya için şunları tanımla:
- Test edilmemiş fonksiyonlar veya metodlar
- Eksik branch coverage (if/else, switch, error yolları)
- Payda'yı şişiren dead code
## Adım 3: Eksik Test'leri Oluştur
Her yetersiz coverage'lı dosya için, bu önceliği takip ederek test'ler oluştur:
1. **Happy path** — Geçerli input'larla temel fonksiyonalite
2. **Hata işleme** — Geçersiz input'lar, eksik veri, network hataları
3. **Edge case'ler** — Boş diziler, null/undefined, sınır değerleri (0, -1, MAX_INT)
4. **Branch coverage** — Her if/else, switch case, ternary
### Test Oluşturma Kuralları
- Test'leri kaynak kodun yanına yerleştir: `foo.ts``foo.test.ts` (veya proje konvansiyonu)
- Projeden mevcut test pattern'lerini kullan (import stili, assertion kütüphanesi, mocking yaklaşımı)
- Harici bağımlılıkları mock'la (veritabanı, API'ler, dosya sistemi)
- Her test bağımsız olmalı — test'ler arasında paylaşılan değişken state olmamalı
- Test'leri açıklayıcı isimlendirin: `test_create_user_with_duplicate_email_returns_409`
## Adım 4: Doğrula
1. Tam test suite'ini çalıştır — tüm test'ler geçmeli
2. Coverage'ı yeniden çalıştır — iyileşmeyi doğrula
3. Hala 80%'in altındaysa, kalan boşluklar için Adım 3'ü tekrarla
## Adım 5: Raporla
Öncesi/sonrası karşılaştırmasını göster:
```
Coverage Report
──────────────────────────────
File Before After
src/services/auth.ts 45% 88%
src/utils/validation.ts 32% 82%
──────────────────────────────
Overall: 67% 84% ✅
```
## Odak Alanları
- Karmaşık branching'e sahip fonksiyonlar (yüksek cyclomatic complexity)
- Hata işleyiciler ve catch blokları
- Codebase genelinde kullanılan utility fonksiyonları
- API endpoint handler'ları (request → response akışı)
- Edge case'ler: null, undefined, empty string, empty array, zero, negatif sayılar