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