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