1/*
2 * Licensed to the Apache Software Foundation (ASF) under one or more
3 * contributor license agreements.  See the NOTICE file distributed with
4 * this work for additional information regarding copyright ownership.
5 * The ASF licenses this file to You under the Apache License, Version 2.0
6 * (the "License"); you may not use this file except in compliance with
7 * the License.  You may obtain a copy of the License at
8 *
9 *     http://www.apache.org/licenses/LICENSE-2.0
10 *
11 *  Unless required by applicable law or agreed to in writing, software
12 *  distributed under the License is distributed on an "AS IS" BASIS,
13 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 *
15 *  See the License for the specific language governing permissions and
16 *  limitations under the License.
17 */
18
19/**
20 * @author Anton V. Karnachuk
21 */
22
23/**
24 * Created on 11.03.2005
25 */
26package org.apache.harmony.jpda.tests.jdwp.MultiSession;
27
28import org.apache.harmony.jpda.tests.share.JPDADebuggeeSynchronizer;
29import org.apache.harmony.jpda.tests.share.SyncDebuggee;
30
31/**
32 * Basic debuggee for events unit tests.
33 * Runs new thread
34 */
35public class EventDebuggee extends SyncDebuggee {
36
37    static final String testedThreadName = "SimpleThread";
38
39    private class SimpleThread extends Thread {
40
41        public SimpleThread () {
42            super(testedThreadName);
43        }
44
45        public void run() {
46            logWriter.println("-> SimpleThread: Running...");
47        }
48    }
49
50    public static void main(String[] args) {
51        runDebuggee(EventDebuggee.class);
52    }
53
54    public void run() {
55        logWriter.println("-> EventDebuggee: STARTED");
56
57        synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_READY);
58        synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE);
59
60        SimpleThread testThread = new SimpleThread();
61        testThread.start();
62        logWriter.println("-> EventDebuggee: SimpleThread started");
63        try {
64            testThread.join();
65        } catch (InterruptedException e) {
66            e.printStackTrace();
67        }
68        logWriter.println("-> EventDebuggee: SimpleThread finished");
69        synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_READY);
70
71        logWriter.println("-> EventDebuggee: wait for signal to continue...");
72        // do NOT finish without signal in order to do NOT generate unexpected events
73
74        while ( true ) {
75            if ( synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE) ) {
76               logWriter.println("-> EventDebuggee: signal received!");
77               break;
78            }
79        }
80
81        logWriter.println("-> EventDebuggee: FINISH...");
82    }
83
84}
85
86