1장: 단위 테스트 작성하기

이 첫 번째 장에서는 간단한 단위 테스트를 작성하는 방법과 테스트 케이스를 독립 실행형 실행 파일로 실행하는 방법을 설명합니다.

테스트 작성하기

QString 클래스의 동작을 테스트하고 싶다고 가정해 보겠습니다. 먼저 테스트 함수를 포함하는 클래스가 필요합니다. 이 클래스는 QObject 에서 상속해야 합니다:

#include <QTest>

class TestQString: public QObject
{
    Q_OBJECT
private slots:
    void toUpper();
};

참고: QTest 헤더를 포함하고 테스트 함수를 비공개 슬롯으로 선언하여 테스트 프레임워크가 이를 찾아 실행할 수 있도록 해야 합니다.

그런 다음 테스트 함수 자체를 구현해야 합니다. 구현은 다음과 같이 할 수 있습니다:

void TestQString::toUpper()
{
    QString str = "Hello";
    QVERIFY(str.toUpper() == "HELLO");
}

QVERIFY() 매크로는 인수로 전달된 표현식을 평가합니다. 표현식이 참으로 평가되면 테스트 함수의 실행이 계속됩니다. 그렇지 않으면 실패를 설명하는 메시지가 테스트 로그에 추가되고 테스트 함수의 실행이 중지됩니다.

그러나 테스트 로그에 보다 자세한 출력을 원한다면 QCOMPARE() 매크로를 대신 사용해야 합니다:

void TestQString::toUpper()
{
    QString str = "Hello";
    QCOMPARE(str.toUpper(), QString("HELLO"));
}

문자열이 같지 않은 경우 두 문자열의 내용이 테스트 로그에 추가되어 비교가 실패한 이유를 즉시 확인할 수 있습니다.

독립 실행형 실행 파일 준비하기

마지막으로 테스트 케이스를 독립 실행형 실행 파일로 만들려면 다음 두 줄이 필요합니다:

QTEST_MAIN(TestQString)
#include "testqstring.moc"

QTEST_MAIN() 매크로는 모든 테스트 함수를 실행하는 간단한 main() 메서드로 확장됩니다. 테스트 클래스의 선언과 구현이 모두 .cpp 파일에 있는 경우, 생성된 moc 파일도 포함해야 Qt의 인트로스펙션이 작동한다는 점에 유의하세요.

실행 파일 빌드하기

CMake 또는 qmake를 사용하여 테스트 케이스 실행 파일을 빌드할 수 있습니다.

CMake로 빌드하기

CMakeLists.txt 파일에서 빌드 설정을 구성합니다:

# Copyright (C) 2022 The Qt Company Ltd.
# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause

cmake_minimum_required(VERSION 3.16)
project(tutorial1 LANGUAGES CXX)

find_package(Qt6 REQUIRED COMPONENTS Core Gui Test Widgets)

qt_standard_project_setup()

qt_add_executable(tutorial1
    testqstring.cpp
)

set_target_properties(tutorial1 PROPERTIES
    WIN32_EXECUTABLE TRUE
    MACOSX_BUNDLE TRUE
)

target_link_libraries(tutorial1 PRIVATE
    Qt6::Core
    Qt6::Gui
    Qt6::Test
    Qt6::Widgets
)

install(TARGETS tutorial1
    BUNDLE  DESTINATION .
    RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
    LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
)

qt_generate_deploy_app_script(
    TARGET tutorial1
    OUTPUT_SCRIPT deploy_script
    NO_UNSUPPORTED_PLATFORM_ERROR
)
install(SCRIPT ${deploy_script})

그런 다음 명령줄에서 cmake 를 실행하거나 Qt-prefix/<version>/<platform>/bin/qt-cmake 에 있는 qt-cmake 편의 스크립트를 사용합니다:

<Qt-prefix>/<version>/<platform>/bin/qt-cmake <source-dir> <build-dir> -G Ninja

그런 다음 선호하는 생성기 도구를 실행하여 실행 파일을 빌드합니다. 여기서는 Ninja를 사용하고 있습니다:

ninja

qmake로 빌드하기

.pro 파일에서 빌드 설정을 구성합니다:

QT += widgets testlib

SOURCES = testqstring.cpp

# install
target.path = $$[QT_INSTALL_EXAMPLES]/qtestlib/tutorial1
INSTALLS += target

그런 다음 qmake 을 실행하고 마지막으로 make 을 실행하여 실행 파일을 빌드합니다:

qmake
make

참고: Windows를 사용하는 경우 makenmake 또는 사용하는 빌드 도구로 바꿉니다.

실행 파일 실행하기

결과 실행 파일을 실행하면 다음과 같은 출력이 표시됩니다:

********* Start testing of TestQString *********
Config: Using QtTest library %VERSION%, Qt %VERSION%
PASS   : TestQString::initTestCase()
PASS   : TestQString::toUpper()
PASS   : TestQString::cleanupTestCase()
Totals: 3 passed, 0 failed, 0 skipped
********* Finished testing of TestQString *********

축하합니다! Qt Test 프레임워크를 사용하여 첫 번째 단위 테스트를 작성하고 실행했습니다.

© 2025 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.