summaryrefslogtreecommitdiffstats
path: root/js/src/tests/non262/Math/15.8.2.4.js
blob: ee957aa93e5309151092d59eb86e340537af566f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/* -*- tab-width: 2; indent-tabs-mode: nil; js-indent-level: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */


/**
   File Name:          15.8.2.4.js
   ECMA Section:       15.8.2.4 atan( x )
   Description:        return an approximation to the arc tangent of the
   argument.  the result is expressed in radians and
   range is from -PI/2 to +PI/2.  special cases:
   - if x is NaN,  the result is NaN
   - if x == +0,   the result is +0
   - if x == -0,   the result is -0
   - if x == +Infinity,    the result is approximately +PI/2
   - if x == -Infinity,    the result is approximately -PI/2
   Author:             christine@netscape.com
   Date:               7 july 1997

*/

var SECTION = "15.8.2.4";
var TITLE   = "Math.atan()";
var BUGNUMBER="77391";

printBugNumber(BUGNUMBER);

writeHeaderToLog( SECTION + " "+ TITLE);

new TestCase(
	      "Math.atan.length",
	      1,
	      Math.atan.length );

new TestCase(
	      "Math.atan()",
	      Number.NaN,
	      Math.atan() );

new TestCase(
	      "Math.atan(void 0)",
	      Number.NaN,
	      Math.atan(void 0) );

new TestCase(
	      "Math.atan(null)",
	      0,
	      Math.atan(null) );

new TestCase(
	      "Math.atan(NaN)",
	      Number.NaN,
	      Math.atan(Number.NaN) );

new TestCase(
	      "Math.atan('a string')",
	      Number.NaN,
	      Math.atan("a string") );

new TestCase(
	      "Math.atan('0')",
	      0,
	      Math.atan('0') );

new TestCase(
	      "Math.atan('1')",
	      Math.PI/4,
	      Math.atan('1') );

new TestCase(
	      "Math.atan('-1')",
	      -Math.PI/4,
	      Math.atan('-1') );

new TestCase(
	      "Math.atan('Infinity)",
	      Math.PI/2,
	      Math.atan('Infinity') );

new TestCase(
	      "Math.atan('-Infinity)",
	      -Math.PI/2,
	      Math.atan('-Infinity') );

new TestCase(
	      "Math.atan(0)",
	      0,
	      Math.atan(0)          );

new TestCase(
	      "Math.atan(-0)",	
	      -0,
	      Math.atan(-0)         );

new TestCase(
	      "Infinity/Math.atan(-0)",
	      -Infinity,
	      Infinity/Math.atan(-0) );

new TestCase(
	      "Math.atan(Infinity)",
	      Math.PI/2,
	      Math.atan(Number.POSITIVE_INFINITY) );

new TestCase(
	      "Math.atan(-Infinity)",
	      -Math.PI/2,
	      Math.atan(Number.NEGATIVE_INFINITY) );

new TestCase(
	      "Math.atan(1)",
	      Math.PI/4,
	      Math.atan(1)          );

new TestCase(
	      "Math.atan(-1)",
	      -Math.PI/4,
	      Math.atan(-1)         );

test();