From 36d22d82aa202bb199967e9512281e9a53db42c9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 21:33:14 +0200 Subject: Adding upstream version 115.7.0esr. Signed-off-by: Daniel Baumann --- .../language/statements/try/S12.14_A11_T2.js | 125 +++++++++++++++++++++ 1 file changed, 125 insertions(+) create mode 100644 js/src/tests/test262/language/statements/try/S12.14_A11_T2.js (limited to 'js/src/tests/test262/language/statements/try/S12.14_A11_T2.js') diff --git a/js/src/tests/test262/language/statements/try/S12.14_A11_T2.js b/js/src/tests/test262/language/statements/try/S12.14_A11_T2.js new file mode 100644 index 0000000000..20089d9a78 --- /dev/null +++ b/js/src/tests/test262/language/statements/try/S12.14_A11_T2.js @@ -0,0 +1,125 @@ +// Copyright 2009 the Sputnik authors. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. + +/*--- +info: | + Using "try" with "catch" or "finally" statement within/without a "for" + statement +es5id: 12.14_A11_T2 +description: Try statement inside loop, where use continue loop +---*/ + +// CHECK#1 +var fin=0; +for(var i=0;i<5;i++){ + try{ + i+=1; + continue; + } + catch(er1){} + finally{ + fin=1; + } + fin=-1; +} +if(fin!==1){ + throw new Test262Error('#1: "finally" block must be evaluated at "try{continue} catch finally" construction'); +} + +// CHECK#2 +var c2=0,fin2=0; +for(var i=0;i<5;i++){ + try{ + throw "ex1"; + } + catch(er1){ + c2+=1; + continue; + } + finally{ + fin2=1; + } + fin2=-1; +} +if(fin2!==1){ + throw new Test262Error('#2.1: "finally" block must be evaluated'); +} +if(c2!==5){ + throw new Test262Error('#2.1: "try catch{continue} finally" must work correctly'); +} + +// CHECK#3 +var c3=0,fin3=0; +for(var i=0;i<5;i++){ + try{ + throw "ex1"; + } + catch(er1){ + c3+=1; + } + finally{ + fin3=1; + continue; + } + fin3=0; +} +if(fin3!==1){ + throw new Test262Error('#3.1: "finally" block must be evaluated'); +} +if(c3!==5){ + throw new Test262Error('#3.2: "try catch finally{continue}" must work correctly'); +} + +// CHECK#4 +var fin=0; +for(var i=0;i<5;i++){ + try{ + i+=1; + continue; + } + finally{ + fin=1; + } + fin=-1; +}; +if(fin!==1){ + throw new Test262Error('#4: "finally" block must be evaluated at "try{continue} finally" construction'); +} + +// CHECK#5 +var c5=0; +for(var c5=0;c5<10;){ + try{ + throw "ex1"; + } + catch(er1){ + c5+=1; + continue; + } + c5+=12; +}; +if(c5!==10){ + throw new Test262Error('#5: "try catch{continue} must work correctly'); +} + +// CHECK#6 +var c6=0,fin6=0; +for(var c6=0;c6<10;){ + try{ + c6+=1; + throw "ex1" + } + finally{ + fin6=1; + continue; + } + fin6=-1; +}; +if(fin6!==1){ + throw new Test262Error('#6.1: "finally" block must be evaluated'); +} +if(c6!==10){ + throw new Test262Error('#6.2: "try finally{continue}" must work correctly'); +} + +reportCompare(0, 0); -- cgit v1.2.3