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