From bd9b40bbfb53164abbac90ad982636fdc76ae10d Mon Sep 17 00:00:00 2001 From: Pavel Punegov Date: Mon, 3 Mar 2014 18:17:00 +0400 Subject: [PATCH] 6946101: ShellScaffold.sh based tests can issue "write error: Broken pipe" messages Reviewed-by: dcubed, sla --- jdk/test/com/sun/jdi/ArrayLengthDumpTest.sh | 4 +- jdk/test/com/sun/jdi/CatchAllTest.sh | 4 +- jdk/test/com/sun/jdi/CatchCaughtTest.sh | 4 +- jdk/test/com/sun/jdi/CatchPatternTest.sh | 5 +- .../com/sun/jdi/CommandCommentDelimiter.sh | 4 +- jdk/test/com/sun/jdi/DeferredStepTest.sh | 3 +- jdk/test/com/sun/jdi/DeoptimizeWalk.sh | 7 +- jdk/test/com/sun/jdi/EvalArgs.sh | 4 +- .../com/sun/jdi/GetLocalVariables3Test.sh | 4 +- .../com/sun/jdi/GetLocalVariables4Test.sh | 4 +- jdk/test/com/sun/jdi/JdbExprTest.sh | 4 +- jdk/test/com/sun/jdi/JdbLockTest.sh | 3 +- jdk/test/com/sun/jdi/JdbMethodExitTest.sh | 7 +- jdk/test/com/sun/jdi/JdbMissStep.sh | 3 +- jdk/test/com/sun/jdi/MixedSuspendTest.sh | 5 +- jdk/test/com/sun/jdi/NotAField.sh | 4 +- jdk/test/com/sun/jdi/NullLocalVariable.sh | 4 +- jdk/test/com/sun/jdi/Redefine-g.sh | 5 +- jdk/test/com/sun/jdi/RedefineAnnotation.sh | 4 +- .../com/sun/jdi/RedefineChangeClassOrder.sh | 4 +- jdk/test/com/sun/jdi/RedefineClasses.sh | 3 +- jdk/test/com/sun/jdi/RedefineException.sh | 5 +- jdk/test/com/sun/jdi/RedefineFinal.sh | 5 +- jdk/test/com/sun/jdi/RedefineImplementor.sh | 4 +- .../com/sun/jdi/RedefineIntConstantToLong.sh | 5 +- jdk/test/com/sun/jdi/RedefineMulti.sh | 5 +- jdk/test/com/sun/jdi/RedefinePop.sh | 5 +- jdk/test/com/sun/jdi/RedefineTTYLineNumber.sh | 4 +- jdk/test/com/sun/jdi/ShellScaffold.sh | 281 +++++++++++------- jdk/test/com/sun/jdi/StringConvertTest.sh | 5 +- jdk/test/com/sun/jdi/WatchFramePop.sh | 4 +- 31 files changed, 234 insertions(+), 178 deletions(-) diff --git a/jdk/test/com/sun/jdi/ArrayLengthDumpTest.sh b/jdk/test/com/sun/jdi/ArrayLengthDumpTest.sh index 9de6aed7412..a1f6b7c5a03 100644 --- a/jdk/test/com/sun/jdi/ArrayLengthDumpTest.sh +++ b/jdk/test/com/sun/jdi/ArrayLengthDumpTest.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -86,7 +86,7 @@ dojdbCmds() cmd dump this.t[1].length cmd dump ArrayLengthDumpTarg.i.length cmd dump this.length - cmd cont + cmd allowExit cont } mysetup() diff --git a/jdk/test/com/sun/jdi/CatchAllTest.sh b/jdk/test/com/sun/jdi/CatchAllTest.sh index aea6325dce2..19b70d99bc8 100644 --- a/jdk/test/com/sun/jdi/CatchAllTest.sh +++ b/jdk/test/com/sun/jdi/CatchAllTest.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -64,7 +64,7 @@ dojdbCmds() cmd ignore caught java.lang.IndexOutOfBoundsException cmd catch uncaught java.lang.IndexOutOfBoundsException cmd ignore uncaught java.lang.IndexOutOfBoundsException - cmd cont + cmd allowExit cont } mysetup() diff --git a/jdk/test/com/sun/jdi/CatchCaughtTest.sh b/jdk/test/com/sun/jdi/CatchCaughtTest.sh index 11fdcb66190..e1665283a55 100644 --- a/jdk/test/com/sun/jdi/CatchCaughtTest.sh +++ b/jdk/test/com/sun/jdi/CatchCaughtTest.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -55,7 +55,7 @@ dojdbCmds() setBkpts @1 runToBkpt @1 cmd catch caught - cmd cont + cmd allowExit cont } mysetup() diff --git a/jdk/test/com/sun/jdi/CatchPatternTest.sh b/jdk/test/com/sun/jdi/CatchPatternTest.sh index c2e18fb0500..b467d5c1e52 100644 --- a/jdk/test/com/sun/jdi/CatchPatternTest.sh +++ b/jdk/test/com/sun/jdi/CatchPatternTest.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -91,8 +91,7 @@ dojdbCmds() cmd cont cmd cont cmd ignore all java.lang.I* - cmd cont - cmd quit + cmd allowExit cont } mysetup() diff --git a/jdk/test/com/sun/jdi/CommandCommentDelimiter.sh b/jdk/test/com/sun/jdi/CommandCommentDelimiter.sh index f2cfc92c8e8..34f0942824b 100644 --- a/jdk/test/com/sun/jdi/CommandCommentDelimiter.sh +++ b/jdk/test/com/sun/jdi/CommandCommentDelimiter.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2004, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2004, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -58,7 +58,7 @@ dojdbCmds() cmd 3 \#blah cmd \# connectors cmd step - cmd cont + cmd allowExit cont } mysetup() diff --git a/jdk/test/com/sun/jdi/DeferredStepTest.sh b/jdk/test/com/sun/jdi/DeferredStepTest.sh index d7d1f4c7537..528404fefc7 100644 --- a/jdk/test/com/sun/jdi/DeferredStepTest.sh +++ b/jdk/test/com/sun/jdi/DeferredStepTest.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -129,7 +129,6 @@ dojdbCmds() cmd next; $sleepcmd cmd next; $sleepcmd cmd next; $sleepcmd - cmd quit } mysetup() diff --git a/jdk/test/com/sun/jdi/DeoptimizeWalk.sh b/jdk/test/com/sun/jdi/DeoptimizeWalk.sh index ffc005e8805..c8df10fac0f 100644 --- a/jdk/test/com/sun/jdi/DeoptimizeWalk.sh +++ b/jdk/test/com/sun/jdi/DeoptimizeWalk.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -66,7 +66,7 @@ public class $1 { a4(22); // it passes if this line is commented out System.out.println("jj"); } - + public void a4(int pp) { int v4 = 90; System.out.println("a4: @1 breakpoint here"); @@ -84,8 +84,6 @@ dojdbCmds() #cmd next cmd step cmd where - cmd quit - jdbFailIfNotPresent "shtest\.main" 3 } @@ -108,5 +106,6 @@ mysetup() mysetup runit +jdbFailIfNotPresent "shtest\.main" 3 debuggeeFailIfPresent "Internal exception:" pass diff --git a/jdk/test/com/sun/jdi/EvalArgs.sh b/jdk/test/com/sun/jdi/EvalArgs.sh index 53c1851b58d..aa3e75fdb74 100644 --- a/jdk/test/com/sun/jdi/EvalArgs.sh +++ b/jdk/test/com/sun/jdi/EvalArgs.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -291,8 +291,6 @@ dojdbCmds() cmd eval "$classname.ffjj2($classname.myoranges)" jdbFailIfNotPresent "InvalidTypeException" 3 - - cmd quit } diff --git a/jdk/test/com/sun/jdi/GetLocalVariables3Test.sh b/jdk/test/com/sun/jdi/GetLocalVariables3Test.sh index 6fce8b790ea..2910897d989 100644 --- a/jdk/test/com/sun/jdi/GetLocalVariables3Test.sh +++ b/jdk/test/com/sun/jdi/GetLocalVariables3Test.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -55,7 +55,7 @@ dojdbCmds() setBkpts @1 runToBkpt @1 cmd locals - cmd cont + cmd allowExit cont } mysetup() diff --git a/jdk/test/com/sun/jdi/GetLocalVariables4Test.sh b/jdk/test/com/sun/jdi/GetLocalVariables4Test.sh index 45ae52f691e..9af3409b96b 100644 --- a/jdk/test/com/sun/jdi/GetLocalVariables4Test.sh +++ b/jdk/test/com/sun/jdi/GetLocalVariables4Test.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -57,7 +57,7 @@ dojdbCmds() setBkpts @1 runToBkpt @1 cmd locals - cmd cont + cmd allowExit cont } mysetup() diff --git a/jdk/test/com/sun/jdi/JdbExprTest.sh b/jdk/test/com/sun/jdi/JdbExprTest.sh index 9645714dc08..ecfd9432aed 100644 --- a/jdk/test/com/sun/jdi/JdbExprTest.sh +++ b/jdk/test/com/sun/jdi/JdbExprTest.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2013, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -130,8 +130,6 @@ dojdbCmds() cmd print ~1 jdbFailIfNotPresent "~1 = -2" 3 - - cmd quit } diff --git a/jdk/test/com/sun/jdi/JdbLockTest.sh b/jdk/test/com/sun/jdi/JdbLockTest.sh index b6573a82a73..6558b98a679 100644 --- a/jdk/test/com/sun/jdi/JdbLockTest.sh +++ b/jdk/test/com/sun/jdi/JdbLockTest.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2003, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -83,7 +83,6 @@ dojdbCmds() # This should say that main owns the lock # and the sleeper thread is waiting for it. cmd lock $classname.jj - cmd quit } diff --git a/jdk/test/com/sun/jdi/JdbMethodExitTest.sh b/jdk/test/com/sun/jdi/JdbMethodExitTest.sh index ab00816ca6e..86a485ae418 100644 --- a/jdk/test/com/sun/jdi/JdbMethodExitTest.sh +++ b/jdk/test/com/sun/jdi/JdbMethodExitTest.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2004, 2005, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2004, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -232,7 +232,7 @@ dojdbCmds() cmd cont jdbFailIfNotPresent "instance of JdbMethodExitTest" jdbFailIfNotPresent "return value = 8" - + # Get out of bkpt back to the call to traceMethods cmd step up @@ -253,7 +253,7 @@ dojdbCmds() jdbFailIfNotPresent 'Method exited: .* JdbMethodExitTest.traceMethods1' cmd untrace cmd step up - + cmd trace method exits $threadid cmd cont @@ -282,7 +282,6 @@ dojdbCmds() cmd trace go method exit $threadid cmd cont jdbFailIfNotPresent 'Method exited: .*JdbMethodExitTest.traceExit1' - cmd quit } diff --git a/jdk/test/com/sun/jdi/JdbMissStep.sh b/jdk/test/com/sun/jdi/JdbMissStep.sh index a9c5fb5bccc..62c0f3eabf9 100644 --- a/jdk/test/com/sun/jdi/JdbMissStep.sh +++ b/jdk/test/com/sun/jdi/JdbMissStep.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, 2003, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -74,7 +74,6 @@ dojdbCmds() cmd stop at $classname'$jj2:20' runToBkpt cmd step - cmd quit } diff --git a/jdk/test/com/sun/jdi/MixedSuspendTest.sh b/jdk/test/com/sun/jdi/MixedSuspendTest.sh index 385b7de6a33..43d0057edfe 100644 --- a/jdk/test/com/sun/jdi/MixedSuspendTest.sh +++ b/jdk/test/com/sun/jdi/MixedSuspendTest.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2005, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2005, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -99,8 +99,7 @@ dojdbCmds() { setBkpts @1 runToBkpt @1 - cmd cont - cmd quit + cmd allowExit cont } diff --git a/jdk/test/com/sun/jdi/NotAField.sh b/jdk/test/com/sun/jdi/NotAField.sh index 20d9916613d..acc627c92ad 100644 --- a/jdk/test/com/sun/jdi/NotAField.sh +++ b/jdk/test/com/sun/jdi/NotAField.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, 2004, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -54,7 +54,7 @@ dojdbCmds() cmd print "java.lang.Class.reflectionFactory.hashCode()" #This should result in a ParseException: ("No such field in ..."): cmd print "java.lang.Class.reflectionFactory.hashCode" - cmd cont + cmd allowExit cont } mysetup() diff --git a/jdk/test/com/sun/jdi/NullLocalVariable.sh b/jdk/test/com/sun/jdi/NullLocalVariable.sh index 63bca9545c4..63c0c4aac38 100644 --- a/jdk/test/com/sun/jdi/NullLocalVariable.sh +++ b/jdk/test/com/sun/jdi/NullLocalVariable.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -59,7 +59,7 @@ dojdbCmds() cmd next ; $sleepcmd cmd next ; $sleepcmd cmd locals ; $sleepcmd - cmd cont + cmd allowExit cont } mysetup() diff --git a/jdk/test/com/sun/jdi/Redefine-g.sh b/jdk/test/com/sun/jdi/Redefine-g.sh index 7b518ed3c2a..5641709f412 100644 --- a/jdk/test/com/sun/jdi/Redefine-g.sh +++ b/jdk/test/com/sun/jdi/Redefine-g.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, 2003, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -88,8 +88,7 @@ dojdbCmds() cmd where cmd locals - cmd cont - cmd quit + cmd allowExit cont } diff --git a/jdk/test/com/sun/jdi/RedefineAnnotation.sh b/jdk/test/com/sun/jdi/RedefineAnnotation.sh index 77a69845e74..066e3d3eb4b 100644 --- a/jdk/test/com/sun/jdi/RedefineAnnotation.sh +++ b/jdk/test/com/sun/jdi/RedefineAnnotation.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2006, 2007, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2006, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -217,7 +217,7 @@ dojdbCmds() setBkpts @1 runToBkpt @1 redefineClass @1 - cmd cont + cmd allowExit cont } diff --git a/jdk/test/com/sun/jdi/RedefineChangeClassOrder.sh b/jdk/test/com/sun/jdi/RedefineChangeClassOrder.sh index 8d4b6287b8d..b14a42201b3 100644 --- a/jdk/test/com/sun/jdi/RedefineChangeClassOrder.sh +++ b/jdk/test/com/sun/jdi/RedefineChangeClassOrder.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2006, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2006, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -123,7 +123,7 @@ dojdbCmds() setBkpts @1 runToBkpt @1 redefineClass @1 - cmd cont + cmd allowExit cont } diff --git a/jdk/test/com/sun/jdi/RedefineClasses.sh b/jdk/test/com/sun/jdi/RedefineClasses.sh index e1d013a783e..f323712d305 100644 --- a/jdk/test/com/sun/jdi/RedefineClasses.sh +++ b/jdk/test/com/sun/jdi/RedefineClasses.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, 2007, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -134,7 +134,6 @@ dojdbCmds() cmd redefine $classname $tmpFileDir/$classname.class cmd redefine $classname $tmpFileDir/$classname.class cmd redefine $classname $tmpFileDir/$classname.class - cmd quit } diff --git a/jdk/test/com/sun/jdi/RedefineException.sh b/jdk/test/com/sun/jdi/RedefineException.sh index f66d2c5e456..e1bc0a3b215 100644 --- a/jdk/test/com/sun/jdi/RedefineException.sh +++ b/jdk/test/com/sun/jdi/RedefineException.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -92,8 +92,7 @@ dojdbCmds() runToBkpt redefineClass @1 cmd pop - cmd cont - cmd quit + cmd allowExit cont } diff --git a/jdk/test/com/sun/jdi/RedefineFinal.sh b/jdk/test/com/sun/jdi/RedefineFinal.sh index 80ec5254e4a..16381381b14 100644 --- a/jdk/test/com/sun/jdi/RedefineFinal.sh +++ b/jdk/test/com/sun/jdi/RedefineFinal.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, 2003, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -74,8 +74,7 @@ dojdbCmds() setBkpts @1 contToBkpt cmd where - cmd cont - cmd quit + cmd allowExit cont } diff --git a/jdk/test/com/sun/jdi/RedefineImplementor.sh b/jdk/test/com/sun/jdi/RedefineImplementor.sh index 4deb347f4b4..dd7f83e8a0c 100644 --- a/jdk/test/com/sun/jdi/RedefineImplementor.sh +++ b/jdk/test/com/sun/jdi/RedefineImplementor.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2006, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2006, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -69,7 +69,7 @@ dojdbCmds() setBkpts @1 runToBkpt @1 redefineClass @1 - cmd cont + cmd allowExit cont } diff --git a/jdk/test/com/sun/jdi/RedefineIntConstantToLong.sh b/jdk/test/com/sun/jdi/RedefineIntConstantToLong.sh index ab921c0cd48..4f384dff504 100644 --- a/jdk/test/com/sun/jdi/RedefineIntConstantToLong.sh +++ b/jdk/test/com/sun/jdi/RedefineIntConstantToLong.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2006, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2006, 2014 Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -89,8 +89,7 @@ dojdbCmds() setBkpts @1 contToBkpt cmd where - cmd cont - cmd quit + cmd allowExit cont } diff --git a/jdk/test/com/sun/jdi/RedefineMulti.sh b/jdk/test/com/sun/jdi/RedefineMulti.sh index a51c3b16398..e2736cb0b5f 100644 --- a/jdk/test/com/sun/jdi/RedefineMulti.sh +++ b/jdk/test/com/sun/jdi/RedefineMulti.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, 2003, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -126,8 +126,7 @@ dojdbCmds() setBkpts @1 contToBkpt redefineClass @2 - cmd cont - cmd quit + cmd allowExit cont } diff --git a/jdk/test/com/sun/jdi/RedefinePop.sh b/jdk/test/com/sun/jdi/RedefinePop.sh index 4059a1a9e5d..c92e83d2f70 100644 --- a/jdk/test/com/sun/jdi/RedefinePop.sh +++ b/jdk/test/com/sun/jdi/RedefinePop.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, 2005, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -74,8 +74,7 @@ dojdbCmds() runToBkpt @1 redefineClass @1 cmd pop - cmd cont - cmd quit + cmd allowExit cont } diff --git a/jdk/test/com/sun/jdi/RedefineTTYLineNumber.sh b/jdk/test/com/sun/jdi/RedefineTTYLineNumber.sh index addf45ca2b2..8bc7a845ef2 100644 --- a/jdk/test/com/sun/jdi/RedefineTTYLineNumber.sh +++ b/jdk/test/com/sun/jdi/RedefineTTYLineNumber.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, 2003, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -74,8 +74,6 @@ dojdbCmds() cmd stop in shtest.A contToBkpt #jdbFailIfNotPresent "System\.out\.println" 3 - cmd quit - } diff --git a/jdk/test/com/sun/jdi/ShellScaffold.sh b/jdk/test/com/sun/jdi/ShellScaffold.sh index 7bc063d44eb..eb3b65bf30b 100644 --- a/jdk/test/com/sun/jdi/ShellScaffold.sh +++ b/jdk/test/com/sun/jdi/ShellScaffold.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -190,11 +190,15 @@ killOrphans() echo "$1: kill -9 $toBeKilled" >& 2 kill -9 $toBeKilled fi -} +} +# Returns 0 if $1 is the pid of a running process findPid() { - # Return 0 if $1 is the pid of a running process. + if [ -z "$1" ] ; then + return 1 + fi + if [ -z "$isWin98" ] ; then if [ "$osname" = SunOS ] ; then # Solaris and OpenSolaris use pgrep and not ps in psCmd @@ -208,7 +212,7 @@ findPid() # cygwin ps puts an I in column 1 for some reason. findPidCmd="$psCmd -e" fi - $findPidCmd | $grep '^I* *'"$1 " > $devnull 2>&1 + $findPidCmd | $grep '^I* *'"$1 " > $devnull 2>&1 return $? fi @@ -245,56 +249,55 @@ setup() echo "--Error: TESTJAVA must be defined as the pathname of a jdk to test." exit 1 fi - + ulimitCmd= osname=`uname -s` isWin98= isCygwin= case "$osname" in - Windows* | CYGWIN*) - devnull=NUL - if [ "$osname" = Windows_98 -o "$osname" = Windows_ME ]; then - isWin98=1 - debuggeeKeyword='we_cant_kill_debuggees_on_win98' - jdbKeyword='jdb\.exe' - fi + Windows* | CYGWIN*) + devnull=NUL + if [ "$osname" = Windows_98 -o "$osname" = Windows_ME ]; then + isWin98=1 + debuggeeKeyword='we_cant_kill_debuggees_on_win98' + jdbKeyword='jdb\.exe' + fi + case "$osname" in + CYGWIN*) + isCygwin=1 + devnull=/dev/null + ;; + esac - case "$osname" in - CYGWIN*) - isCygwin=1 - devnull=/dev/null - ;; - esac - - if [ -r $jdk/bin/dt_shmem.dll -o -r $jdk/jre/bin/dt_shmem.dll ] ; then - transport=dt_shmem - address=kkkk.$$ - else - transport=dt_socket - address= - fi - baseArgs="$baseArgs -XX:-ShowMessageBoxOnError" - # jtreg puts \\s in TESTCLASSES and some uses, eg. echo - # treat them as control chars on mks (eg \t is tab) - # Oops; windows mks really seems to want this cat line - # to start in column 1 - if [ -w "$SystemRoot" ] ; then - tmpFile=$SystemRoot/tmp.$$ - elif [ -w "$SYSTEMROOT" ] ; then - tmpFile=$SYSTEMROOT/tmp.$$ - else - tmpFile=tmp.$$ - fi + if [ -r $jdk/bin/dt_shmem.dll -o -r $jdk/jre/bin/dt_shmem.dll ] ; then + transport=dt_shmem + address=kkkk.$$ + else + transport=dt_socket + address= + fi + baseArgs="$baseArgs -XX:-ShowMessageBoxOnError" + # jtreg puts \\s in TESTCLASSES and some uses, eg. echo + # treat them as control chars on mks (eg \t is tab) + # Oops; windows mks really seems to want this cat line + # to start in column 1 + if [ -w "$SystemRoot" ] ; then + tmpFile=$SystemRoot/tmp.$$ + elif [ -w "$SYSTEMROOT" ] ; then + tmpFile=$SYSTEMROOT/tmp.$$ + else + tmpFile=tmp.$$ + fi cat <$tmpFile $TESTCLASSES EOF - TESTCLASSES=`cat $tmpFile | sed -e 's@\\\\@/@g'` - rm -f $tmpFile - # on mks - grep=egrep - psCmd=ps - jstack=jstack.exe - ;; + TESTCLASSES=`cat $tmpFile | sed -e 's@\\\\@/@g'` + rm -f $tmpFile + # on mks + grep=egrep + psCmd=ps + jstack=jstack.exe + ;; SunOS | Linux | Darwin | AIX) transport=dt_socket address= @@ -378,7 +381,7 @@ EOF # linux same as above # win mks: No dice; processes still running trap "cleanup" 0 1 2 3 4 6 9 10 15 - + jdbOptions="$jdbOptions -J-D${jdbKeyword}" } @@ -397,7 +400,7 @@ docompile() cp $classname.java.1 $classname.java echo "--Compiling first version of `pwd`/$classname.java with options: $compileOptions" # Result is in $pkgSlash$classname.class - + if [ -z "$javacCmd" ] ; then javacCmd=$jdk/bin/javac fi @@ -523,29 +526,52 @@ docompile() # If it ever becomes necessary to send a jdb command before # a main[10] form of prompt appears, then this # code will have to be modified. -cmd() +# +# Specify $1 = allowExit to show that the command given +# allows JDB to exit +cmd() { - if [ $1 = quit -o -r "$failFile" ] ; then - # if jdb got a cont cmd that caused the debuggee - # to run to completion, jdb can be gone before - # we get here. - echo "--Sending cmd: quit" >& 2 - echo quit - # See 6562090. Maybe there is a way that the exit - # can cause jdb to not get the quit. - sleep 5 + allowExit= + case "$1" in + allowExit) + allowExit="allowExit" + shift + ;; + exitJdb) + # Quit JDB only with this cmd() invocation + echo "--Sending cmd: quit" >& 2 + echo quit + echo "--Quit cmd was sent" >& 2 + # See 6562090. Maybe there is a way that the exit + # can cause jdb to not get the quit. + sleep 5 - # The exit code value here doesn't matter since this function - # is called as part of a pipeline and it is not the last command - # in the pipeline. - exit 1 + # The exit code value here doesn't matter since this function + # is called as part of a pipeline and it is not the last command + # in the pipeline. + exit 1 + ;; + esac + command=$* + + if [ -z "$command" ] ; then + dofail "Command can't be a null string. Test failure" fi - + if [ "$command" = "quit" -o "$command" = "exit" ] ; then + # We don't want the test to manually quit jdb, + # we will do it in the end automatically + dofail "It's not allowed to send quit or exit commands from the test" + fi + if [ -r "$failFile" ] ; then + # failFile exists, it's better to finish execution + dofinish "quit" + fi + # $jdbOutFile always exists here and is non empty # because after starting jdb, we waited # for the prompt. fileSize=`wc -c $jdbOutFile | awk '{ print $1 }'` - echo "--Sending cmd: " $* >&2 + echo "--Sending cmd: " $command >&2 # jjh: We have a few intermittent failures here. # It is as if every so often, jdb doesn't @@ -570,7 +596,7 @@ cmd() # And, we know jdb is started because the main[1] output is in the .jtr # file. And, we wouldn't have gotten here if mydojdbcmds hadn't # seen the ]. - echo $* + echo $command # Now we have to wait for the next jdb prompt. We wait for a pattern # to appear in the last line of jdb output. Normally, the prompt is @@ -644,7 +670,7 @@ cmd() # wait for 4 new chars to appear in the jdb output count=0 desiredFileSize=`expr $fileSize + 4` - msg1=`echo At start: cmd/size/waiting : $* / $fileSize / \`date\`` + msg1=`echo At start: cmd/size/waiting : $command / $fileSize / \`date\`` while [ 1 = 1 ] ; do newFileSize=`wc -c $jdbOutFile | awk '{ print $1 } '` #echo jj: desired = $desiredFileSize, new = $newFileSize >& 2 @@ -657,7 +683,7 @@ cmd() count=`expr $count + 1` if [ $count = 30 -o $count = 60 ] ; then # record some debug info. - echo "--DEBUG: jdb $$ didn't responded to command in $count secs: $*" >& 2 + echo "--DEBUG: jdb $$ didn't responded to command in $count secs: $command" >& 2 echo "--DEBUG:" $msg1 >& 2 echo "--DEBUG: "done size/waiting : / $newFileSize / `date` >& 2 echo "-- $jdbOutFile follows-------------------------------" >& 2 @@ -666,13 +692,12 @@ cmd() dojstack #$psCmd | sed -e '/com.sun.javatest/d' -e '/nsk/d' >& 2 if [ $count = 60 ] ; then - dofail "jdb never responded to command: $*" + dofail "jdb never responded to command: $command" fi fi done # Note that this assumes just these chars in thread names. - waitForJdbMsg '[a-zA-Z0-9_-][a-zA-Z0-9_-]*\[[1-9][0-9]*\] [ >]*$' \ - 1 allowExit + waitForJdbMsg '[a-zA-Z0-9_-][a-zA-Z0-9_-]*\[[1-9][0-9]*\] [ >]*$' 1 $allowExit } setBkpts() @@ -681,12 +706,13 @@ setBkpts() # $1 is the bkpt name, eg, @1 allLines=`$grep -n "$1 *breakpoint" $tmpFileDir/$classname.java.1 | sed -e 's@^\([0-9]*\).*@\1@g'` for ii in $allLines ; do - cmd stop at $pkgDot$classname:$ii + cmd "stop at $pkgDot$classname:$ii" done } runToBkpt() { + # Don't pass allowExit here as we don't want JDB to unexpectedly exit cmd run # Don't need to do this - the above waits for the next prompt which comes out # AFTER the Breakpoint hit message. @@ -696,6 +722,7 @@ runToBkpt() contToBkpt() { + # Don't pass allowExit here as we don't want JDB to unexpectedly exit cmd cont # Don't need to do this - the above waits for the next prompt which comes out # AFTER the Breakpoint hit message. @@ -723,22 +750,24 @@ waitForJdbMsg() # Found desired string break fi - fi - tail -2 $jdbOutFile | $grep -s "The application exited" > $devnull 2>&1 - if [ $? = 0 ] ; then + fi + tail -2 $jdbOutFile | $grep -s "The application exited" > $devnull 2>&1 + if [ $? = 0 ] ; then # Found 'The application exited' + echo "--JDB finished: The application exited" >&2 if [ ! -z "$allowExit" ] ; then - break + # Exit is allowed + dofinish fi # Otherwise, it is an error if we don't find $1 - if [ -r $jdbOutFile ] ; then - tail -$nlines $jdbOutFile | $grep -s "$1" > $devnull 2>&1 + if [ -r $jdbOutFile ] ; then + tail -$nlines $jdbOutFile | $grep -s "$1" > $devnull 2>&1 if [ $? = 0 ] ; then - break - fi - fi - dofail "Waited for jdb msg $1, but it never appeared" - fi + break + fi + fi + dofail "JDB unexpectedly finished: Waited for jdb msg $1, but it never appeared" + fi sleep ${sleep_seconds} findPid $topPid @@ -761,6 +790,19 @@ waitForJdbMsg() } +# Finishes JDB execution +# Specify command to finish if it's needed +dofinish() +{ + if [ ! -z "$*" ] ; then + echo "--Finish execution with sending \"$*\" command to JDB" >&2 + cmd "exitJdb" "$*" + else + echo "--Finish without sending \"quit\" command to JDB" >&2 + fi + exit 0 +} + # $1 is the string to print. If $2 exists, # it is the name of a file to print, ie, the name # of the file that contains the $1 string. @@ -774,10 +816,11 @@ dofail() # Kill the debuggee ; it could be hung so # we want to get rid of it as soon as possible. killOrphans "killing debuggee" $debuggeeKeyword + # Kill debugger, it could be hung + killOrphans "killing debugger" $jdbKeyword echo " " >>$failFile echo "--Fail: $*" >> $failFile - echo quit fi if [ ! -z "$2" ] ; then echo "---- contents of $2 follows -------" >> $failFile @@ -788,7 +831,7 @@ dofail() } -redefineClass() +redefineClass() { if [ -z "$1" ] ; then vers=2 @@ -796,8 +839,8 @@ redefineClass() vers=`echo $1 | sed -e 's/@//'` vers=`expr $vers + 1` fi - - cmd redefine $pkgDot$classname $tmpFileDir/vers$vers/$classname.class + + cmd "redefine $pkgDot$classname $tmpFileDir/vers$vers/$classname.class" cp $tmpFileDir/$classname.java.$vers \ $tmpFileDir/$classname.java @@ -807,8 +850,10 @@ mydojdbCmds() { # Wait for jdb to start before we start sending cmds waitForJdbMsg ']' 1 + # Send commands from the test dojdbCmds - cmd quit + # Finish jdb with quit command + dofinish "quit" } startJdb() @@ -853,7 +898,7 @@ startDebuggee() if [ -r $TESTCLASSES/../@debuggeeVMOptions ] ; then args=`cat $TESTCLASSES/../@debuggeeVMOptions` fi - + if [ ! -z "$args" ] ; then echo "--Starting debuggee with args from @debuggeeVMOptions: $args" else @@ -932,16 +977,13 @@ waitForFinish() break fi if [ ! -z "$isWin98" ] ; then - $psCmd | $grep -i 'JDB\.EXE' >$devnull 2>&1 - if [ $? != 0 ] ; then - break; - fi - fi - $grep -s 'Input stream closed' $jdbOutFile > $devnull 2>&1 - if [ $? = 0 ] ; then - #something went wrong - dofail "jdb input stream closed prematurely" + $psCmd | $grep -i 'JDB\.EXE' >$devnull 2>&1 + if [ $? != 0 ] ; then + break + fi fi + # Something went wrong + jdbFailIfPresent "Input stream closed" # If a failure has occured, quit if [ -r "$failFile" ] ; then @@ -951,6 +993,46 @@ waitForFinish() sleep ${sleep_seconds} done + # jdb exited because its input stream closed prematurely + jdbFailIfPresent "Input stream closed" + + # It is necessary here to avoid the situation when JDB exited but + # mydojdbCmds() didn't finish because it waits for JDB message + # in waitForJdbMsg(), at the same time main process will finish + # the execution with no errors. + # To avoid that, wait for spawned processes to finish + case "$osname" in + SunOS) + # `wait` function doesn't work in Solaris shell as in bash, + # so create replacement that finds mydojdbCmds() shell process + # and waits for its finish + cmdsPid= + # get list of processes except main process with $topPid + processes=`$psCmd | $grep -v "$grep" | $grep -v $topPid | awk '{print $1}'` + for pid in $processes; do + # for each process grep its full args string for test name $0 + # $0 contains full test name with path + pargs -l $pid 2>$devnull | $grep "$0" >$devnull 2>&1 + if [ $? = 0 ] ; then + cmdsPid=$pid + break + fi + done + echo "--waitForFinish: Waiting for mydojdbCmds() to finish" >&2 + while [ 1 = 1 ] ; do + findPid $cmdsPid + if [ $? != 0 ] ; then + break + fi + sleep ${sleep_seconds} + done + ;; + *) + echo "--waitForFinish: Waiting for all processes to finish" >&2 + wait + ;; + esac + if [ -r "$failFile" ] ; then ls -l "$failFile" >&2 echo "" >&2 @@ -1130,13 +1212,8 @@ pass() runit() { setup - runitAfterSetup -} - -runitAfterSetup() -{ docompile - startJdb + startJdb startDebuggee waitForFinish diff --git a/jdk/test/com/sun/jdi/StringConvertTest.sh b/jdk/test/com/sun/jdi/StringConvertTest.sh index c86ab3dab46..181105c6257 100644 --- a/jdk/test/com/sun/jdi/StringConvertTest.sh +++ b/jdk/test/com/sun/jdi/StringConvertTest.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, 2003, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -164,7 +164,7 @@ dojdbCmds() cmd print "$classname.growit(\"xyz\")" cmd eval "$classname.sbGrower.append(\"xyz\")" cmd print 1 - + cmd eval "sbTim.toString()" cmd print 1 @@ -183,7 +183,6 @@ dojdbCmds() cmd print "this.ivar" cmd print gusLoc cmd print 1 - cmd quit } mysetup() diff --git a/jdk/test/com/sun/jdi/WatchFramePop.sh b/jdk/test/com/sun/jdi/WatchFramePop.sh index 5aa7905cac7..870f32f0a3c 100644 --- a/jdk/test/com/sun/jdi/WatchFramePop.sh +++ b/jdk/test/com/sun/jdi/WatchFramePop.sh @@ -1,7 +1,7 @@ #!/bin/sh # -# Copyright (c) 2002, 2003, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it @@ -83,7 +83,7 @@ dojdbCmds() contToBkpt # stops at the bkpt at cmd next # The bug is that this next runs to completion # In which case, so does jdb - cmd quit # so we never get here. + # so we never get here. }