summaryrefslogtreecommitdiff
path: root/tests/test-floorl.c
diff options
context:
space:
mode:
authorBruno Haible <bruno@clisp.org>2007-10-05 03:34:16 +0200
committerBruno Haible <bruno@clisp.org>2007-10-05 03:34:16 +0200
commit3b63293b88852539e9df5eab6e4e056878cfb650 (patch)
treef56230f67edcfa6825d65c7750c8124f3f62c0e9 /tests/test-floorl.c
parent33f47a8259736ab62fb8f2a3b548e2c0f67ddd97 (diff)
downloadgnulib-3b63293b88852539e9df5eab6e4e056878cfb650.tar.gz
Test for module 'floorl'.
Diffstat (limited to 'tests/test-floorl.c')
-rw-r--r--tests/test-floorl.c79
1 files changed, 79 insertions, 0 deletions
diff --git a/tests/test-floorl.c b/tests/test-floorl.c
new file mode 100644
index 0000000000..5baf36230b
--- /dev/null
+++ b/tests/test-floorl.c
@@ -0,0 +1,79 @@
+/* Test of rounding towards negative infinity.
+ Copyright (C) 2007 Free Software Foundation, Inc.
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2, or (at your option)
+ any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software Foundation,
+ Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */
+
+/* Written by Bruno Haible <bruno@clisp.org>, 2007. */
+
+#include <config.h>
+
+#include <math.h>
+
+#include <stdio.h>
+#include <stdlib.h>
+
+#include "fpucw.h"
+#include "isnanl-nolibm.h"
+
+#define ASSERT(expr) \
+ do \
+ { \
+ if (!(expr)) \
+ { \
+ fprintf (stderr, "%s:%d: assertion failed\n", __FILE__, __LINE__); \
+ abort (); \
+ } \
+ } \
+ while (0)
+
+int
+main ()
+{
+ DECL_LONG_DOUBLE_ROUNDING
+
+ BEGIN_LONG_DOUBLE_ROUNDING ();
+
+ /* Zero. */
+ ASSERT (floorl (0.0L) == 0.0L);
+ ASSERT (floorl (-0.0L) == 0.0L);
+ /* Positive numbers. */
+ ASSERT (floorl (0.3L) == 0.0L);
+ ASSERT (floorl (0.7L) == 0.0L);
+ ASSERT (floorl (1.0L) == 1.0L);
+ ASSERT (floorl (1.5L) == 1.0L);
+ ASSERT (floorl (1.999L) == 1.0L);
+ ASSERT (floorl (2.0L) == 2.0L);
+ ASSERT (floorl (65535.999L) == 65535.0L);
+ ASSERT (floorl (65536.0L) == 65536.0L);
+ ASSERT (floorl (2.341e31L) == 2.341e31L);
+ /* Negative numbers. */
+ ASSERT (floorl (-0.3L) == -1.0L);
+ ASSERT (floorl (-0.7L) == -1.0L);
+ ASSERT (floorl (-1.0L) == -1.0L);
+ ASSERT (floorl (-1.001L) == -2.0L);
+ ASSERT (floorl (-1.5L) == -2.0L);
+ ASSERT (floorl (-1.999L) == -2.0L);
+ ASSERT (floorl (-2.0L) == -2.0L);
+ ASSERT (floorl (-65535.999L) == -65536.0L);
+ ASSERT (floorl (-65536.0L) == -65536.0L);
+ ASSERT (floorl (-2.341e31L) == -2.341e31L);
+ /* Infinite numbers. */
+ ASSERT (floorl (1.0L / 0.0L) == 1.0L / 0.0L);
+ ASSERT (floorl (-1.0L / 0.0L) == -1.0L / 0.0L);
+ /* NaNs. */
+ ASSERT (isnanl (floorl (0.0L / 0.0L)));
+
+ return 0;
+}