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