[typescript] 타입스크립트 단위 테스트 작성 시 테스트 반복과 리팩토링 사이클

단위 테스트는 소프트웨어 개발 과정에서 매우 중요한 부분입니다. 테스트 코드를 작성하고 실행하는 반복적인 과정을 통해 안정적이고 견고한 소프트웨어를 만들 수 있습니다. 이번 글에서는 타입스크립트로 단위 테스트를 작성하고, 테스트 코드를 계속해서 리팩토링하는 과정에 대해 살펴보겠습니다.

테스트 코드 작성

먼저, 타입스크립트로 테스트할 코드에 대한 단위 테스트 코드를 작성해야 합니다. Jest나 Mocha와 같은 테스트 프레임워크를 사용하여 간단하게 테스트 코드를 작성할 수 있습니다.

// example.spec.ts
import { sum } from './example';

describe('sum function', () => {
  test('adds 1 + 2 to equal 3', () => {
    expect(sum(1, 2)).toBe(3);
  });

  test('adds 0 + 0 to equal 0', () => {
    expect(sum(0, 0)).toBe(0);
  });
});

위의 예시는 sum 함수에 대한 단위 테스트 코드입니다. 이제 이 테스트 코드를 실행하여 기능이 제대로 동작하는지 확인합니다.

테스트 실행 및 실패 확인

테스트 코드를 실행하여 테스트가 실패하는지 확인합니다. 실패하는 테스트를 수정하여 성공하도록 코드를 수정하는 과정을 반복합니다. 이를 통해 코드의 품질을 향상시킬 수 있습니다.

코드 리팩토링

테스트가 통과하는 코드를 얻었다면, 리팩토링을 진행합니다. 코드를 보다 간결하고 유지보수가 쉬운 형태로 개선하는 작업을 리팩토링이라고 합니다. 테스트 코드를 계속 실행하면서 리팩토링한 코드가 여전히 기능을 제대로 수행하는지 확인하고, 문제가 없다면 안전하게 변경된 코드를 적용할 수 있습니다.

결론

단위 테스트 작성, 실행, 실패 확인, 코드 리팩토링과정을 반복하면서 안정적이고 견고한 소프트웨어를 만들 수 있습니다. 이러한 단계를 여러 차례 반복하면서 프로젝트 전체적으로 코드의 품질을 향상시킬 수 있습니다.

위에서 제시된 예시 코드는 Jest를 사용하여 작성되었습니다. 다른 테스트 프레임워크에서는 문법이 다를 수 있으니 해당 프레임워크의 문서를 참고하시기 바랍니다.

참고 자료