gtest - Report index variable for loop with EXPECT_EQ
Asked Answered
P

2

8

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?

Poor answered 13/6, 2018 at 18:23 Comment(0)
V
10

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;
Vola answered 13/6, 2018 at 19:34 Comment(0)
F
3

SCOPED_TRACE (https://github.com/google/googletest/blob/main/docs/advanced.md#adding-traces-to-assertions) can be used, like:

for (int x = 0; x < a.size(); x++) {
  SCOPED_TRACE("x = " + std::to_string(x));
  EXPECT_EQ(
  ...

It's especially useful when there are more than one check:

for (int x = 0; x < a.size(); x++) {
  SCOPED_TRACE("x = " + std::to_string(x));
  EXPECT_EQ(...
  EXPECT_EQ(...
Fourscore answered 25/11, 2021 at 9:39 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.