1 /*
2  * Copyright (c) 2002, 2018, Oracle and/or its affiliates. All rights reserved.
3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4  *
5  * This code is free software; you can redistribute it and/or modify it
6  * under the terms of the GNU General Public License version 2 only, as
7  * published by the Free Software Foundation.
8  *
9  * This code is distributed in the hope that it will be useful, but WITHOUT
10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
12  * version 2 for more details (a copy is included in the LICENSE file that
13  * accompanied this code).
14  *
15  * You should have received a copy of the GNU General Public License version
16  * 2 along with this work; if not, write to the Free Software Foundation,
17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18  *
19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20  * or visit www.oracle.com if you need additional information or have any
21  * questions.
22  */
23 
24 package nsk.jdi.StackFrame.hashCode;
25 
26 import nsk.share.*;
27 import nsk.share.jpda.*;
28 import nsk.share.jdi.*;
29 
30 //    THIS TEST IS LINE NUMBER SENSITIVE
31 
32 /**
33  * The debugged application of the test.
34  */
35 public class hashcode001a {
36 
37     //------------------------------------------------------- immutable common fields
38 
39     private static int exitStatus;
40     private static ArgumentHandler argHandler;
41     private static Log log;
42     private static IOPipe pipe;
43 
44     //------------------------------------------------------- immutable common methods
45 
display(String msg)46     static void display(String msg) {
47         log.display("debuggee > " + msg);
48     }
49 
complain(String msg)50     static void complain(String msg) {
51         log.complain("debuggee FAILURE > " + msg);
52     }
53 
receiveSignal(String signal)54     public static void receiveSignal(String signal) {
55         String line = pipe.readln();
56 
57         if ( !line.equals(signal) )
58             throw new Failure("UNEXPECTED debugger's signal " + line);
59 
60         display("debuger's <" + signal + "> signal received.");
61     }
62 
63     //------------------------------------------------------ mutable common fields
64 
65     //------------------------------------------------------ test specific fields
66 
67     public final static String brkpMethodName = "breakHere";
68     public final static int brkpLineNumber = 92;
69 
70     //------------------------------------------------------ mutable common method
71 
main(String argv[])72     public static void main (String argv[]) {
73         exitStatus = Consts.TEST_FAILED;
74         argHandler = new ArgumentHandler(argv);
75         log = new Log(System.err, argHandler);
76         pipe = argHandler.createDebugeeIOPipe(log);
77         try {
78             pipe.println(hashcode001.SIGNAL_READY);
79             breakHere();
80             receiveSignal(hashcode001.SIGNAL_QUIT);
81             display("completed succesfully.");
82             System.exit(Consts.TEST_PASSED + Consts.JCK_STATUS_BASE);
83         } catch (Failure e) {
84             log.complain(e.getMessage());
85             System.exit(Consts.TEST_FAILED + Consts.JCK_STATUS_BASE);
86         }
87     }
88 
89     //--------------------------------------------------------- test specific methods
breakHere()90     public static void breakHere () {
91         receiveSignal(hashcode001.SIGNAL_GO);
92         log.display("breakpoint line"); // brkpLineNumber
93     }
94 }
95 
96 //--------------------------------------------------------- test specific classes
97