maint: don't specify XZ_OPT=-9ev in dist-related rule
[gnulib.git] / tests / test-hypotl.c
1 /* Test of hypotl() function.
2    Copyright (C) 2010-2012 Free Software Foundation, Inc.
3
4    This program is free software: you can redistribute it and/or modify
5    it under the terms of the GNU General Public License as published by
6    the Free Software Foundation; either version 3 of the License, or
7    (at your option) any later version.
8
9    This program 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
12    GNU General Public License for more details.
13
14    You should have received a copy of the GNU General Public License
15    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
16
17 /* Written by Bruno Haible <bruno@clisp.org>, 2010.  */
18
19 #include <config.h>
20
21 #include <math.h>
22
23 #include "signature.h"
24 SIGNATURE_CHECK (hypotl, long double, (long double, long double));
25
26 #include <float.h>
27
28 #include "macros.h"
29
30 volatile long double x;
31 volatile long double y;
32 long double z;
33
34 int
35 main ()
36 {
37   /* A particular value.  */
38   x = 0.4L;
39   y = 0.6L;
40   z = hypotl (x, y);
41   ASSERT (z >= 0.7211102550L && z <= 0.7211102551L);
42
43   /* Overflow.  */
44   x = LDBL_MAX;
45   y = LDBL_MAX * 0.5L;
46   z = hypotl (x, y);
47   ASSERT (z == HUGE_VALL);
48
49   /* No underflow.  */
50   x = LDBL_MIN;
51   y = 0.0L;
52   z = hypotl (x, y);
53   ASSERT (z == LDBL_MIN);
54
55   /* No underflow.  */
56   x = LDBL_MIN * 2.0L;
57   y = LDBL_MIN * 3.0L;
58   z = hypotl (x, y);
59   ASSERT (z >= LDBL_MIN * 2.0L && z <= LDBL_MIN * 4.0L);
60
61   return 0;
62 }