summaryrefslogtreecommitdiffstats
path: root/tests/math_test.cpp
diff options
context:
space:
mode:
authorCalin Juravle <calin@google.com>2014-04-01 16:45:53 +0100
committerCalin Juravle <calin@google.com>2014-04-02 21:54:39 +0100
commitd8d6feed3add3965f481dcdd6e1bb259a46f21c2 (patch)
tree14361f2be3d0195e28ce8cc50ad08f71e95f772e /tests/math_test.cpp
parentb7afa9df2552c6a6889a43c6a1722e1ce46f1969 (diff)
downloadbionic-d8d6feed3add3965f481dcdd6e1bb259a46f21c2.zip
bionic-d8d6feed3add3965f481dcdd6e1bb259a46f21c2.tar.gz
bionic-d8d6feed3add3965f481dcdd6e1bb259a46f21c2.tar.bz2
Fix modf* tests
Use a value that can be exactly represented. Change-Id: Idf3b1db5e6042fb49c1f591f25f9eee656659ece
Diffstat (limited to 'tests/math_test.cpp')
-rw-r--r--tests/math_test.cpp27
1 files changed, 7 insertions, 20 deletions
diff --git a/tests/math_test.cpp b/tests/math_test.cpp
index 084ea0c..7734018 100644
--- a/tests/math_test.cpp
+++ b/tests/math_test.cpp
@@ -1224,36 +1224,23 @@ TEST(math, frexpl) {
TEST(math, modf) {
double di;
- double df = modf(123.456, &di);
+ double df = modf(123.75, &di);
ASSERT_DOUBLE_EQ(123.0, di);
- // ASSERT_DOUBLE uses more decimals than the double precision when performing
- // the comparison which can result in false failures. And it seems that modf
- // results are not 100% precise as expected but within the acceptable delta.
- // Work around this by tweaking the expected value (taken) from the result of
- // glibc modf).
- ASSERT_DOUBLE_EQ(0.45600000000000307, df);
+ ASSERT_DOUBLE_EQ(0.75, df);
}
TEST(math, modff) {
float fi;
- float ff = modff(123.456f, &fi);
+ float ff = modff(123.75f, &fi);
ASSERT_FLOAT_EQ(123.0f, fi);
- // See modf comment on why we don't use 0.456f as an excepted value.
- ASSERT_FLOAT_EQ(0.45600128f, ff);
+ ASSERT_FLOAT_EQ(0.75f, ff);
}
TEST(math, modfl) {
long double ldi;
- long double ldf = modfl(123.456l, &ldi);
- ASSERT_DOUBLE_EQ(123.0l, ldi);
- // See modf comment on why we don't use 0.456l as an excepted value when the
- // modf == modfl. For LP64, where long double != double, modfl algorithm
- // gives precise results and thus we don't need to tweak the expected value.
-#if defined(__LP64__) || !defined(__BIONIC__)
- ASSERT_DOUBLE_EQ(0.456l, ldf);
-#else
- ASSERT_DOUBLE_EQ(0.45600000000000307, ldf);
-#endif // __LP64__ || !__BIONIC__
+ long double ldf = modfl(123.75L, &ldi);
+ ASSERT_DOUBLE_EQ(123.0L, ldi);
+ ASSERT_DOUBLE_EQ(0.75L, ldf);
}
TEST(math, remquo) {