"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 클린 코드 이해: 단위 테스트 ⚡

클린 코드 이해: 단위 테스트 ⚡

2024-08-31에 게시됨
검색:106

Understanding Clean Code: Unit Tests ⚡

소프트웨어 개발에서 단위 테스트는 코드의 정확성을 보장하는 데 도움이 되는 중요한 방법입니다.

Clean Code: A Handbook of Agile Software Craftsmanship의 9장에서는 "유닛 테스트"라는 제목으로 깨끗하고 효과적인 단위 테스트를 작성하기 위한 원칙과 사례를 다룹니다.

이 문서에서는 이 장의 주요 내용을 요약하고 이러한 개념을 설명하는 JavaScript 예제를 제공합니다.


? 단위 테스트가 중요한 이유

단위 테스트에는 코드의 개별 단위 또는 구성 요소에 대한 테스트를 작성하여 예상대로 작동하는지 확인하는 작업이 포함됩니다. 단위 테스트의 주요 목표는 다음과 같습니다.

1- 버그 조기 감지: 개발 중에 문제가 프로덕션에 도달하기 전에 포착합니다.

2- 리팩토링 촉진: 코드 변경으로 인해 기존 기능이 중단되지 않는지 확인하세요.

3- 코드 동작 문서화: 코드 사용 방법에 대한 문서 역할을 합니다.


? 효과적인 단위 테스트의 원칙

⚡ 한 번에 하나씩 테스트

각 단위 테스트는 기능의 단일 측면에 초점을 맞춰야 합니다. 이렇게 하면 테스트를 더 쉽게 이해하고 유지 관리할 수 있습니다. 테스트가 실패하면 문제가 어디에 있는지 정확히 알 수 있습니다.

function add(a, b) {
    return a   b;
}

// Test case for the add function
function testAdd() {
    // Test adding positive numbers
    assertEqual(add(2, 3), 5, '2   3 should be 5');
    // Test adding negative numbers
    assertEqual(add(-1, -1), -2, '-1   -1 should be -2');
}

// A simple assertion function
function assertEqual(actual, expected, message) {
    if (actual !== expected) {
        throw new Error(message);
    }
}

⚡ 테스트를 읽을 수 있게 만들기

테스트는 읽고 이해하기 쉬워야 합니다. 테스트 함수에 설명적인 이름을 사용하고 명확한 어설션을 사용하세요. 이는 다른 사람(그리고 본인)이 각 테스트에서 확인하는 내용을 빠르게 파악하는 데 도움이 됩니다.

function isEven(number) {
    return number % 2 === 0;
}

// Descriptive test function
function testIsEven() {
    assertEqual(isEven(4), true, '4 should be even');
    assertEqual(isEven(5), false, '5 should be odd');
}

⚡ 명확하고 설명이 포함된 이름을 사용하세요.

테스트 사례 이름은 테스트 대상을 설명해야 합니다. 이를 통해 테스트의 가독성과 유지 관리성이 향상됩니다.

function calculateTotalPrice(items) {
    return items.reduce((total, item) => total   item.price, 0);
}

// Descriptive test case names
function testCalculateTotalPrice() {
    assertEqual(calculateTotalPrice([{ price: 10 }, { price: 20 }]), 30, 'Total price should be 30 for items costing 10 and 20');
    assertEqual(calculateTotalPrice([{ price: 5 }]), 5, 'Total price should be 5 for a single item costing 5');
}

⚡ 테스트를 독립적으로 유지

각 테스트는 다른 테스트와 독립적이어야 합니다. 공유 상태에 의존하는 테스트는 불안정한 테스트로 이어질 수 있으며 디버깅을 어렵게 만들 수 있습니다.

function multiply(a, b) {
    return a * b;
}

// Independent test cases
function testMultiply() {
    assertEqual(multiply(2, 3), 6, '2 * 3 should be 6');
    assertEqual(multiply(0, 10), 0, '0 * 10 should be 0');
}

⚡ 모의(Mock)와 스텁(Stub)을 적절하게 사용하세요

모의 및 스텁은 종속성을 시뮬레이션하여 테스트 중인 코드 단위를 격리하는 데 도움이 될 수 있습니다. 그러나 테스트가 지나치게 복잡해지지 않도록 신중하게 사용하세요.

// Example of using a mock for a database call
function getUser(id) {
    // Imagine this function makes a database call
    return database.getUserById(id);
}

function testGetUser() {
    const mockDatabase = {
        getUserById: (id) => ({ id, name: 'John Doe' }),
    };

    const result = getUser(1, mockDatabase);
    assertEqual(result.name, 'John Doe', 'User name should be John Doe');
}

⚡ 테스트 자동화

단위 테스트 실행을 자동화하여 정기적으로 실행되도록 하세요. CI(지속적 통합) 도구는 변경 사항이 있을 때마다 자동으로 테스트를 실행하는 데 도움이 됩니다.

Jest와 같은 테스트 프레임워크를 사용하는 경우 package.json에 스크립트를 설정할 수 있습니다.

"scripts": {
    "test": "jest"
}

npm 테스트를 실행하면 모든 테스트가 실행되고 상태에 대한 피드백이 제공됩니다.


결론

깔끔하고 효과적인 단위 테스트를 작성하는 것은 고품질 코드를 유지하는 데 필수적입니다.

클린 코드 9장에 설명된 원칙을 따르면 테스트가 신뢰할 수 있고 이해 가능하며 가치가 있음을 확인할 수 있습니다.

JavaScript 코드에 이러한 방법을 구현하면 테스트 품질이 향상될 뿐만 아니라 더욱 강력하고 유지 관리가 용이한 코드베이스를 만드는 데 도움이 됩니다.

즐거운 코딩하세요!

릴리스 선언문 이 글은 https://dev.to/alisamir/understanding-clean-code-unit-tests-5d1a?1 에서 복제되었습니다.1 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3