15f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/* 25f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * Licensed to the Apache Software Foundation (ASF) under one or more 35f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * contributor license agreements. See the NOTICE file distributed with 45f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * this work for additional information regarding copyright ownership. 55f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * The ASF licenses this file to You under the Apache License, Version 2.0 65f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * (the "License"); you may not use this file except in compliance with 75f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * the License. You may obtain a copy of the License at 85f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * 95f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * http://www.apache.org/licenses/LICENSE-2.0 105f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * 115f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * Unless required by applicable law or agreed to in writing, software 125f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * distributed under the License is distributed on an "AS IS" BASIS, 135f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 145f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * 155f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * See the License for the specific language governing permissions and 165f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * limitations under the License. 175f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */ 185f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 195f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/** 205f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * @author Anatoly F. Bondarenko 215f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */ 225f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 235f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/** 245f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * Created on 31.03.2005 255f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */ 265f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespackage org.apache.harmony.jpda.tests.jdwp.ThreadReference; 275f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 285f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes// import org.apache.harmony.jpda.tests.share.JPDADebuggeeSynchronizer; 295f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.share.SyncDebuggee; 305f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 315f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/** 325f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * The class specifies debuggee for <code>org.apache.harmony.jpda.tests.jdwp.ThreadReference.Status004Test</code>. 335f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */ 345f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespublic class Status004Debuggee extends SyncDebuggee { 355f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 365f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes static Status004Debuggee status004DebuggeeThis; 375f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes static volatile boolean status004DebuggeeThreadStarted = false; 385f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 395f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes static Object waitTimeObject = new Object(); 405d36ea7c6bdfa6fbcd1ccd53465fe41d7225273bElliott Hughes static void waitMlsecsTime(long mlsecsTime) { 415f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes synchronized(waitTimeObject) { 425f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes try { 435f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes waitTimeObject.wait(mlsecsTime); 445f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } catch (Throwable throwable) { 455f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes // ignore 465f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 475f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 485f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 495d36ea7c6bdfa6fbcd1ccd53465fe41d7225273bElliott Hughes 505f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes public void run() { 515f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("--> Debuggee: Status004Debuggee: START"); 525f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes status004DebuggeeThis = this; 535d36ea7c6bdfa6fbcd1ccd53465fe41d7225273bElliott Hughes 545f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes String status004DebuggeeThreadName = "Status004DebuggeeThread"; 555f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes Status004Debuggee_Thread status004DebuggeeThread 565d36ea7c6bdfa6fbcd1ccd53465fe41d7225273bElliott Hughes = new Status004Debuggee_Thread(status004DebuggeeThreadName); 575f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 585f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes status004DebuggeeThread.start(); 595f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 605f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes while ( ! status004DebuggeeThreadStarted ) { 615f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes waitMlsecsTime(1000); 625f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 635d36ea7c6bdfa6fbcd1ccd53465fe41d7225273bElliott Hughes logWriter.println("--> Debuggee: Status004Debuggee: will sleep for 1 second"); 645d36ea7c6bdfa6fbcd1ccd53465fe41d7225273bElliott Hughes waitMlsecsTime(1000); // to make sure that status004DebuggeeThread is sleeping 655f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 665f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes synchronizer.sendMessage(status004DebuggeeThreadName); 675d36ea7c6bdfa6fbcd1ccd53465fe41d7225273bElliott Hughes synchronizer.receiveMessage(); // signal to finish 685d36ea7c6bdfa6fbcd1ccd53465fe41d7225273bElliott Hughes 695f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes try { 705f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes status004DebuggeeThread.interrupt(); 715f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } catch (Throwable thrown) { 725d36ea7c6bdfa6fbcd1ccd53465fe41d7225273bElliott Hughes // ignore 735f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 745f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes while ( status004DebuggeeThread.isAlive() ) { 755f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes waitMlsecsTime(100); 765f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 775f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 785f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("--> Debuggee: Status004Debuggee: FINISH"); 795f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes System.exit(0); 805f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 815f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 825f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes public static void main(String [] args) { 835f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes runDebuggee(Status004Debuggee.class); 845f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 855f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes} 865f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 875f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesclass Status004Debuggee_Thread extends Thread { 885f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 895f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes public Status004Debuggee_Thread(String name) { 905f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes super(name); 915f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 925f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 935f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes public void run() { 945f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes Status004Debuggee parent = Status004Debuggee.status004DebuggeeThis; 955f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes parent.logWriter.println("--> Thread: " + getName() + ": started..."); 965f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes parent.logWriter.println 975f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes ("--> Thread: " + getName() + ": will wait UNDEFINITELY"); 985f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes Status004Debuggee.status004DebuggeeThreadStarted = true; 995f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes Object ObjectForWait = new Object(); 1005f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes synchronized(ObjectForWait) { 1015f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes try { 1025f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes ObjectForWait.wait(); 1035f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } catch (Throwable throwable) { 1045f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes // ignore 1055f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1065f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1075f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes parent.logWriter.println("--> Thread: " + getName() + ": is finishibg..."); 1085f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1095f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes} 110