Skip to content

Latest commit

 

History

History
171 lines (126 loc) · 7.16 KB

UsingCatch2v3.md

File metadata and controls

171 lines (126 loc) · 7.16 KB

Using Approval Tests With Catch2 v3

Note: This is explicitly for Catch2 v3. Click here for Catch2 v2.

Contents

Introduction

The Catch2 test framework works well with Approval Tests.

This section describes the various ways of using Approval Tests with Catch2 v3.

Requirements

With separate Catch2 v3 headers

If you use the piecewise Catch2 v3 headers described in its v2 to v3 migration guide, Approval Tests requires that the following files are found:

#include <catch2/reporters/catch_reporter_event_listener.hpp>
#include <catch2/catch_test_macros.hpp>
#include <catch2/reporters/catch_reporter_registrars.hpp>
#include <catch2/catch_test_case_info.hpp>

snippet source | anchor

The selection of these headers is enabled by using APPROVALS_CATCH2_V3 in the examples below.

With Catch2 amalgamated releases

If you use catch_amalgamated.hpp and catch_amalgamated.cpp, Approval Tests requires that the following file is found:

#include <catch_amalgamated.hpp>

snippet source | anchor

The selection of this header is enabled by using APPROVALS_CATCH2_V3_AMALGAMATED in the examples below.

Getting Started With Catch2 v3

Note for users of Catch2 amalgamated releases

If you are using catch_amalgamated.hpp, you will need to make the following changes to all the example code below:

  1. In example main.cpp files, use APPROVALS_CATCH2_V3_AMALGAMATED instead of APPROVALS_CATCH2_V3
  2. In test files, use catch_amalgamated.hpp instead of catch2/catch_*.hpp.

Starter Project

The quickest way to start experimenting with Approval Tests will soon be:

  1. Download the project ApprovalTests.cpp.StarterProject - via the green "Clone or Download" button at the top-right of the project site.
  2. Opening the project in the C++ IDE of your choice.

Each time we release a new version of Approval Tests, we update this project, so it always has the latest features.

New Project

Create a file main.cpp and add just the following two lines:

// main.cpp:
#define APPROVALS_CATCH2_V3 // This tells Approval Tests to provide a main() - only do this in one cpp file
#include "ApprovalTests.hpp"

snippet source | anchor

Existing Project - with your main()

If you have supplied your own main() for Catch, you will need to teach it how to supply test names to Approval Tests.

You should make the following additions to your own source file that contains main().

// Add these two lines to the top of your main.cpp file:
#define APPROVALS_CATCH2_V3
#include "ApprovalTests.hpp"
#include <catch2/catch_session.hpp>

snippet source | anchor

Note: We think that using your own main() like this may not work with Catch2 amalgamated releases.

Code to copy for your first Catch2 Approvals test

Here is sample code to create your main() function, to set up Approval Tests' Catch2 integration.

We called this file catch2_v3_starter_main.cpp:

#define APPROVALS_CATCH2_V3
#include "ApprovalTests.hpp"

// This puts "received" and "approved" files in approval_tests/ sub-directory,
// keeping the test source directory tidy:
auto directoryDisposer =
    ApprovalTests::Approvals::useApprovalsSubdirectory("approval_tests");

snippet source | anchor

Here is sample code to create your first test. We called this file catch2_v3_starter_test.cpp:

#include "catch2/catch_all.hpp"
#include "ApprovalTests.hpp"

TEST_CASE("catch2_starter sample")
{
    // TODO Replace 42 with the value or object whose contents you are verifying.
    // For help, see:
    // https://approvaltestscpp.readthedocs.io/en/latest/generated_docs/ToString.html
    ApprovalTests::Approvals::verify(42);
}

snippet source | anchor

And finally, here is sample code to put in your CMakeLists.txt file:

set(EXE_NAME catch2_v3_starter)
set(CMAKE_CXX_STANDARD 14)
add_executable(${EXE_NAME}
        catch2_v3_starter_main.cpp
        catch2_v3_starter_test.cpp
        )
target_link_libraries(${EXE_NAME} ApprovalTests::ApprovalTests Catch2::Catch2WithMain)

add_test(NAME ${EXE_NAME} COMMAND ${EXE_NAME})

snippet source | anchor


Back to User Guide