blob: 8d86825651638ec820fb7a0adad65d9ba848f717 (
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
|
// Copyright 2009 the Sputnik authors. All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/**
* @name: S15.7.4.5_A1.3_T01;
* @section: 15.7.4.5;
* @assertion: Step 4: If this number value is NaN, return the string "NaN";
* @description: NaN is computed by new Number("string");
*/
//CHECK#1
if((new Number("a")).toFixed() !== "NaN"){
$ERROR('#1: (new Number("a")).prototype.toFixed() === "NaN"');
}
//CHECK#2
if((new Number("a")).toFixed(0) !== "NaN"){
$ERROR('#2: (new Number("a")).prototype.toFixed(0) === "NaN"');
}
//CHECK#3
if((new Number("a")).toFixed(1) !== "NaN"){
$ERROR('#3: (new Number("a")).prototype.toFixed(1) === "NaN"');
}
//CHECK#4
if((new Number("a")).toFixed(1.1) !== "NaN"){
$ERROR('#4: (new Number("a")).toFixed(1.1) === "NaN"');
}
//CHECK#5
if((new Number("a")).toFixed(0.9) !== "NaN"){
$ERROR('#5: (new Number("a")).toFixed(0.9) === "NaN"');
}
//CHECK#6
if((new Number("a")).toFixed("1") !== "NaN"){
$ERROR('#6: (new Number("a")).toFixed("1") === "NaN"');
}
//CHECK#7
if((new Number("a")).toFixed("1.1") !== "NaN"){
$ERROR('#7: (new Number("a")).toFixed("1.1") === "NaN"');
}
//CHECK#8
if((new Number("a")).toFixed("0.9") !== "NaN"){
$ERROR('#8: (new Number("a")).toFixed("0.9") === "NaN"');
}
//CHECK#9
if((new Number("a")).toFixed(Number.NaN) !== "NaN"){
$ERROR('#9: (new Number("a")).toFixed(Number.NaN) === "NaN"');
}
//CHECK#10
if((new Number("a")).toFixed("some string") !== "NaN"){
$ERROR('#9: (new Number("a")).toFixed("some string") === "NaN"');
}
//CHECK#10
try{
s = (new Number("a")).toFixed(Number.POSITIVE_INFINITY);
$ERROR('#10: (new Number("a")).toFixed(Number.POSITIVE_INFINITY) should throw RangeError, not return NaN');
}
catch(e){
if(!(e instanceof RangeError)){
$ERROR('#10: (new Number("a")).toFixed(Number.POSITIVE_INFINITY) should throw RangeError, not '+e);
}
}
|