A modern, C++-native, test framework for unit-tests, TDD and BDD - using C++14, C++17 and later (C++11 support is in v2.x branch, and C++03 on the Catch1.x branch)
Go to file
Martin Hořeňovský 1ca8f43b01 Add PredicateMatcher that takes an arbitrary predicate functions
Also adds `Predicate` helper function to create `PredicateMatcher`.
Because of limitations in type inference it needs to be explicitly
typed, like so
`Predicate<std::string>([](std::string const& str) { ... })`.
It also takes an optional second argument for description of the
predicate.

It is possible to infer the argument with sufficient TMP, see
https://stackoverflow.com/questions/43560492/how-to-extract-lambdas-return-type-and-variadic-parameters-pack-back-from-gener/43561563#43561563
but I don't think that the magic is worth introducing ATM.

Closes #1236
2018-04-04 11:14:19 +02:00
.github Added "How to test changes in PR" section to documentation 2017-06-22 18:56:10 +02:00
CMake Add codecov.io coverage tracking 2017-11-27 20:13:47 +01:00
artwork Tweaked logo 2017-11-07 11:41:49 +00:00
contrib Catch ``catch_discover_tests`` 2018-01-11 21:17:12 +01:00
docs Add PredicateMatcher that takes an arbitrary predicate functions 2018-04-04 11:14:19 +02:00
examples Namespace Catch CMake options 2018-01-18 23:20:26 +01:00
include Add PredicateMatcher that takes an arbitrary predicate functions 2018-04-04 11:14:19 +02:00
misc Fixup various spelling errors (#1208) 2018-03-07 10:08:35 +01:00
projects Add PredicateMatcher that takes an arbitrary predicate functions 2018-04-04 11:14:19 +02:00
scripts Fixup various spelling errors (#1208) 2018-03-07 10:08:35 +01:00
single_include v2.2.1 2018-03-11 12:04:28 +01:00
test_package v2.2.1 2018-03-11 12:04:28 +01:00
third_party Bring in Clara v1.1.4 2018-03-09 10:37:56 +01:00
.gitattributes Keep .py files with LF endings so they can be executed from bash 2018-02-09 16:49:35 +01:00
.gitignore Exclude benchmark dir 2018-01-05 14:39:59 +00:00
.travis.yml Fix potential for false negative CI results on coverage collection 2018-04-01 14:36:55 +02:00
CMakeLists.txt Add PredicateMatcher that takes an arbitrary predicate functions 2018-04-04 11:14:19 +02:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2017-08-17 07:45:12 +01:00
LICENSE.txt Renamed licence file, license should now be detected by github 2017-03-20 08:59:25 +01:00
README.md v2.2.1 2018-03-11 12:04:28 +01:00
appveyor.yml Disable PIP's version check on AppVeyor 2018-03-22 15:19:09 +01:00
catch.pc.in Small fix to generate pc with include path 2018-04-02 21:38:17 +02:00
codecov.yml Set patch coverage check to target 80% 2018-02-09 20:09:55 +01:00
conanfile.py v2.2.1 2018-03-11 12:04:28 +01:00

README.md

catch logo

Github Releases Build Status Build status codecov Try online

The latest version of the single header can be downloaded directly using this link

Catch2 is released!

If you've been using an earlier version of Catch, please see the Breaking Changes section of the release notes before moving to Catch2. You might also like to read this blog post for more details.

What's the Catch?

Catch2 stands for C++ Automated Test Cases in a Header and is a multi-paradigm test framework for C++. which also supports Objective-C (and maybe C). It is primarily distributed as a single header file, although certain extensions may require additional headers.

How to use it

This documentation comprises these three parts:

More