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 Aleksander V. Budniy 215f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */ 225f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 235f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/** 245f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * Created on 11.03.2005 255f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */ 265f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespackage org.apache.harmony.jpda.tests.jdwp.MultiSession; 275f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 285f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.TestOptions; 295f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.TestErrorException; 305f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.CommandPacket; 315f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.Event; 325f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.EventMod; 335f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.JDWPConstants; 345f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.ParsedEvent; 355f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.ReplyPacket; 365f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.jdwp.share.JDWPUnitDebuggeeWrapper; 375f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.share.JPDADebuggeeSynchronizer; 385f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 395f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 405f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/** 415f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * JDWP Unit test for verifying canceling of THREAD_END event after re-connection. 425f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */ 435f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespublic class ThreadEndTest extends JDWPEventTestCase { 445f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes /** 455f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * This testcase verifies canceling of THREAD_END event after re-connection. 465f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * <BR>It runs EventDebuggee, sets request for THREAD_END event 475f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * and re-connects. 485f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * <BR>It is expected that no any events, including THREAD_END, occur after re-connection 495f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * and before EventDebuggee finish. 505f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */ 515f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes public void testThreadEnd001() { 525f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("==> testThreadEnd001 - STARTED..."); 535f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 545f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_READY); 555f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 565f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> set ThreadEndEvent..."); 575f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes ReplyPacket reply; 585f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes byte eventKind = JDWPConstants.EventKind.THREAD_END; 595f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes byte suspendPolicy = JDWPConstants.SuspendPolicy.NONE; 605f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes EventMod[] mods = new EventMod[0]; 615f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes Event eventToSet = new Event(eventKind, suspendPolicy, mods); 625f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 635f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes reply = debuggeeWrapper.vmMirror.setEvent(eventToSet); 645f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes checkReplyPacket(reply, "Set THREAD_END event"); 655f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 665f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> set ThreadEndEvent - DONE"); 675f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 685f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println(""); 695f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> CLOSE CONNECTION"); 705f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes closeConnection(); 715f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> CONNECTION CLOSED"); 725f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 735f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println(""); 745f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> OPEN NEW CONNECTION"); 755f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes openConnection(); 765f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> CONNECTION OPENED"); 775f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 785f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> Resuming debuggee"); 795f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 805f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes // start the thread 815f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE); 825f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes // wait for thread start and finish 835f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_READY); 845f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 855f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> vmMirror.receiveEvent()..."); 865f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes CommandPacket event = null; 875f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes try { 885f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes event = debuggeeWrapper.vmMirror.receiveEvent(); 895f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } catch (TestErrorException thrown) { 905f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> Exception while receiving event:" + thrown); 915f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 925f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes if (event == null) { 935f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> It's expected result, nothing was caught"); 945f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> Resuming debuggee"); 955f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes //resuming debuggee 965f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE); 975f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("==> testThreadStart001 PASSED! "); 985f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } else { 995f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("##FAILURE: Event was received"); 1005f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes try { 1015f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes ParsedEvent[] parsedEvents = ParsedEvent.parseEventPacket(event); 1025f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> Number of events = " + parsedEvents.length); 1035f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes for (int i = 0; i < parsedEvents.length; i++) { 1045f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> EventKind() = " 1055f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + parsedEvents[0].getEventKind() 1065f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + " (" 1075f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + JDWPConstants.EventKind.getName(parsedEvents[0] 1085f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes .getEventKind()) + ")"); 1095f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> EventRequestID() = " 1105f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + parsedEvents[0].getRequestID()); 1115f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 1125f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1135f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } catch (Throwable thrown) { 1145f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("##FAILURE: Exception while analyzing received event:" 1155f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + thrown); 1165f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes fail("##FAILURE: Exception while analyzing received event:" + thrown); 1175f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1185f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 1195f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE); 1205f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("==> testThreadEnd001 PASSED"); 1215f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1225f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1235f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 12425d0ba6cfaa67354e1dd47ce156ca56a815f5fd0Roland Levillain protected void beforeConnectionSetUp() { 1255f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes settings.setAttachConnectorKind(); 1265f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes if (settings.getTransportAddress() == null) { 1275f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes settings.setTransportAddress(TestOptions.DEFAULT_ATTACHING_ADDRESS); 1285f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1295f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("ATTACH connector kind"); 13025d0ba6cfaa67354e1dd47ce156ca56a815f5fd0Roland Levillain super.beforeConnectionSetUp(); 1315f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1325f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes} 133