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_A9_T3.js | 162 +++++++++++++++++++++ 1 file changed, 162 insertions(+) create mode 100644 js/src/tests/test262/language/statements/try/S12.14_A9_T3.js (limited to 'js/src/tests/test262/language/statements/try/S12.14_A9_T3.js') diff --git a/js/src/tests/test262/language/statements/try/S12.14_A9_T3.js b/js/src/tests/test262/language/statements/try/S12.14_A9_T3.js new file mode 100644 index 0000000000..2489cebd21 --- /dev/null +++ b/js/src/tests/test262/language/statements/try/S12.14_A9_T3.js @@ -0,0 +1,162 @@ +// Copyright 2009 the Sputnik authors. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. + +/*--- +info: | + "try" with "catch" or "finally" statement within/without an "do while" + statement +es5id: 12.14_A9_T3 +description: > + "try" statement within a loop, the statement contains "break" + statement +---*/ + +// CHECK#1 +var c1=0,fin=0; +do{ + try{ + c1+=1; + break; + } + catch(er1){} + finally{ + fin=1; + } + fin=-1; + c1+=2; +} +while(c1<2); +if(fin!==1){ + throw new Test262Error('#1.1: "finally" block must be evaluated'); +} +if(c1!==1){ + throw new Test262Error('#1.2: "try{break}catch finally" must work correctly'); +} + +// CHECK#2 +var c2=0,fin2=0; +do{ + try{ + throw "ex1"; + } + catch(er1){ + c2+=1; + break; + } + finally{ + fin2=1; + } + c2+=2; + fin2=-1; +} +while(c2<2); +if(fin2!==1){ + throw new Test262Error('#2.1: "finally" block must be evaluated'); +} +if(c2!==1){ + throw new Test262Error('#2.2: "try catch{break} finally" must work correctly'); +} + +// CHECK#3 +var c3=0,fin3=0; +do{ + try{ + throw "ex1"; + } + catch(er1){ + c3+=1; + } + finally{ + fin3=1; + break; + } + c3+=2; + fin3=0; +} +while(c3<2); +if(fin3!==1){ + throw new Test262Error('#3.1: "finally" block must be evaluated'); +} +if(c3!==1){ + throw new Test262Error('#3.2: "try catch finally{break}" must work correctly'); +} + +// CHECK#4 +var c4=0,fin4=0; +do{ + try{ + c4+=1; + break; + } + finally{ + fin4=1; + } + fin4=-1; + c4+=2; +} +while(c4<2); +if(fin4!==1){ + throw new Test262Error('#4.1: "finally" block must be evaluated'); +} +if(c4!==1){ + throw new Test262Error('#4.2: "try{break} finally" must work correctly'); +} + +// CHECK#5 +var c5=0; +do{ + try{ + throw "ex1"; + } + catch(er1){ + break; + } +} +while(c5<2); +if(c5!==0){ + throw new Test262Error('#5: "try catch{break}" must work correctly'); +} + +// CHECK#6 +var c6=0; +do{ + try{ + c6+=1; + break; + } + catch(er1){} + c6+=2; +} +while(c6<2); +if(c6!==1){ + throw new Test262Error('#6: "try{break} catch" must work correctly'); +} + +// CHECK#7 +var c7=0,fin7=0; +try{ + do{ + try{ + c7+=1; + throw "ex1"; + } + finally{ + fin7=1; + break; + } + fin7=-1; + c7+=2; + } + while(c7<2); +} +catch(ex1){ + c7=10; +} +if(fin7!==1){ + throw new Test262Error('#7.1: "finally" block must be evaluated'); +} +if(c7!==1){ + throw new Test262Error('#7.2: try finally{break} error'); +} + +reportCompare(0, 0); -- cgit v1.2.3