the Compartmented Robust Posix C++ Unit Test system

ASSERT_EQ(a, b)

Assert that two expressions are equal.

Used in: A test function body, the constructor or destructor of a fixture, or a function called from them. See TEST(name, ...).

Requirement: The expression (a == b) can be evaluated as a bool.

The assertion succeeds if, and only if, the expression bool(a == b) evaluates to true.

On success the test continues without side effects.

On failure the test is terminated with an error report. The report includes the exact parameter text for each parameter and, when they are output streamable, a text representation of each expression value, or a byte by byte hex dump otherwise.

See also: VERIFY_EQ(a, b)

Example: The test program

     
     #include <crpcut.hpp>
     
     struct a {
       a(int val) : n(val) {}
       int n;
       operator int() const { return n; }
     };
     
     TEST(assert_eq_succeeds)
     {
       a val1(3);
       int val2 = 5;
       ASSERT_EQ(val1, val2 - 2);
     }
     
     TEST(assert_eq_fails)
     {
       a val1(3);
       int val2 = 4;
       ASSERT_EQ(val1, val2 - 2);
     }
     
     int main(int argc, char *argv[])
     {
       return crpcut::run(argc, argv);
     }

reports one failed test:


     FAILED!: assert_eq_fails
     phase="running"  --------------------------------------------------------------
     samples/assert_eq_fails.cpp:47
     ASSERT_EQ(val1, val2 - 2)
       where val1 = 4-byte object <0300 0000>
             val2 - 2 = 2
     -------------------------------------------------------------------------------
     ===============================================================================
     2 test cases selected
     
                    Sum   Critical   Non-critical
     PASSED   :       1          1              0
     FAILED   :       1          1              0