I want to do somethink like this:
TEST(MyTestFixture, printAfterExpectationFailure)
{
  const string request("bring me tea");
  const string&& response = sendRequestAndGetResponse(request);
  checkResponseWithExpectarions1(response);
  checkResponseWithExpectarions2(response);
  checkResponseWithExpectarions3(response);
  checkResponseWithExpectarions4(response);
  if (anyOfExpectsFailed())
      cout << "Request: " << request << "\nresponse: " << response << endl;
}
TEST(MyTestFixture, printAfterAssertionFailure)
{
  const string request("bring me tea");
  const string&& response = sendRequestAndGetResponse(request);
  doWhenFailure([&request, &response]()
  {
      cout << "Request: " << request << "\nresponse: " << response << endl;
  });
  checkResponseWithAssertion1(response);
  checkResponseWithAssertion2(response);
  checkResponseWithAssertion3(response);
  checkResponseWithAssertion4(response);
}
I want to print some additional information when and only when expectations/assertions failures.
I know that I can do something like this:
#define MY_ASSERT_EQ(lhr, rhs, message) if(lhs != rhs) ASSERT_EQ(lhs, rhs) << message
but this kind of solution is not comfortable because:
the fact that doing what you want to do is difficult is actually a test code smell. In particular, these two tests (1) do too much and (2) are unreadable, in the sense that they do not describe what the unit under test does.
I recommend two readings: Unit Tests are FIRST and the book Modern C++ Programming with Test-Driven Development.
Instead of trying to call 4 functions, each checking something, and then wondering how to print an error message in case of failure, I suggest the following:
At the end of this process, you should find yourself in a situation where your goal of printing additional information on test failure can be reached simply with something like:
ASSERT_THAT(Response, EQ("something")) << "Request: " << request;
Note: also if better that the starting point, I don't consider the above example good enough. The test name should be so good, so descriptive, that you would gain zero information by printing the value of request.
I realize this is a sort of philosophical answer; on the other hand it comes directly from my experience in attempting to write good, maintainable tests. Writing good tests requires the same care than writing good code, and it will pay off many times :-)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With