mirror of
https://github.com/catchorg/Catch2.git
synced 2024-11-14 09:49:54 +01:00
054d356332
By default, it expands into a `static_assert` + `SUCCEED` pair, but it can also be deferred to runtime by defining `CATCH_CONFIG_RUNTIME_STATIC_REQUIRE`, which causes it to expand into plain old `REQUIRE`. Closes #1362 Closes #1356
84 lines
3.0 KiB
C++
84 lines
3.0 KiB
C++
// X11-DisableStringification.cpp
|
|
// Test that Catch's prefixed macros compile and run properly.
|
|
|
|
#define CATCH_CONFIG_MAIN
|
|
// This won't provide full coverage, but it might be worth checking
|
|
// the other branch as well
|
|
#define CATCH_CONFIG_RUNTIME_STATIC_REQUIRE
|
|
#include <catch2/catch.hpp>
|
|
|
|
#include <type_traits>
|
|
#include <stdexcept>
|
|
|
|
[[noreturn]]
|
|
void this_throws() {
|
|
throw std::runtime_error("Some msg");
|
|
}
|
|
void this_doesnt_throw() {}
|
|
|
|
CATCH_TEST_CASE("PrefixedMacros") {
|
|
using namespace Catch::Matchers;
|
|
|
|
CATCH_REQUIRE( 1 == 1 );
|
|
CATCH_REQUIRE_FALSE( 1 != 1 );
|
|
|
|
CATCH_REQUIRE_THROWS(this_throws());
|
|
CATCH_REQUIRE_THROWS_AS(this_throws(), std::runtime_error);
|
|
CATCH_REQUIRE_THROWS_WITH(this_throws(), "Some msg");
|
|
CATCH_REQUIRE_THROWS_MATCHES(this_throws(), std::runtime_error, Predicate<std::runtime_error>([](std::runtime_error const&) { return true; }));
|
|
CATCH_REQUIRE_NOTHROW(this_doesnt_throw());
|
|
|
|
CATCH_CHECK( 1 == 1 );
|
|
CATCH_CHECK_FALSE( 1 != 1 );
|
|
CATCH_CHECKED_IF( 1 == 1 ) {
|
|
CATCH_SUCCEED("don't care");
|
|
} CATCH_CHECKED_ELSE ( 1 == 1 ) {
|
|
CATCH_SUCCEED("don't care");
|
|
}
|
|
|
|
CATCH_CHECK_NOFAIL(1 == 2);
|
|
|
|
CATCH_CHECK_THROWS(this_throws());
|
|
CATCH_CHECK_THROWS_AS(this_throws(), std::runtime_error);
|
|
CATCH_CHECK_THROWS_WITH(this_throws(), "Some msg");
|
|
CATCH_CHECK_THROWS_MATCHES(this_throws(), std::runtime_error, Predicate<std::runtime_error>([](std::runtime_error const&) { return true; }));
|
|
CATCH_CHECK_NOTHROW(this_doesnt_throw());
|
|
|
|
CATCH_REQUIRE_THAT("abcd", Equals("abcd"));
|
|
CATCH_CHECK_THAT("bdef", Equals("bdef"));
|
|
|
|
CATCH_INFO( "some info" );
|
|
CATCH_WARN( "some warn" );
|
|
CATCH_SECTION("some section") {
|
|
int i = 1;
|
|
CATCH_CAPTURE( i );
|
|
CATCH_DYNAMIC_SECTION("Dynamic section: " << i) {
|
|
CATCH_FAIL_CHECK( "failure" );
|
|
}
|
|
}
|
|
|
|
CATCH_STATIC_REQUIRE( std::is_void<void>::value );
|
|
CATCH_STATIC_REQUIRE_FALSE( std::is_void<int>::value );
|
|
}
|
|
|
|
CATCH_ANON_TEST_CASE() {
|
|
CATCH_FAIL("");
|
|
}
|
|
|
|
// Missing:
|
|
|
|
//
|
|
// #define CATCH_TEST_CASE_METHOD( className, ... ) INTERNAL_CATCH_TEST_CASE_METHOD( className, __VA_ARGS__ )
|
|
// #define CATCH_METHOD_AS_TEST_CASE( method, ... ) INTERNAL_CATCH_METHOD_AS_TEST_CASE( method, __VA_ARGS__ )
|
|
// #define CATCH_REGISTER_TEST_CASE( Function, ... ) INTERNAL_CATCH_REGISTER_TESTCASE( Function, __VA_ARGS__ )
|
|
//
|
|
// // "BDD-style" convenience wrappers
|
|
// #define CATCH_SCENARIO( ... ) CATCH_TEST_CASE( "Scenario: " __VA_ARGS__ )
|
|
// #define CATCH_SCENARIO_METHOD( className, ... ) INTERNAL_CATCH_TEST_CASE_METHOD( className, "Scenario: " __VA_ARGS__ )
|
|
// #define CATCH_GIVEN( desc ) INTERNAL_CATCH_DYNAMIC_SECTION( " Given: " << desc )
|
|
// #define CATCH_WHEN( desc ) INTERNAL_CATCH_DYNAMIC_SECTION( " When: " << desc )
|
|
// #define CATCH_AND_WHEN( desc ) INTERNAL_CATCH_DYNAMIC_SECTION( "And when: " << desc )
|
|
// #define CATCH_THEN( desc ) INTERNAL_CATCH_DYNAMIC_SECTION( " Then: " << desc )
|
|
// #define CATCH_AND_THEN( desc ) INTERNAL_CATCH_DYNAMIC_SECTION( " And: " << desc )
|
|
//
|