Neler yeni

Yazılım Forum

Tüm özelliklerimize erişmek için şimdi bize katılın. Kayıt olduktan ve giriş yaptıktan sonra konu oluşturabilecek, mevcut konulara yanıt gönderebilecek, itibar kazanabilecek, özel mesajlaşmaya erişebilecek ve çok daha fazlasını yapabileceksiniz! Bu hizmetlerimiz ise tamamen ücretsiz ve kurallara uyulduğu sürece sınırsızdır, o zaman ne bekliyorsunuz? Hadi, sizde aramıza katılın!

Jest ile JavaScript Uygulamalarınızı Güvenle Test Edin: Kapsamlı Bir Rehber

Jest ile JavaScript Uygulamalarınızı Güvenle Test Edin: Kapsamlı Bir Rehber

Modern JavaScript geliştirme süreçlerinde kod kalitesini ve güvenilirliğini sağlamak, uygulamanın uzun ömürlülüğü ve sürdürülebilirliği açısından kritik bir öneme sahiptir. Hızla değişen kütüphane ve çerçeveler dünyasında, geliştiricilerin kodlarını olası hatalara karşı güvence altına alması kaçınılmazdır. İşte bu noktada JavaScript test çatısı Jest devreye giriyor. Facebook tarafından geliştirilen Jest, developer experience (geliştirici deneyimi) odaklı, hızlı ve özellik açısından zengin bir test aracıdır. Bu rehberde, Jest'in temelden ileri seviyeye nasıl kullanılacağını, test yazma pratiklerini ve uygulamanıza nasıl entegre edebileceğinizi ayrıntılı bir şekilde inceleyeceğiz.

Neden Jest Kullanmalıyız?

Jest, birçok test aracından sıyrılan özelliklere sahiptir. Öncelikle, zero-configuration (sıfır yapılandırma) yaklaşımı sayesinde kutudan çıkar çıkmaz çoğu JavaScript projesinde kolayca çalışabilir. Entegre test çalıştırıcısı, assertion kütüphanesi ve mocking yetenekleri sayesinde ek paketlere ihtiyaç duymadan kapsamlı testler yazabilirsiniz. Ayrıca, anlık geri bildirim sağlayan watch mode özelliği, kodunuzda yaptığınız değişiklikleri anında test edip sonuçları görmenizi sağlar. Bu da geliştirme hızınızı artırır ve hataları erken aşamada tespit etmenize yardımcı olur.

Jest Kurulumu ve İlk Testiniz

Jest'i projenize dahil etmek oldukça basittir. Genellikle, npm veya yarn kullanarak projenize bir geliştirme bağımlılığı olarak eklersiniz.

Kod:
npm install --save-dev jest
# veya
yarn add --dev jest

Kurulum tamamlandıktan sonra, `package.json` dosyanıza basit bir `test` komutu ekleyebilirsiniz:

Kod:
{
  "name": "my-js-app",
  "version": "1.0.0",
  "scripts": {
    "test": "jest"
  }
}

Artık `npm test` veya `yarn test` komutunu çalıştırdığınızda Jest testlerinizi aramaya başlayacaktır. Jest, varsayılan olarak `__tests__` klasöründeki dosyaları, `.test.js`, `.spec.js` uzantılı dosyaları ve `.js` uzantılı dosyaları arar, ancak bu davranış yapılandırılabilir.

Basit Bir Fonksiyonu Test Etmek

Jest'in temelini oluşturan `describe`, `test` (veya `it`) ve `expect` global fonksiyonlarını kullanarak basit bir toplama fonksiyonunu test edelim.

Önce, `sum.js` adında bir dosya oluşturalım:

Kod:
// sum.js
function sum(a, b) {
  return a + b;
}
module.exports = sum;

Şimdi de `sum.test.js` adında bir test dosyası oluşturalım:

Kod:
// sum.test.js
const sum = require('./sum');

describe('sum fonksiyonu', () => {
  test('iki sayıyı doğru bir şekilde toplamalı', () => {
    expect(sum(1, 2)).toBe(3);
  });

  test('negatif sayılarla da doğru sonuç vermeli', () => {
    expect(sum(-1, -2)).toBe(-3);
  });

  test('sıfır ile toplandığında sayının kendisini vermeli', () => {
    expect(sum(5, 0)).toBe(5);
  });
});

Bu örnekte:
* `describe('sum fonksiyonu', () => { ... });` bloğu, ilgili testlerin bir grubunu tanımlamak için kullanılır. Bu, testlerinizi organize etmenizi sağlar.
* `test('iki sayıyı doğru bir şekilde toplamalı', () => { ... });` veya `it()` fonksiyonu, tek bir test senaryosunu tanımlar. Açıklayıcı bir isim vermek önemlidir.
* `expect(sum(1, 2))` ifadesi, test etmek istediğimiz değeri veya sonucu Jest'e bildirir.
* `.toBe(3)` ise bir "matcher"dır. `expect` ile verilen değerin belirli bir koşulu sağlayıp sağlamadığını kontrol eder. Jest zengin bir matcher kütüphanesine sahiptir: `toEqual`, `not.toBe`, `toContain`, `toHaveBeenCalled` gibi birçok seçenek mevcuttur.

Asenkron Kod Testleri

JavaScript uygulamalarının büyük bir çoğunluğu asenkron işlemler (API çağrıları, zamanlayıcılar vb.) içerir. Jest, bu tür kodları test etmek için çeşitli yöntemler sunar. En yaygın olanları `done` callback'i, Promise'ler ve `async/await` kullanımıdır. Modern JavaScript'te `async/await` en okunaklı ve tercih edilen yöntemdir.

Örnek bir asenkron fonksiyonumuz olsun:

Kod:
// fetchData.js
function fetchData() {
  return new Promise(resolve => {
    setTimeout(() => {
      resolve('veriler alındı');
    }, 100);
  });
}
module.exports = fetchData;

Bu fonksiyonu `async/await` ile test edelim:

Kod:
// fetchData.test.js
const fetchData = require('./fetchData');

describe('fetchData asenkron fonksiyonu', () => {
  test('verileri başarıyla almalı', async () => {
    const data = await fetchData();
    expect(data).toBe('veriler alındı');
  });

  test('başarısız bir durumda hata fırlatmalı (varsayımsal)', async () => {
    // fetchData() fonksiyonunu bir hata fırlatacak şekilde yeniden düzenlediğimizi varsayalım
    // Örneğin, reject() ile bir Promise döndürmesi gibi
    // expect(async () => await fetchDataThatRejects()).rejects.toThrow('Hata!');
    // Bu örnek için basitçe mocklanmış bir hata senaryosu düşünelim.
    const mockFetchDataWithError = () => Promise.reject(new Error('Ağ Hatası'));
    await expect(mockFetchDataWithError()).rejects.toThrow('Ağ Hatası');
  });
});

Mocking ile Bağımlılıkları Yönetme

Birim testlerinin temel prensiplerinden biri, test edilen birimin izole olmasıdır. Yani, bir fonksiyonu veya bileşeni test ederken, onun dış bağımlılıklarının (veritabanı, ağ çağrıları, harici servisler) gerçek implementasyonları yerine sahte (mock) implementasyonlar kullanırız. Jest, bu konuda güçlü mocking yetenekleri sunar. `jest.fn()` ve `jest.mock()` en sık kullanılan araçlardır.

jest.fn() Kullanımı:

`jest.fn()` basit bir sahte fonksiyon oluşturur. Bu fonksiyonun çağrılıp çağrılmadığını, kaç kez çağrıldığını, hangi argümanlarla çağrıldığını ve ne döndürdüğünü kontrol edebiliriz.

Kod:
// utils.js
function greet(name) {
  return `Merhaba, ${name}!`;
}
module.exports = { greet };

Kod:
// app.js (greet fonksiyonunu kullanan bir başka dosya)
const { greet } = require('./utils');

function sayHelloToUser(user) {
  return greet(user.name);
}
module.exports = sayHelloToUser;

Şimdi `sayHelloToUser` fonksiyonunu test ederken `greet` fonksiyonunu mocklayalım:

Kod:
// app.test.js
const sayHelloToUser = require('./app');
const utils = require('./utils'); // Orijinal modülü çekiyoruz

jest.mock('./utils', () => ({
  greet: jest.fn((name) => `Mocked Merhaba, ${name}!`)
}));

describe('sayHelloToUser fonksiyonu', () => {
  test('utils.greet fonksiyonunu doğru argümanlarla çağırmalı', () => {
    const user = { name: 'Ayşe' };
    sayHelloToUser(user);
    expect(utils.greet).toHaveBeenCalledWith('Ayşe');
  });

  test('doğru bir mesaj döndürmeli', () => {
    const user = { name: 'Mehmet' };
    const result = sayHelloToUser(user);
    expect(result).toBe('Mocked Merhaba, Mehmet!');
  });
});

Yukarıdaki örnekte `jest.mock('./utils', ...)` ile `utils` modülünün `greet` fonksiyonunu sahte bir versiyonuyla değiştirdik. Böylece `sayHelloToUser` fonksiyonunu test ederken `greet` fonksiyonunun gerçek implementasyonuna bağımlı kalmadık.

Snapshot Testing

Snapshot testleri, kullanıcı arayüzlerinin (UI) veya seri hale getirilebilir herhangi bir değerin zamanla değişmediğinden emin olmak için kullanılır. İlk çalıştırmada, test edilen bileşenin veya değerin bir "snapshot"ını alır ve diske kaydeder. Sonraki test çalıştırmalarında, mevcut çıktı kaydedilen snapshot ile karşılaştırılır. Eğer iki çıktı uyuşmazsa, Jest bir hata verir ve bu kasıtlı bir değişiklik mi yoksa bir hata mı olduğunu size sorar.

Örneğin, bir React bileşeninin çıktısını test edebiliriz (Jest, React ile birlikte sıkça kullanılır, ancak genel bir JSON çıktısı için de geçerlidir):

Kod:
// userProfile.js
const userProfile = (user) => ({
  id: user.id,
  fullName: `${user.firstName} ${user.lastName}`,
  email: user.email,
  createdAt: new Date('2023-01-01T10:00:00Z').toISOString()
});
module.exports = userProfile;

Kod:
// userProfile.test.js
const userProfile = require('./userProfile');

describe('userProfile fonksiyonu', () => {
  test('kullanıcı profili nesnesi doğru bir şekilde oluşturulmalı', () => {
    const user = {
      id: 1,
      firstName: 'Can',
      lastName: 'Yılmaz',
      email: 'can.yilmaz@example.com'
    };
    const profile = userProfile(user);
    expect(profile).toMatchSnapshot();
  });
});

Bu testi ilk kez çalıştırdığınızda, Jest `__snapshots__` dizininde `userProfile.test.js.snap` adında bir dosya oluşturacak ve içine `profile` nesnesinin seri hale getirilmiş halini kaydedecektir.

Kod:
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`userProfile fonksiyonu kullanıcı profili nesnesi doğru bir şekilde oluşturulmalı 1`] = `
Object {
  "createdAt": "2023-01-01T10:00:00.000Z",
  "email": "can.yilmaz@example.com",
  "fullName": "Can Yılmaz",
  "id": 1,
}
`;

Sonraki çalıştırmalarda, `profile` nesnesinde herhangi bir değişiklik olursa test başarısız olacaktır. Eğer değişiklik kasıtlıysa, `jest -u` komutuyla snapshot'ı güncelleyebilirsiniz.

Test Yapısı ve En İyi Uygulamalar

Etkili ve sürdürülebilir testler yazmak için belirli prensiplere uymak önemlidir:

  • Küçük ve Odaklanmış Testler: Her testin sadece tek bir şeyi test etmesi, hatanın kaynağını bulmayı kolaylaştırır.
  • Açıklayıcı Test İsimleri: Test isimleri, neyin test edildiğini ve hangi senaryoda başarılı veya başarısız olduğunu net bir şekilde belirtmelidir. Örneğin: `test('toplama fonksiyonu pozitif sayıları doğru toplamalı', ...)`
  • Arrange-Act-Assert (AAA) Prensibi:
    * Arrange (Hazırlık): Test için gerekli verileri ve ortamı hazırlayın.
    * Act (Eylem): Test ettiğiniz kodu çalıştırın.
    * Assert (Doğrulama): Sonucun beklenen gibi olduğunu doğrulayın.
  • Bağımsız Testler: Testler birbirine bağımlı olmamalıdır. Bir testin sonucu diğerini etkilememelidir. `beforeEach` ve `afterEach` gibi Jest hook'ları bu konuda yardımcı olabilir.
  • Gerçekçi Olmayan Mock Kullanımından Kaçının: Mock'lar güçlüdür ancak aşırıya kaçmak, testlerinizin gerçek implementasyondan uzaklaşmasına neden olabilir. Yalnızca gerekli gördüğünüz bağımlılıkları mock'layın.
  • Kapsam Raporları: Jest, kod kapsamı (code coverage) raporları oluşturabilir (`jest --coverage`). Bu raporlar, kodunuzun ne kadarının testler tarafından kapsandığını gösterir ve test eksikliklerini belirlemenize yardımcı olur. Ancak %100 kapsama körü körüne ulaşmaya çalışmak yerine, kritik iş mantıklarını kapsadığınızdan emin olun.

Test Dosyalarını Organize Etme:

Test dosyalarınızı genellikle iki şekilde organize edebilirsiniz:
1. `__tests__` dizini içinde: Tüm test dosyalarınızı projenizin kök dizininde veya ilgili modüllerin içinde ayrı bir `__tests__` dizininde tutabilirsiniz.
2. İlgili kod dosyasıyla birlikte: Her bir kod dosyasının yanında, aynı isimde `.test.js` veya `.spec.js` uzantısıyla test dosyasını tutabilirsiniz (örneğin, `myModule.js` için `myModule.test.js`).

Her iki yaklaşımın da avantajları ve dezavantajları vardır, projenizin büyüklüğüne ve takımınızın tercihine göre birini seçebilirsiniz.

Daha İleri Konular ve CI/CD Entegrasyonu

Jest'in sunduğu diğer güçlü özellikler arasında zamanlayıcıların mocklanması (`jest.useFakeTimers()`), global yapılandırma (`jest.config.js`) ve özel match'erler oluşturma bulunur. Büyük projelerde, Jest testlerinizi sürekli entegrasyon (CI) ve sürekli dağıtım (CD) süreçlerinize entegre etmek hayati önem taşır. GitHub Actions, GitLab CI/CD, Jenkins gibi araçlarla Jest testlerinizi otomatik olarak çalıştırarak, her kod değişikliğinde testlerin geçtiğinden emin olabilirsiniz. Bu, hataların üretim ortamına ulaşmasını engeller ve genel yazılım kalitesini artırır.

"Testler, kodunuzun beklendiği gibi çalıştığının kanıtıdır ve gelecekteki değişikliklerin mevcut işlevselliği bozmayacağının güvencesidir."

Bu söz, testlerin sadece hata bulmakla kalmayıp aynı zamanda bir tür "canlı dokümantasyon" görevi gördüğünü ve kod refaktörü sırasında bir güvenlik ağı sağladığını vurgular.

Kaynaklar

Jest hakkında daha fazla bilgi edinmek ve en güncel dökümantasyona ulaşmak için resmi web sitesini ziyaret edebilirsiniz: Jest Resmi Dokümantasyonu. Ayrıca, topluluk forumları ve çeşitli online kurslar da Jest becerilerinizi geliştirmeniz için harika kaynaklardır.

Sonuç

Jest, JavaScript ekosistemindeki en popüler ve güçlü test araçlarından biridir. Kolay kurulumu, zengin özellik seti ve geliştirici dostu arayüzü sayesinde, hem küçük projelerde hem de büyük ölçekli uygulamalarda etkili bir şekilde kullanılabilir. Kodunuza Jest testleri ekleyerek, uygulamanızın kalitesini artırabilir, hataları azaltabilir ve geliştirme sürecinizi daha güvenli ve keyifli hale getirebilirsiniz. Unutmayın, iyi yazılmış testler, zamanla size çok daha fazlasını geri kazandıracaktır. Test etmeye bugün başlayın ve kodunuzun geleceğini güvence altına alın!
 
shape1
shape2
shape3
shape4
shape5
shape6
Üst

Bu web sitenin performansı Hazal Host tarafından sağlanmaktadır.

YazilimForum.com.tr internet sitesi, 5651 sayılı Kanun’un 2. maddesinin 1. fıkrasının (m) bendi ve aynı Kanun’un 5. maddesi kapsamında Yer Sağlayıcı konumundadır. Sitede yer alan içerikler ön onay olmaksızın tamamen kullanıcılar tarafından oluşturulmaktadır.

YazilimForum.com.tr, kullanıcılar tarafından paylaşılan içeriklerin doğruluğunu, güncelliğini veya hukuka uygunluğunu garanti etmez ve içeriklerin kontrolü veya araştırılması ile yükümlü değildir. Kullanıcılar, paylaştıkları içeriklerden tamamen kendileri sorumludur.

Hukuka aykırı içerikleri fark ettiğinizde lütfen bize bildirin: lydexcoding@gmail.com

Sitemiz, kullanıcıların paylaştığı içerik ve bilgileri 6698 sayılı KVKK kapsamında işlemektedir. Kullanıcılar, kişisel verileriyle ilgili haklarını KVKK Politikası sayfasından inceleyebilir.

Sitede yer alan reklamlar veya üçüncü taraf bağlantılar için YazilimForum.com.tr herhangi bir sorumluluk kabul etmez.

Sitemizi kullanarak Forum Kuralları’nı kabul etmiş sayılırsınız.

DMCA.com Protection Status Copyrighted.com Registered & Protected