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.framework.jdwp.CommandPacket;
295f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.Event;
305f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.EventMod;
315f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.JDWPConstants;
325f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.ParsedEvent;
335f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.ReplyPacket;
345f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.ParsedEvent.*;
355f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.share.JPDADebuggeeSynchronizer;
365f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
375f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
385f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/**
395f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * JDWP Unit test for THREAD_END event.
405f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */
415f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespublic class ThreadEndTest extends JDWPEventTestCase {
425f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    /**
435f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * This testcase is for THREAD_END event.
445f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>It runs EventDebuggee and verifies that requested
455f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * THREAD_END event occurs.
465f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     */
475f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    public void testThreadEndEvent001() {
485f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("==> testThreadEndEvent001 - STARTED...");
495f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
505f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_READY);
515f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
525f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> set ThreadEndEvent...");
535f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        ReplyPacket reply;
545f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        byte eventKind = JDWPConstants.EventKind.THREAD_END;
555f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        byte suspendPolicy = JDWPConstants.SuspendPolicy.NONE;
565f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        EventMod[] mods = new EventMod[0];
575f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        Event eventToSet = new Event(eventKind, suspendPolicy, mods);
585f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
595f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        reply = debuggeeWrapper.vmMirror.setEvent(eventToSet);
605f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        checkReplyPacket(reply, "Set THREAD_END event");
615f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
625f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> set ThreadEndEvent - DONE");
635f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
645f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        // start the thread
655f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE);
665f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
675f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        // wait for thread start and finish
685f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_READY);
695f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
705f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> vmMirror.receiveEvent()...");
715f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        CommandPacket event = debuggeeWrapper.vmMirror.receiveEvent();
725f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
735f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        assertNotNull("Invalid (null) event received", event);
745f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> Event received!");
755f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
765f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        ParsedEvent[] parsedEvents = ParsedEvent.parseEventPacket(event);
775f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> Number of events = " + parsedEvents.length);
785f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        assertEquals("Invalid number of events,", 1, parsedEvents.length);
795f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> EventKind() = " + parsedEvents[0].getEventKind()
805f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + " (" + JDWPConstants.EventKind.getName(parsedEvents[0].getEventKind()) + ")");
815f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        assertEquals("Invalid event kind,",
825f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPConstants.EventKind.THREAD_END,
835f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                parsedEvents[0].getEventKind(),
845f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPConstants.EventKind.getName(JDWPConstants.EventKind.THREAD_END),
855f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPConstants.EventKind.getName(parsedEvents[0].getEventKind()));
865f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> EventRequestID() = " + parsedEvents[0].getRequestID());
875f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
885f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        long threadID = ((Event_THREAD_DEATH)parsedEvents[0]).getThreadID();
895f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> threadID = " + threadID);
905f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        String threadName = debuggeeWrapper.vmMirror.getThreadName(threadID);
915f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> threadName = " + threadName);
925f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        assertEquals("Invalid thread name", EventDebuggee.testedThreadName, threadName);
935f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
945f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE);
955f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("==> testThreadEndEvent001 - OK");
965f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
975f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes}
98