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 06.04.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.JDWPConstants;
305f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.ParsedEvent;
315f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.ReplyPacket;
32e8c8e4aa631449e03043945cb4bbf1338d6b9894Sebastien Hertzimport org.apache.harmony.jpda.tests.framework.jdwp.ParsedEvent.EventThread;
335f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.share.JPDADebuggeeSynchronizer;
345f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
355f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
365f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
375f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/**
385f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * JDWP Unit test for METHOD_ENTRY event.
395f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */
405f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespublic class MethodEntryTest extends JDWPEventTestCase {
415f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
42e1833aa2673d4f975ad35e7a39317feeea922fe1Sebastien Hertz    @Override
435f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    protected String getDebuggeeClassName() {
445f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        return MethodEntryDebuggee.class.getName();
455f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
465f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
475f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    /**
485f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * This testcase is for METHOD_ENTRY event.
495f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>It runs MethodEntryDebuggee that executed its own method
505f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * and verify that requested METHOD_ENTRY event occurs.
515f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     */
525f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    public void testMethodEntry() {
535f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("testMethodEntry started");
545f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
555f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        String methodEntryClassNameRegexp = "org.apache.harmony.jpda.tests.jdwp.Events.MethodEntryDebuggee";
565f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        //String methodEntryClassNameSignature = "Lorg/apache/harmony/jpda/tests/jdwp/Events/MethodEntryDebuggee;";
575f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
585f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_READY);
595f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
605f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        ReplyPacket reply = debuggeeWrapper.vmMirror.setMethodEntry(methodEntryClassNameRegexp);
615f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        checkReplyPacket(reply, "Set METHOD_ENTRY event");
625f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
635f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE);
645f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
655f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        CommandPacket event = debuggeeWrapper.vmMirror.receiveEvent();
665f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        ParsedEvent[] parsedEvents = ParsedEvent.parseEventPacket(event);
675f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
685f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        assertEquals("Invalid number of events,", 1, parsedEvents.length);
695f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        assertEquals("Invalid event kind,",
705f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPConstants.EventKind.METHOD_ENTRY,
715f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                parsedEvents[0].getEventKind(),
725f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPConstants.EventKind.getName(JDWPConstants.EventKind.METHOD_ENTRY),
735f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPConstants.EventKind.getName(parsedEvents[0].getEventKind()));
745f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
75e8c8e4aa631449e03043945cb4bbf1338d6b9894Sebastien Hertz        long eventThreadID = ((EventThread) parsedEvents[0]).getThreadID();
76e8c8e4aa631449e03043945cb4bbf1338d6b9894Sebastien Hertz        checkThreadState(eventThreadID, JDWPConstants.ThreadStatus.RUNNING,
77e8c8e4aa631449e03043945cb4bbf1338d6b9894Sebastien Hertz                JDWPConstants.SuspendStatus.SUSPEND_STATUS_SUSPENDED);
78e8c8e4aa631449e03043945cb4bbf1338d6b9894Sebastien Hertz
795f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("MethodEntryTest done");
805f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
815f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes}
82