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 Vitaly A. Provodin
215f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */
225f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
235f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/**
245f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * Created on 22.02.2005
255f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */
265f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespackage org.apache.harmony.jpda.tests.jdwp.ThreadReference;
275f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
285f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.CommandPacket;
295f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.JDWPCommands;
305f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.JDWPConstants;
315f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.framework.jdwp.ReplyPacket;
325f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.jdwp.share.JDWPSyncTestCase;
335f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughesimport org.apache.harmony.jpda.tests.share.JPDADebuggeeSynchronizer;
345f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
355f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
365f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/**
375f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * JDWP Unit test for ThreadReference.Status command.
385f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */
395f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespublic class StatusTest extends JDWPSyncTestCase {
405f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
415f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    protected String getDebuggeeClassName() {
425f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        return "org.apache.harmony.jpda.tests.jdwp.ThreadReference.StatusDebuggee";
435f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
445f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
455f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    /**
465f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * This testcase exercises ThreadReference.Status command for suspended Thread.
475f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>At first the test starts StatusDebuggee which runs
485f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * the tested thread.
495f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR> At first the test suspends tested thread by ThreadReference.Suspend command.
505f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR> Then the tests performs the ThreadReference.Status command
515f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * for tested thread.
525f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>It is expected that:
535f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>&nbsp;&nbsp; - returned thread status is RUNNING status;
545f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>&nbsp;&nbsp; - returned suspend status is SUSPEND_STATUS_SUSPENDED status;
555f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     */
565f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    public void testStatus002() {
575f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_READY);
585f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
595f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        // getting ID of the tested thread
605f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("get thread ID");
615f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        long threadID =
625f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            debuggeeWrapper.vmMirror.getThreadID(StatusDebuggee.TESTED_THREAD);
635f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("suspend thread");
645f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        debuggeeWrapper.vmMirror.suspendThread(threadID);
655f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
665f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        // getting the thread group ID
675f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        CommandPacket packet = new CommandPacket(
685f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPCommands.ThreadReferenceCommandSet.CommandSetID,
695f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPCommands.ThreadReferenceCommandSet.StatusCommand);
705f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        packet.setNextValueAsThreadID(threadID);
715f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
725f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        ReplyPacket reply = debuggeeWrapper.vmMirror.performCommand(packet);
735f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        checkReplyPacket(reply, "ThreadReference::Status command");
745f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
755f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        int threadStatus = reply.getNextValueAsInt();
765f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        int suspendStatus = reply.getNextValueAsInt();
775f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
785f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("\t" + threadID + " "
795f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + "\"" + StatusDebuggee.TESTED_THREAD + "\" "
805f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + JDWPConstants.ThreadStatus.getName(threadStatus) + " "
815f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + JDWPConstants.SuspendStatus.getName(suspendStatus));
825f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
835f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        if (threadStatus != JDWPConstants.ThreadStatus.RUNNING) {
845f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            printErrorAndFail("Unexpected thread status: "
855f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                    + JDWPConstants.ThreadStatus.getName(threadStatus));
865f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        } else {
875f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            logWriter.println("Expected thread status "
885f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                    + JDWPConstants.ThreadStatus.getName(threadStatus));
895f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        }
905f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
915f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        if (suspendStatus != JDWPConstants.SuspendStatus.SUSPEND_STATUS_SUSPENDED) {
925f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            printErrorAndFail("Unexpected suspend status: "
935f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                    + JDWPConstants.ThreadStatus.getName(suspendStatus));
945f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        } else {
955f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            logWriter.println("Expected suspend status "
965f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                    + JDWPConstants.SuspendStatus.getName(suspendStatus));
975f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        }
985f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
995f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("resume thread");
1005f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        debuggeeWrapper.vmMirror.resumeThread(threadID);
1015f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1025f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE);
1035f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
1045f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1055f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    /**
1065f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * This testcase exercises ThreadReference.Status command.
1075f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>At first the test starts StatusDebuggee which runs
1085f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * the tested thread.
1095f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR> Then the tests performs the ThreadReference.Status command
1105f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * for tested thread.
1115f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>It is expected that:
1125f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>&nbsp;&nbsp; - returned thread status is RUNNING status;
1135f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>&nbsp;&nbsp; - returned suspend status is not SUSPEND_STATUS_SUSPENDED status;
1145f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     */
1155f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    public void testStatus001() {
1165f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.receiveMessage(JPDADebuggeeSynchronizer.SGNL_READY);
1175f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1185f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        // getting ID of the tested thread
1195f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("get thread ID");
1205f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        long threadID =
1215f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            debuggeeWrapper.vmMirror.getThreadID(StatusDebuggee.TESTED_THREAD);
1225f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1235f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        // getting the thread group ID
1245f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        CommandPacket packet = new CommandPacket(
1255f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPCommands.ThreadReferenceCommandSet.CommandSetID,
1265f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPCommands.ThreadReferenceCommandSet.StatusCommand);
1275f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        packet.setNextValueAsThreadID(threadID);
1285f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1295f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        ReplyPacket reply = debuggeeWrapper.vmMirror.performCommand(packet);
1305f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        checkReplyPacket(reply, "ThreadReference::Status command");
1315f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1325f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        int threadStatus = reply.getNextValueAsInt();
1335f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        int suspendStatus = reply.getNextValueAsInt();
1345f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1355f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("\t" + threadID + " "
1365f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + "\"" + StatusDebuggee.TESTED_THREAD + "\" "
1375f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + JDWPConstants.ThreadStatus.getName(threadStatus) + " "
1385f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + JDWPConstants.SuspendStatus.getName(suspendStatus));
1395f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1405f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        if (threadStatus != JDWPConstants.ThreadStatus.RUNNING) {
1415f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            printErrorAndFail("Unexpected thread status: "
1425f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                    + JDWPConstants.ThreadStatus.getName(threadStatus));
1435f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        } else {
1445f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            logWriter.println("Expected thread status "
1455f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                    + JDWPConstants.ThreadStatus.getName(threadStatus));
1465f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        }
1475f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1485f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        if (suspendStatus == JDWPConstants.SuspendStatus.SUSPEND_STATUS_SUSPENDED) {
1495f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            printErrorAndFail("Unexpected suspend status: "
1505f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                    + JDWPConstants.ThreadStatus.getName(suspendStatus));
1515f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        } else {
1525f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            logWriter.println("Expected suspend status "
1535f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                    + JDWPConstants.SuspendStatus.getName(suspendStatus));
1545f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        }
1555f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1565f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE);
1575f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
1585f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes}
159