1
0
mirror of https://github.com/catchorg/Catch2.git synced 2025-01-10 20:03:30 +01:00
catch2/tests/SelfTest/Baselines
Martin Hořeňovský fe483c056d
Improve performance of JUnit reporter when handling passing assertions
This is done by no longer requiring all assertions to be seen
by the JUnit reporter. Since the JUnit reporter never outputs
all assertions, even with `-s`, the only difference from storing
passing assertions in the `CumulativeReporterBase` was some
bookkeeping in deciding which sections are relevant to the output.

Given `TEST_CASE` that just runs many passing assertions, e.g.

```
TEST_CASE( "PERFORMANCE_TEST_CASE", "[.]" ) {
    for (size_t i = 0; i < 1000'000'000; ++i) {
        REQUIRE( i == i );
    }
}
```

the new JUnit reporter will finish in 5:47, using up ~7.7 MB of RAM.
The old JUnit reporter would finish in 0:30, due to bad_alloc
after using up 14.5 GB of RAM (the system has 16 GB total).

If the total number of assertions is lowered to 10M, the old
implementation uses up ~7.1 GB of RAM and finishes in 12 minutes.
The new implementation still needs only ~7.7 MB of RAM, and finishes
in 4 minutes.

There is a slight downside in that the output is slightly different;
the new implementation will include the `TEST_CASE` level section
in output, even if it does not have its own assertion. In other words,
given a `TEST_CASE` like this

```
TEST_CASE( "JsonWriter", "[JSON][JsonWriter]" ) {
    std::stringstream stream;
    SECTION( "Newly constructed JsonWriter does nothing" ) {
        Catch::JsonValueWriter writer{ stream };
        REQUIRE( stream.str() == "" );
    }

    SECTION( "Calling writeObject will create an empty pair of braces" ) {
        { auto writer = Catch::JsonValueWriter{ stream }.writeObject(); }
        REQUIRE( stream.str() == "{\n}" );
    }
}
```

the new implementation will output 3 `testcase` tags, 2 for the explicit
 `SECTION`s with tests, and 1 for the top level section.

However, this can be worked-around if required, and the performance
improvement is such that it is worth changing the current output,
even if it needs to be fixed in the future.

Closes 
2024-08-13 19:13:03 +02:00
..
automake.std.approved.txt Move tests from projects/ to tests/ 2019-12-05 16:00:20 +01:00
automake.sw.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
automake.sw.multi.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
compact.sw.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
compact.sw.multi.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
console.std.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
console.sw.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
console.sw.multi.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
console.swa4.approved.txt Stop exceptions in generator constructors from aborting the binary 2023-01-22 16:04:16 +01:00
default.sw.multi.approved.txt Add new SKIP macro for skipping tests at runtime () 2023-01-12 15:01:47 +01:00
junit.sw.approved.txt Improve performance of JUnit reporter when handling passing assertions 2024-08-13 19:13:03 +02:00
junit.sw.multi.approved.txt Improve performance of JUnit reporter when handling passing assertions 2024-08-13 19:13:03 +02:00
sonarqube.sw.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
sonarqube.sw.multi.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
tap.sw.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
tap.sw.multi.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
teamcity.sw.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
teamcity.sw.multi.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
xml.sw.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00
xml.sw.multi.approved.txt TEST_CASE_PERSISTENT_FIXTURE: A new fixture macro for allowing persistent fixtures throughout a TEST_CASE () 2024-08-05 17:01:41 +02:00