Search code examples
c++unit-testinggoogletest

gtest - Report index variable for loop with EXPECT_EQ


I am using gtest but I am new to gtest. I would like to do compares of values within two std::vectors of complex data structures. I want to do something like this:

ASSERT_EQ(a.size(), b.size());

for (int x = 0; x < a.size(); x++) {
  EXPECT_EQ(
    sqrt(pow(a.real[x], 2) + pow(a.imag[x], 2)),
    sqrt(pow(b.real[x], 2) + pow(b.imag[x], 2)));
}

This is great in that for mismatches it reports the values that were compared, e.g. 5 != 7, but it does not report the index variable "x". Is there some way I can easily output the index variable when mismatch is detected?


Solution

  • From https://github.com/google/googletest/blob/main/docs/primer.md:

    To provide a custom failure message, simply stream it into the macro using the << operator, or a sequence of such operators.

    So if you wanted to output what your index is for the expect equal, you would do something like:

    EXPECT_EQ(
      sqrt(pow(a.real[x], 2) + pow(a.imag[x], 2)),
      sqrt(pow(b.real[x], 2) + pow(b.imag[x], 2))) << "x is : " << x << std::endl;