Industriële fabricage
Industrieel internet der dingen | Industriële materialen | Onderhoud en reparatie van apparatuur | Industriële programmering |
home  MfgRobots >> Industriële fabricage >  >> Manufacturing Technology >> Industriële technologie

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

  1. SaaS- en cloudbeveiliging toevoegen met testen en automatisering
  2. C++-operators
  3. C++ do...while-lus met voorbeelden
  4. C++ Switch Case Statement met VOORBEELD
  5. C++ Dynamische toewijzing van arrays met voorbeeld
  6. C++-aanwijzers met voorbeelden
  7. C++ Char-gegevenstype met voorbeelden
  8. Overbelasting van C++-operator met voorbeelden
  9. C++-structuur met voorbeeld
  10. std::lijst in C++ met Voorbeeld
  11. C++-functies met programmavoorbeelden