mirror of
https://github.com/catchorg/Catch2.git
synced 2024-11-29 16:53:30 +01:00
Added benchmark tests
This commit is contained in:
parent
22e9ebef0d
commit
f45d35c980
@ -55,6 +55,7 @@ endfunction()
|
|||||||
set(TEST_SOURCES
|
set(TEST_SOURCES
|
||||||
${SELF_TEST_DIR}/ApproxTests.cpp
|
${SELF_TEST_DIR}/ApproxTests.cpp
|
||||||
${SELF_TEST_DIR}/BDDTests.cpp
|
${SELF_TEST_DIR}/BDDTests.cpp
|
||||||
|
${SELF_TEST_DIR}/Benchmark.tests.cpp
|
||||||
${SELF_TEST_DIR}/ClassTests.cpp
|
${SELF_TEST_DIR}/ClassTests.cpp
|
||||||
${SELF_TEST_DIR}/CmdLineTests.cpp
|
${SELF_TEST_DIR}/CmdLineTests.cpp
|
||||||
${SELF_TEST_DIR}/CompilationTests.cpp
|
${SELF_TEST_DIR}/CompilationTests.cpp
|
||||||
@ -96,9 +97,9 @@ set(SURROGATE_SOURCES
|
|||||||
${SELF_TEST_DIR}/SurrogateCpps/catch_option.cpp
|
${SELF_TEST_DIR}/SurrogateCpps/catch_option.cpp
|
||||||
${SELF_TEST_DIR}/SurrogateCpps/catch_stream.cpp
|
${SELF_TEST_DIR}/SurrogateCpps/catch_stream.cpp
|
||||||
${SELF_TEST_DIR}/SurrogateCpps/catch_streambuf.cpp
|
${SELF_TEST_DIR}/SurrogateCpps/catch_streambuf.cpp
|
||||||
|
${SELF_TEST_DIR}/SurrogateCpps/catch_test_case_tracker.cpp
|
||||||
${SELF_TEST_DIR}/SurrogateCpps/catch_test_spec.cpp
|
${SELF_TEST_DIR}/SurrogateCpps/catch_test_spec.cpp
|
||||||
${SELF_TEST_DIR}/SurrogateCpps/catch_xmlwriter.cpp
|
${SELF_TEST_DIR}/SurrogateCpps/catch_xmlwriter.cpp
|
||||||
${SELF_TEST_DIR}/SurrogateCpps/catch_test_case_tracker.cpp
|
|
||||||
)
|
)
|
||||||
CheckFileList(SURROGATE_SOURCES ${SELF_TEST_DIR}/SurrogateCpps)
|
CheckFileList(SURROGATE_SOURCES ${SELF_TEST_DIR}/SurrogateCpps)
|
||||||
|
|
||||||
|
@ -850,6 +850,22 @@ warning:
|
|||||||
Uncomment the code in this test to check that it gives a sensible compiler
|
Uncomment the code in this test to check that it gives a sensible compiler
|
||||||
error
|
error
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
benchmarked
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
String.tests.cpp:<line number>
|
||||||
|
...............................................................................
|
||||||
|
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
| benchmark name | iters | elapsed ns | average |
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
|
||||||
|
| Load up a vector | 1 | 8459 | 8459 ns |
|
||||||
|
| Load up a map | 1 | 28774 | 28774 ns |
|
||||||
|
| Reserved vector | 1 | 2430 | 2430 ns |
|
||||||
|
| A fixed size array that should require | | | |
|
||||||
|
| no allocations | 10 | 2563 | 256 ns |
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
checkedElse, failing
|
checkedElse, failing
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
@ -1016,6 +1032,6 @@ with expansion:
|
|||||||
"{?}" == "1"
|
"{?}" == "1"
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
test cases: 182 | 131 passed | 47 failed | 4 failed as expected
|
test cases: 183 | 132 passed | 47 failed | 4 failed as expected
|
||||||
assertions: 896 | 779 passed | 96 failed | 21 failed as expected
|
assertions: 900 | 783 passed | 96 failed | 21 failed as expected
|
||||||
|
|
||||||
|
@ -6381,6 +6381,67 @@ PASSED:
|
|||||||
with expansion:
|
with expansion:
|
||||||
0 == 0
|
0 == 0
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
benchmarked
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
String.tests.cpp:<line number>
|
||||||
|
...............................................................................
|
||||||
|
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
| benchmark name | iters | elapsed ns | average |
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
|
||||||
|
| Load up a vector | 1 | 6957 | 6957 ns |
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
String.tests.cpp:<line number>:
|
||||||
|
PASSED:
|
||||||
|
REQUIRE( v.size() == size )
|
||||||
|
with expansion:
|
||||||
|
100 == 100
|
||||||
|
|
||||||
|
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
|
||||||
|
| benchmark name | iters | elapsed ns | average |
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
|
||||||
|
| Load up a map | 1 | 27868 | 27868 ns |
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
String.tests.cpp:<line number>:
|
||||||
|
PASSED:
|
||||||
|
REQUIRE( m.size() == size )
|
||||||
|
with expansion:
|
||||||
|
100 == 100
|
||||||
|
|
||||||
|
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
|
||||||
|
| benchmark name | iters | elapsed ns | average |
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
|
||||||
|
| Reserved vector | 1 | 2711 | 2711 ns |
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
String.tests.cpp:<line number>:
|
||||||
|
PASSED:
|
||||||
|
REQUIRE( v.size() == size )
|
||||||
|
with expansion:
|
||||||
|
100 == 100
|
||||||
|
|
||||||
|
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
|
||||||
|
| benchmark name | iters | elapsed ns | average |
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
|
||||||
|
| A fixed size array that should require | | | |
|
||||||
|
| no allocations | 1 | 530 | 530 ns |
|
||||||
|
+-----------------------------------------------------------------------------+
|
||||||
|
String.tests.cpp:<line number>:
|
||||||
|
PASSED:
|
||||||
|
REQUIRE( sum > size )
|
||||||
|
with expansion:
|
||||||
|
4950 (0x<hex digits>) > 100
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
boolean member
|
boolean member
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
@ -7590,6 +7651,6 @@ MiscTests.cpp:<line number>:
|
|||||||
PASSED:
|
PASSED:
|
||||||
|
|
||||||
===============================================================================
|
===============================================================================
|
||||||
test cases: 182 | 130 passed | 48 failed | 4 failed as expected
|
test cases: 183 | 131 passed | 48 failed | 4 failed as expected
|
||||||
assertions: 898 | 779 passed | 98 failed | 21 failed as expected
|
assertions: 902 | 783 passed | 98 failed | 21 failed as expected
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<testsuitesspanner>
|
<testsuitesspanner>
|
||||||
<testsuite name="<exe-name>" errors="15" failures="84" tests="899" hostname="tbd" time="{duration}" timestamp="{iso8601-timestamp}">
|
<testsuite name="<exe-name>" errors="15" failures="84" tests="903" hostname="tbd" time="{duration}" timestamp="{iso8601-timestamp}">
|
||||||
<testcase classname="<exe-name>.global" name="# A test name that starts with a #" time="{duration}"/>
|
<testcase classname="<exe-name>.global" name="# A test name that starts with a #" time="{duration}"/>
|
||||||
<testcase classname="<exe-name>.global" name="#748 - captures with unexpected exceptions/outside assertions" time="{duration}">
|
<testcase classname="<exe-name>.global" name="#748 - captures with unexpected exceptions/outside assertions" time="{duration}">
|
||||||
<error type="TEST_CASE">
|
<error type="TEST_CASE">
|
||||||
@ -641,6 +641,7 @@ ExceptionTests.cpp:<line number>
|
|||||||
<testcase classname="<exe-name>.global" name="XmlEncode/string with control char (1)" time="{duration}"/>
|
<testcase classname="<exe-name>.global" name="XmlEncode/string with control char (1)" time="{duration}"/>
|
||||||
<testcase classname="<exe-name>.global" name="XmlEncode/string with control char (x7F)" time="{duration}"/>
|
<testcase classname="<exe-name>.global" name="XmlEncode/string with control char (x7F)" time="{duration}"/>
|
||||||
<testcase classname="<exe-name>.global" name="atomic if" time="{duration}"/>
|
<testcase classname="<exe-name>.global" name="atomic if" time="{duration}"/>
|
||||||
|
<testcase classname="<exe-name>.global" name="benchmarked" time="{duration}"/>
|
||||||
<testcase classname="<exe-name>.global" name="boolean member" time="{duration}"/>
|
<testcase classname="<exe-name>.global" name="boolean member" time="{duration}"/>
|
||||||
<testcase classname="<exe-name>.global" name="checkedElse" time="{duration}"/>
|
<testcase classname="<exe-name>.global" name="checkedElse" time="{duration}"/>
|
||||||
<testcase classname="<exe-name>.global" name="checkedElse, failing" time="{duration}">
|
<testcase classname="<exe-name>.global" name="checkedElse, failing" time="{duration}">
|
||||||
|
@ -7201,6 +7201,41 @@ Message from section two
|
|||||||
</Expression>
|
</Expression>
|
||||||
<OverallResult success="true"/>
|
<OverallResult success="true"/>
|
||||||
</TestCase>
|
</TestCase>
|
||||||
|
<TestCase name="benchmarked" tags="[benchmark]" filename="projects/<exe-name>/String.tests.cpp" >
|
||||||
|
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/String.tests.cpp" >
|
||||||
|
<Original>
|
||||||
|
v.size() == size
|
||||||
|
</Original>
|
||||||
|
<Expanded>
|
||||||
|
100 == 100
|
||||||
|
</Expanded>
|
||||||
|
</Expression>
|
||||||
|
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/String.tests.cpp" >
|
||||||
|
<Original>
|
||||||
|
m.size() == size
|
||||||
|
</Original>
|
||||||
|
<Expanded>
|
||||||
|
100 == 100
|
||||||
|
</Expanded>
|
||||||
|
</Expression>
|
||||||
|
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/String.tests.cpp" >
|
||||||
|
<Original>
|
||||||
|
v.size() == size
|
||||||
|
</Original>
|
||||||
|
<Expanded>
|
||||||
|
100 == 100
|
||||||
|
</Expanded>
|
||||||
|
</Expression>
|
||||||
|
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/String.tests.cpp" >
|
||||||
|
<Original>
|
||||||
|
sum > size
|
||||||
|
</Original>
|
||||||
|
<Expanded>
|
||||||
|
4950 (0x<hex digits>) > 100
|
||||||
|
</Expanded>
|
||||||
|
</Expression>
|
||||||
|
<OverallResult success="true"/>
|
||||||
|
</TestCase>
|
||||||
<TestCase name="boolean member" tags="[Tricky]" filename="projects/<exe-name>/TrickyTests.cpp" >
|
<TestCase name="boolean member" tags="[Tricky]" filename="projects/<exe-name>/TrickyTests.cpp" >
|
||||||
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/TrickyTests.cpp" >
|
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/TrickyTests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
@ -8441,7 +8476,7 @@ spanner <OverallResult success="true"/>
|
|||||||
</Section>
|
</Section>
|
||||||
<OverallResult success="true"/>
|
<OverallResult success="true"/>
|
||||||
</TestCase>
|
</TestCase>
|
||||||
<OverallResults successes="779" failures="99" expectedFailures="21"/>
|
<OverallResults successes="783" failures="99" expectedFailures="21"/>
|
||||||
</Group>
|
</Group>
|
||||||
<OverallResults successes="779" failures="98" expectedFailures="21"/>
|
<OverallResults successes="783" failures="98" expectedFailures="21"/>
|
||||||
</Catch>
|
</Catch>
|
||||||
|
43
projects/SelfTest/Benchmark.tests.cpp
Normal file
43
projects/SelfTest/Benchmark.tests.cpp
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
#include "catch.hpp"
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
|
||||||
|
TEST_CASE( "benchmarked", "[.][benchmark]" ) {
|
||||||
|
|
||||||
|
static const int size = 100;
|
||||||
|
|
||||||
|
std::vector<int> v;
|
||||||
|
std::map<int, int> m;
|
||||||
|
|
||||||
|
BENCHMARK( "Load up a vector" ) {
|
||||||
|
v = std::vector<int>();
|
||||||
|
for(int i =0; i < size; ++i )
|
||||||
|
v.push_back( i );
|
||||||
|
}
|
||||||
|
REQUIRE( v.size() == size );
|
||||||
|
|
||||||
|
BENCHMARK( "Load up a map" ) {
|
||||||
|
m = std::map<int, int>();
|
||||||
|
for(int i =0; i < size; ++i )
|
||||||
|
m.insert( { i, i+1 } );
|
||||||
|
}
|
||||||
|
REQUIRE( m.size() == size );
|
||||||
|
|
||||||
|
BENCHMARK( "Reserved vector" ) {
|
||||||
|
v = std::vector<int>();
|
||||||
|
v.reserve(size);
|
||||||
|
for(int i =0; i < size; ++i )
|
||||||
|
v.push_back( i );
|
||||||
|
}
|
||||||
|
REQUIRE( v.size() == size );
|
||||||
|
|
||||||
|
int array[size];
|
||||||
|
BENCHMARK( "A fixed size array that should require no allocations" ) {
|
||||||
|
for(int i =0; i < size; ++i )
|
||||||
|
array[i] = i;
|
||||||
|
}
|
||||||
|
int sum = 0;
|
||||||
|
for(int i =0; i < size; ++i )
|
||||||
|
sum += array[i];
|
||||||
|
REQUIRE( sum > size );
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user