summaryrefslogtreecommitdiff
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
parent33f47a8259736ab62fb8f2a3b548e2c0f67ddd97 (diff)
downloadgnulib-3b63293b88852539e9df5eab6e4e056878cfb650.tar.gz
Test for module 'floorl'.
-rw-r--r--ChangeLog3
-rw-r--r--modules/floorl-tests16
-rw-r--r--tests/test-floorl.c79
3 files changed, 98 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index d7033bf1a9..ae0545ccd3 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
2007-10-04 Bruno Haible <bruno@clisp.org>
+ * modules/floorl-tests: New file.
+ * tests/test-floorl.c: New file.
+
* modules/floorl: New file.
* lib/floorl.c: Replace entire file.
* m4/floorl.m4: New file.
diff --git a/modules/floorl-tests b/modules/floorl-tests
new file mode 100644
index 0000000000..4354d663b4
--- /dev/null
+++ b/modules/floorl-tests
@@ -0,0 +1,16 @@
+Files:
+tests/test-floorl.c
+
+Depends-on:
+fpucw
+isnanl-nolibm
+
+configure.ac:
+
+Makefile.am:
+TESTS += test-floorl
+check_PROGRAMS += test-floorl
+test_floorl_LDADD = $(LDADD) @FLOORL_LIBM@
+
+License:
+LGPL
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;
+}