S12.10_A1.11_T1.js (3753B)
1 // Copyright 2009 the Sputnik authors. All rights reserved. 2 // This code is governed by the BSD license found in the LICENSE file. 3 4 /*--- 5 info: | 6 The with statement adds a computed object to the front of the 7 scope chain of the current execution context 8 es5id: 12.10_A1.11_T1 9 description: > 10 Calling a function within "with" statement declared without the 11 statement, leading to normal completion 12 flags: [noStrict] 13 ---*/ 14 15 this.p1 = 1; 16 this.p2 = 2; 17 this.p3 = 3; 18 var result = "result"; 19 var myObj = {p1: 'a', 20 p2: 'b', 21 p3: 'c', 22 value: 'myObj_value', 23 valueOf : function(){return 'obj_valueOf';}, 24 parseInt : function(){return 'obj_parseInt';}, 25 NaN : 'obj_NaN', 26 Infinity : 'obj_Infinity', 27 eval : function(){return 'obj_eval';}, 28 parseFloat : function(){return 'obj_parseFloat';}, 29 isNaN : function(){return 'obj_isNaN';}, 30 isFinite : function(){return 'obj_isFinite';} 31 } 32 var del; 33 var st_p1 = "p1"; 34 var st_p2 = "p2"; 35 var st_p3 = "p3"; 36 var st_parseInt = "parseInt"; 37 var st_NaN = "NaN"; 38 var st_Infinity = "Infinity"; 39 var st_eval = "eval"; 40 var st_parseFloat = "parseFloat"; 41 var st_isNaN = "isNaN"; 42 var st_isFinite = "isFinite"; 43 44 var f = function(){ 45 st_p1 = p1; 46 st_p2 = p2; 47 st_p3 = p3; 48 st_parseInt = parseInt; 49 st_NaN = NaN; 50 st_Infinity = Infinity; 51 st_eval = eval; 52 st_parseFloat = parseFloat; 53 st_isNaN = isNaN; 54 st_isFinite = isFinite; 55 p1 = 'x1'; 56 this.p2 = 'x2'; 57 del = delete p3; 58 var p4 = 'x4'; 59 p5 = 'x5'; 60 var value = 'value'; 61 } 62 63 with(myObj){ 64 f(); 65 } 66 67 if(!(p1 === "x1")){ 68 throw new Test262Error('#1: p1 === "x1". Actual: p1 ==='+ p1 ); 69 } 70 71 if(!(p2 === "x2")){ 72 throw new Test262Error('#2: p2 === "x2". Actual: p2 ==='+ p2 ); 73 } 74 75 try{ 76 p3; 77 throw new Test262Error('#3: p3 is nod defined'); 78 } 79 catch(e){ 80 } 81 82 try { 83 p4; 84 throw new Test262Error('#4: p4 is not defined'); 85 } catch(e) { 86 } 87 88 if(!(p5 === "x5")){ 89 throw new Test262Error('#5: p5 === "x5". Actual: p5 ==='+ p5 ); 90 } 91 92 if(!(myObj.p1 === "a")){ 93 throw new Test262Error('#6: myObj.p1 === "a". Actual: myObj.p1 ==='+ myObj.p1 ); 94 } 95 96 if(!(myObj.p2 === "b")){ 97 throw new Test262Error('#7: myObj.p2 === "b". Actual: myObj.p2 ==='+ myObj.p2 ); 98 } 99 100 if(!(myObj.p3 === "c")){ 101 throw new Test262Error('#8: myObj.p3 === "c". Actual: myObj.p3 ==='+ myObj.p3 ); 102 } 103 104 if(!(myObj.p4 === undefined)){ 105 throw new Test262Error('#9: myObj.p4 === undefined. Actual: myObj.p4 ==='+ myObj.p4 ); 106 } 107 108 if(!(myObj.p5 === undefined)){ 109 throw new Test262Error('#10: myObj.p5 === undefined. Actual: myObj.p5 ==='+ myObj.p5 ); 110 } 111 112 if(!(st_parseInt === parseInt)){ 113 throw new Test262Error('#11: st_parseInt === parseInt. Actual: st_parseInt ==='+ st_parseInt ); 114 } 115 116 assert.sameValue(st_NaN, NaN, "st_NaN is NaN"); 117 118 if(!(st_Infinity === Infinity)){ 119 throw new Test262Error('#13: st_Infinity === Infinity. Actual: st_Infinity ==='+ st_Infinity ); 120 } 121 122 if(!(st_eval === eval)){ 123 throw new Test262Error('#14: st_eval === eval. Actual: st_eval ==='+ st_eval ); 124 } 125 126 if(!(st_parseFloat === parseFloat)){ 127 throw new Test262Error('#15: st_parseFloat === parseFloat. Actual: st_parseFloat ==='+ st_parseFloat ); 128 } 129 130 if(!(st_isNaN === isNaN)){ 131 throw new Test262Error('#16: st_isNaN === isNaN. Actual: st_isNaN ==='+ st_isNaN ); 132 } 133 134 if(!(st_isFinite === isFinite)){ 135 throw new Test262Error('#17: st_isFinite === isFinite. Actual: st_isFinite ==='+ st_isFinite ); 136 } 137 138 try { 139 value; 140 throw new Test262Error('#18: value is not defined'); 141 } catch(e) { 142 } 143 144 if(!(myObj.value === "myObj_value")){ 145 throw new Test262Error('#19: myObj.value === "myObj_value". Actual: myObj.value ==='+ myObj.value ); 146 } 147 148 reportCompare(0, 0);