Blob Blame History Raw
From 517cd4f961c155284916fe393445adbe0e137d2b Mon Sep 17 00:00:00 2001
From: Elliott Sales de Andrade <quantum.analyst@gmail.com>
Date: Wed, 8 Aug 2018 00:03:32 -0400
Subject: [PATCH 1/2] Fix complex test.

Signed-off-by: Elliott Sales de Andrade <quantum.analyst@gmail.com>
---
 test/test_xcomplex.cpp | 17 +++++++++++++----
 1 file changed, 13 insertions(+), 4 deletions(-)

diff --git a/test/test_xcomplex.cpp b/test/test_xcomplex.cpp
index d238f33..a8a96c9 100644
--- a/test/test_xcomplex.cpp
+++ b/test/test_xcomplex.cpp
@@ -253,12 +253,21 @@ namespace xtl
     TEST(xcomplex, power)
     {
         complex_type c(1., 2.);
+        complex_type r, sr;
         std::complex<double> sc(c);
         double d = 1.5;
-        EXPECT_EQ(pow(c, c), complex_type(std::pow(sc, sc)));
-        EXPECT_EQ(pow(c, d), complex_type(std::pow(sc, d)));
-        EXPECT_EQ(pow(d, c), complex_type(std::pow(d, sc)));
-        EXPECT_EQ(sqrt(c), complex_type(std::sqrt(sc)));
+#define EXPECT_COMPLEX_EQ(a, b) \
+        do { \
+                r = a; \
+                sr = b; \
+                EXPECT_DOUBLE_EQ(r.real(), sr.real()); \
+                EXPECT_DOUBLE_EQ(r.imag(), sr.imag()); \
+        } while (0)
+        EXPECT_COMPLEX_EQ(pow(c, c), complex_type(std::pow(sc, sc)));
+        EXPECT_COMPLEX_EQ(pow(c, d), complex_type(std::pow(sc, d)));
+        EXPECT_COMPLEX_EQ(pow(d, c), complex_type(std::pow(d, sc)));
+        EXPECT_COMPLEX_EQ(sqrt(c), complex_type(std::sqrt(sc)));
+#undef EXPECT_COMPLEX_EQ
     }
 
     TEST(xcomplex, trigonometric)
-- 
2.17.1