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 Anton V. Karnachuk
215f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */
225f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
235f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/**
245f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * Created on 11.03.2005
255f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */
265f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespackage org.apache.harmony.jpda.tests.jdwp.Events;
275f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
285f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.share.JPDADebuggeeSynchronizer;
295f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.share.SyncDebuggee;
305f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
315f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/**
325f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * Basic debuggee for events unit tests.
335f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * Runs new thread
345f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */
355f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespublic class EventDebuggee extends SyncDebuggee {
365f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
375f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    public static final String testedThreadName = "SimpleThread";
385f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
395f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    private class SimpleThread extends Thread {
405f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
415f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        public SimpleThread () {
425f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            super(testedThreadName);
435f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        }
445f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
455f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        public void run() {
465f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            logWriter.println("-> SimpleThread: Running...");
475f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        }
485f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
495f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
505f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    public static void main(String[] args) {
515f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        runDebuggee(EventDebuggee.class);
525f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
535f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
545f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    public void run() {
555f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("-> EventDebuggee: STARTED");
565f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
575f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_READY);
585f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE);
595f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
605f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        SimpleThread testThread = new SimpleThread();
615f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        testThread.start();
625f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("-> EventDebuggee: SimpleThread started");
635f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        try {
645f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            testThread.join();
655f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        } catch (InterruptedException e) {
665f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            e.printStackTrace();
675f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        }
685f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("-> EventDebuggee: SimpleThread finished");
695f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_READY);
705f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
715f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("-> EventDebuggee: wait for signal to continue...");
725f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        // do NOT finish without signal (in acceptable time) in order
735f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        // to do NOT generate unexpected events
745f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        String infoMessage = "-> EventDebuggee: TIMED OUT in waiting for signal!";
755f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        for (int i=0; i < 10; i++ ) {
765f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            if ( synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE) ) {
775f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                infoMessage = "-> EventDebuggee: signal received!";
785f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes               break;
795f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            }
805f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        }
815f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println(infoMessage);
825f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
835f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("-> EventDebuggee: FINISH...");
845f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
855f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
865f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes}
875f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
88