Skip to content

Commit

Permalink
fixup! Report generator states for failed assertions
Browse files Browse the repository at this point in the history
  • Loading branch information
gotschmarcel committed Oct 1, 2022
1 parent 48a5431 commit 3370452
Show file tree
Hide file tree
Showing 5 changed files with 13 additions and 9 deletions.
2 changes: 1 addition & 1 deletion examples/311-Gen-CustomCapture.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ TEST_CASE("Generate random doubles across different ranges",
// This will take r1 by reference and r2 by value.
// Note that there are no advantages for doing so in this example,
// it is done only for expository purposes.
auto number = Catch::Generators::generate( "custom capture generator", "custom definition", CATCH_INTERNAL_LINEINFO,
auto number = Catch::Generators::generate( "custom capture generator", "custom arguments description", CATCH_INTERNAL_LINEINFO,
[&r1, r2]{
using namespace Catch::Generators;
return makeGenerators(take(50, random(std::get<0>(r1), std::get<1>(r2))));
Expand Down
4 changes: 2 additions & 2 deletions src/catch2/generators/catch_generators.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -211,7 +211,7 @@ namespace Detail {
// Note: The type after -> is weird, because VS2015 cannot parse
// the expression used in the typedef inside, when it is in
// return type. Yeah.
auto generate( StringRef generatorName, StringRef definition, SourceLineInfo const& lineInfo, L const& generatorExpression ) -> decltype(std::declval<decltype(generatorExpression())>().get()) {
auto generate( StringRef generatorName, StringRef argumentsDescription, SourceLineInfo const& lineInfo, L const& generatorExpression ) -> decltype(std::declval<decltype(generatorExpression())>().get()) {
using UnderlyingType = typename decltype(generatorExpression())::type;

IGeneratorTracker& tracker = acquireGeneratorTracker( generatorName, lineInfo );
Expand All @@ -220,7 +220,7 @@ namespace Detail {
}

auto const& generator = static_cast<IGenerator<UnderlyingType> const&>( *tracker.getGenerator() );
getResultCapture().trackGeneratorState(GeneratorInfo(definition, lineInfo, generator.currentElementAsString()));
getResultCapture().trackGeneratorState(GeneratorInfo(generatorName, argumentsDescription, lineInfo, generator.currentElementAsString()));
return generator.get();
}

Expand Down
6 changes: 4 additions & 2 deletions src/catch2/internal/catch_generator_info.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,12 @@

namespace Catch {

GeneratorInfo::GeneratorInfo( StringRef _definition,
GeneratorInfo::GeneratorInfo( StringRef _name,
StringRef _arguments,
SourceLineInfo const& _lineInfo,
StringRef _currentElement ):
definition( _definition ),
name( _name ),
arguments( _arguments ),
lineInfo( _lineInfo ),
currentElement( _currentElement ) {}

Expand Down
8 changes: 5 additions & 3 deletions src/catch2/internal/catch_generator_info.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -15,16 +15,18 @@
namespace Catch {

struct GeneratorInfo {
GeneratorInfo( StringRef _definition,
GeneratorInfo( StringRef _name,
StringRef _arguments,
SourceLineInfo const& _lineInfo,
StringRef currentElement );

StringRef definition;
StringRef name;
StringRef arguments;
SourceLineInfo lineInfo;
StringRef currentElement;

bool operator==( GeneratorInfo const& other ) const {
return definition == other.definition &&
return name == other.name && arguments == other.arguments &&
lineInfo == other.lineInfo &&
currentElement == other.currentElement;
}
Expand Down
2 changes: 1 addition & 1 deletion src/catch2/reporters/catch_reporter_console.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,7 @@ class ConsoleAssertionPrinter {
for ( auto const& info : stats.generatorInfos ) {
stream << TextFlow::Column( "line:" ).indent( 2 )
<< info.lineInfo.line << ": "
<< "GENERATE(" << info.definition << ")\n"
<< "GENERATE(" << info.arguments << ")\n"
<< TextFlow::Column( "value: " ).indent( 2 )
<< colourImpl->guardColour( Colour::GeneratorValue )
<< info.currentElement << '\n';
Expand Down

0 comments on commit 3370452

Please sign in to comment.