summaryrefslogtreecommitdiffstats
path: root/js/src/tests/non262/Math/15.8.2.8.js
blob: 78f7eb78982d160488d25c30f4e7e33dbabe9d11 (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
/* -*- 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.8.js
   ECMA Section:       15.8.2.8  Math.exp(x)
   Description:        return an approximation to the exponential function of
   the argument (e raised to the power of the argument)
   special cases:
   -   if x is NaN         return NaN
   -   if x is 0           return 1
   -   if x is -0          return 1
   -   if x is Infinity    return Infinity
   -   if x is -Infinity   return 0
   Author:             christine@netscape.com
   Date:               7 july 1997
*/


var SECTION = "15.8.2.8";
var TITLE   = "Math.exp(x)";

writeHeaderToLog( SECTION + " "+ TITLE);

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

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

new TestCase( "Math.exp(null)",
	      1,
	      Math.exp(null) );

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

new TestCase( "Math.exp(1)",
	      Math.E,
	      Math.exp(1) );

new TestCase( "Math.exp(true)",
	      Math.E,
	      Math.exp(true) );

new TestCase( "Math.exp(false)",
	      1,
	      Math.exp(false) );

new TestCase( "Math.exp('1')",
	      Math.E,
	      Math.exp('1') );

new TestCase( "Math.exp('0')",
	      1,
	      Math.exp('0') );

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

new TestCase( "Math.exp(0)",
	      1,
	      Math.exp(0)          );

new TestCase( "Math.exp(-0)",
	      1,
	      Math.exp(-0)         );

new TestCase( "Math.exp(Infinity)",
	      Number.POSITIVE_INFINITY,
	      Math.exp(Number.POSITIVE_INFINITY) );

new TestCase( "Math.exp(-Infinity)", 
	      0,
	      Math.exp(Number.NEGATIVE_INFINITY) );

test();