efl
1/* EINA - EFL data type library
2* Copyright (C) 2017 Cedric Bail
3*
4* This library is free software; you can redistribute it and/or
5* modify it under the terms of the GNU Lesser General Public
6* License as published by the Free Software Foundation; either
7* version 2.1 of the License, or (at your option) any later version.
8*
9* This library is distributed in the hope that it will be useful,
10* but WITHOUT ANY WARRANTY; without even the implied warranty of
11* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12* Lesser General Public License for more details.
13*
14* You should have received a copy of the GNU Lesser General Public
15* License along with this library;
16* if not, see <http://www.gnu.org/licenses/>.
17*/
18
19EINA_TEST_START(eina_util_fpx)20{
21double a = 42.42, b = 42.41;22float c = 7.654, d = 8.765;23
24ck_assert_int_eq(eina_dbl_exact(a, b), EINA_FALSE);25ck_assert_int_eq(eina_dbl_exact(a, a), EINA_TRUE);26ck_assert_int_eq(eina_flt_exact(c, d), EINA_FALSE);27ck_assert_int_eq(eina_flt_exact(c, c), EINA_TRUE);28ck_assert_int_eq(eina_dbl_exact(a, c), EINA_FALSE);29}
30EINA_TEST_END
31
32EINA_TEST_START(eina_util_fpeq)33{
34double a, b, c;35double d, e, f;36
37a = 6.0 * 7.0 + 7.0;38b = 7.0 * 7.0;39c = a - 0.1;40
41d = 6.0 * 7.0 + 7.0;42e = 7.0 * 7.0;43f = a - 0.1;44
45ck_assert_int_ne(EINA_DBL_EQ(a, b), 0);46ck_assert_int_eq(EINA_DBL_EQ(a, c), 0);47ck_assert_int_ne(EINA_DBL_EQ(d, e), 0);48ck_assert_int_eq(EINA_DBL_EQ(d, f), 0);49}
50EINA_TEST_END
51
52EINA_TEST_START(eina_util_fpz)53{
54ck_assert_int_eq(EINA_FLT_NONZERO(7.0 - 7.0), 0);55ck_assert_int_ne(EINA_FLT_NONZERO(7.1 - 7.0), 0);56ck_assert_int_eq(EINA_FLT_NONZERO(0.0), 0);57ck_assert_int_eq(EINA_DBL_NONZERO(7.0 - 7.0), 0);58ck_assert_int_ne(EINA_DBL_NONZERO(7.1 - 7.0), 0);59ck_assert_int_eq(EINA_DBL_NONZERO(0.0), 0);60}
61EINA_TEST_END
62