c++ testen met catch2
Abstract
In dit artikel leg ik uit hoe je catch2
. gebruikt om unit-tests te doen.
Hoe te bouwen
Om de bronnen te bouwen, moet je een release downloaden van https://github.com/catchorg/Catch2/tags. Nu kunt u de broncode compileren met gcc. Het volgende codefragment toont de cmake script
te compileren.
#Please set the environment variables to your needs
cmake \
-G "Unix Malkefiles" \
-D CMAKE_BUILD_TYPE=Release \
-D BUILD_TESTING=OFF \
-D BUILD_SHARED_LIBS=ON \
-D "CMAKE_STAGING_PREFIX=${CMAKE_STAGING_PREFIX}" \
-D "CMAKE_INSTALL_PREFIX=${CMAKE_STAGING_PREFIX}" \
-D BUILD_TESTS=OFF \
-S "${SOURCE_DIRECTORY}" \
-B "${BUILD_DIRECTORY}"
cmake --build "${BUILD_DIRECTORY}" --target install
Integreren in projectstructuur
Aanbevolen projectstructuur:
|-- project
|----CMakeLists-txt
|----test
|------cmake
|--------Catch.cmake
|--------CatchAddTests.cmake
|--------FindCatch2.cmake
|--------ParseAndAddCatchTests.cmake
|------Main.cpp
|------ExampleTest1.cpp
|------ExampleTest2.cpp
|------CMakeLists.txt
Instellingen in CMakeLists.txt
van het project
include(CTest)
target_compile_definitions(${TARGET} PRIVATE
TEST_DATA_PATH="${PROJECT_SOURCE_DIR}/data")
//set environment variable to ON if you want to enable testing
if (BUILD_TESTING)
enable_testing()
add_subdirectory(test)
endif()
Instellingen in CMakeLists.txt
van de testmap.
cmake_minimum_required(VERSION 3.13)
list(APPEND CMAKE_MODULE_PATH "${PROJECT_SOURCE_DIR}/test/cmake")
set (WILDCARD_SOURCE *.cpp)
file(GLOB_RECURSE TEST_SOURCES ${WILDCARD_SOURCE})
add_executable(${TARGET_TEST} ${TEST_SOURCES})
find_package(Catch2 REQUIRED)
# Link to the desired libraries
target_link_libraries(${TARGET_TEST}
PRIVATE
Catch2::Catch2
...
)
target_compile_definitions(DcmlParserTest PRIVATE
TEST_DATA_PATH="${PROJECT_SOURCE_DIR}/data")
include(ParseAndAddCatchTests)
ParseAndAddCatchTests(${TARGET_TEST})
Hoe te gebruiken
Hoofd.cpp
#define CATCH_CONFIG_MAIN
#include <catch2/catch.hpp>
VoorbeeldTest.cpp
Dit voorbeeld laat zien hoe u kunt testen met SCENARIOS
.
#include <catch2/catch.hpp>
#ifndef DATA_PATH
#define DATA_PATH "/tmp/data"
#endif
SCENARIO("testcase", "")
{
GIVEN("usercase 1")
{
WHEN("instance is created")
{
THEN("test properties")
{
//check if true
REQUIRE(...);
/check if no exception
REQUIRE_NOTHROW(...);
}
}
}
}
VoorbeeldTest2.cpp
Dit voorbeeld laat zien hoe te testen met TEST_CASE
.
#include <catch2/catch.hpp>
#ifndef DATA_PATH
#define DATA_PATH "/tmp/data"
#endif
TEST_CASE( "TestCase1", "" ) {
REQUIRE( 1 == 1 );
}
TEST_CASE( "Testcase2", "" ) {
REQUIRE( 3 != 1 );
}
Speciale opmerking voor PLCnext-toepassingen
Om catch2
. te gebruiken als testraamwerk moet je ARP-inhoud uitsluiten. U moet uw code compileren met de lokale gcc-compiler. Met deze setup kunt u uw niet-ARP-code lokaal testen.
Meer informatie
Als u geïnteresseerd bent in meer informatie over catch2
u kunt de volgende link bekijken:
- GitHub:https://github.com/catchorg/Catch2
Licentie
De bibliotheek is gepubliceerd onder Boost Software License 1.0
Industriële technologie
- SaaS- en cloudbeveiliging toevoegen met testen en automatisering
- C++-operators
- C++ do...while-lus met voorbeelden
- C++ Switch Case Statement met VOORBEELD
- C++ Dynamische toewijzing van arrays met voorbeeld
- C++-aanwijzers met voorbeelden
- C++ Char-gegevenstype met voorbeelden
- Overbelasting van C++-operator met voorbeelden
- C++-structuur met voorbeeld
- std::lijst in C++ met Voorbeeld
- C++-functies met programmavoorbeelden