/* * Copyright (c) 2002, 2021, 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 * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package nsk.jdi.Event.hashCode; import nsk.share.*; import nsk.share.jpda.*; import nsk.share.jdi.*; // THIS TEST IS LINE NUMBER SENSITIVE /** * The debugged application of the test. */ public class hashcode001a { //------------------------------------------------------- immutable common fields private static int exitStatus; private static ArgumentHandler argHandler; private static Log log; private static IOPipe pipe; //------------------------------------------------------- immutable common methods static void display(String msg) { log.display("debuggee > " + msg); } static void complain(String msg) { log.complain("debuggee FAILURE > " + msg); } public static void receiveSignal(String signal) { String line = pipe.readln(); if ( !line.equals(signal) ) throw new Failure("UNEXPECTED debugger's signal " + line); display("debugger's <" + signal + "> signal received."); } //------------------------------------------------------ mutable common fields //------------------------------------------------------ test specific fields static Object lock = new Object(); static Object wait = new Object(); //------------------------------------------------------ mutable common method public static void main (String argv[]) { exitStatus = Consts.TEST_FAILED; argHandler = new ArgumentHandler(argv); log = new Log(System.err, argHandler); pipe = argHandler.createDebugeeIOPipe(log); try { Thread thread1 = JDIThreadFactory.newThread(new hashcode001aThread("thread1")); synchronized (lock) { synchronized(wait) { thread1.start(); try { wait.wait(); pipe.println(hashcode001.SIGNAL_READY); } catch (InterruptedException e) { throw new Failure("Unexpected InterruptedException while waiting for notification"); } } receiveSignal(hashcode001.SIGNAL_GO); } try { thread1.join(); } catch (InterruptedException e) { throw new Failure("Unexpected InterruptedException while waiting for thread1 join"); } // receiveSignal(hashcode001.SIGNAL_QUIT); display("completed succesfully."); System.exit(Consts.TEST_PASSED + Consts.JCK_STATUS_BASE); } catch (Failure e) { log.complain(e.getMessage()); System.exit(Consts.TEST_FAILED + Consts.JCK_STATUS_BASE); } } //--------------------------------------------------------- test specific methods } //--------------------------------------------------------- test specific classes class hashcode001aThread extends NamedTask { String name; public hashcode001aThread (String name) { super(name); this.name = name; } public void run() { synchronized (hashcode001a.wait) { hashcode001a.wait.notifyAll(); } synchronized (hashcode001a.lock) { } foo(); Thread thread2 = JDIThreadFactory.newThread(new hashcode001aThread1()); thread2.start(); try { throw new Exception(); } catch (Exception e) { } try { thread2.join(); } catch (InterruptedException e) { throw new Failure("Unexpected InterruptedException while waiting for thread2 join"); } } void foo () { name = "afterFoo"; // hashcode001.brkpLineNumber hashcode001a.display("thread1's name == " + name); } } class hashcode001aThread1 implements Runnable { public void run() { } }