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