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 Anatoly F. Bondarenko
215f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */
225f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
235f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes/**
245f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * Created on 31.03.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 for the sleeping Thread.
385f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */
395f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespublic class Status002Test extends JDWPSyncTestCase {
405f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
415f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    static final int testStatusPassed = 0;
425f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    static final int testStatusFailed = -1;
435f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
445f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    protected String getDebuggeeClassName() {
455f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        return "org.apache.harmony.jpda.tests.jdwp.ThreadReference.Status002Debuggee";
465f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
475f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
485f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    String getThreadSuspendStatusName(int suspendStatus) {
495f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
505f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        String result = JDWPConstants.SuspendStatus.getName(suspendStatus);
515f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        if ( result.equals("") ) {
525f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            result = "NOT_SUSPENDED";
535f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        }
545f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        return result;
555f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
565f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
575f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    /**
585f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * This testcase exercises ThreadReference.Status command for the sleeping Thread.
595f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>At first the test starts Status002Debuggee which runs
605f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * the tested thread and blocks it in invocation of
615f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * the 'Thread.sleep()' method.
625f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR> Then the tests performs the ThreadReference.Status command
635f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * for tested thread.
645f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>It is expected that:
655f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>&nbsp;&nbsp; - returned thread status is SLEEPING status;
665f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     * <BR>&nbsp;&nbsp; - returned suspend status is not SUSPEND_STATUS_SUSPENDED status;
675f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes     */
685f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    public void testStatus003() {
695f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        String thisTestName = "testStatus003";
705f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("==> " + thisTestName +
715f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                " for ThreadReference.Status command: START...");
725f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("==> This " + thisTestName +
735f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            " checks command for SLEEPING Thread: which is sleeping in Thread.sleep(Time) method...");
745f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        String checkedThreadName = synchronizer.receiveMessage();
755f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> checkedThreadName = " + checkedThreadName);
765f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
775f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        long checkedThreadID = debuggeeWrapper.vmMirror.getThreadID(checkedThreadName);
785f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> checkedThreadID = " + checkedThreadID);
795f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
805f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println
815f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        ("=> Send ThreadReference.Status command for checked Thread and check reply...");
825f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        CommandPacket checkedCommand = new CommandPacket(
835f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPCommands.ThreadReferenceCommandSet.CommandSetID,
845f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                JDWPCommands.ThreadReferenceCommandSet.StatusCommand);
855f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        checkedCommand.setNextValueAsThreadID(checkedThreadID);
865f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
875f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        ReplyPacket checkedReply = debuggeeWrapper.vmMirror.performCommand(checkedCommand);
885f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        checkReplyPacket(checkedReply, "ThreadReference.Status command");
895f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
905f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        int threadStatus = checkedReply.getNextValueAsInt();
915f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        int suspendStatus = checkedReply.getNextValueAsInt();
925f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
935f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("\n=> Returned thread status = 0x" + Integer.toHexString(threadStatus)
945f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + "(" + JDWPConstants.ThreadStatus.getName(threadStatus) + ")");
955f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        if (threadStatus != JDWPConstants.ThreadStatus.SLEEPING) {
965f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            finalSyncMessage = JPDADebuggeeSynchronizer.SGNL_CONTINUE;
975f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            printErrorAndFail("Unexpected thread status is returned: "
985f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + Integer.toHexString(threadStatus)
995f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + "(" + JDWPConstants.ThreadStatus.getName(threadStatus) + ")"
1005f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + "\nExpected thread status: 0x"
1015f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + Integer.toHexString(JDWPConstants.ThreadStatus.SLEEPING)
1025f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + "(" + JDWPConstants.ThreadStatus.getName(JDWPConstants.ThreadStatus.SLEEPING) + ")");
1035f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        } else {
1045f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            logWriter.println("=> OK - Expected thread status is returned");
1055f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        }
1065f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1075f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println
1085f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            ("\n=> Returned thread suspend status = 0x" + Integer.toHexString(suspendStatus)
1095f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            + "(" + getThreadSuspendStatusName(suspendStatus) + ")");
1105f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        if (suspendStatus == JDWPConstants.SuspendStatus.SUSPEND_STATUS_SUSPENDED) {
1115f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            finalSyncMessage = JPDADebuggeeSynchronizer.SGNL_CONTINUE;
1125f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            printErrorAndFail("Unexpected thread status is returned:"
1135f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + Integer.toHexString(0)
1145f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                + "(" + getThreadSuspendStatusName(0) + ")");
1155f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        } else {
1165f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes            logWriter.println("=> OK - Expected thread suspend status is returned");
1175f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        }
1185f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1195f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("=> Send to Debuggee signal to funish ...");
1205f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE);
1215f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes
1225f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes        logWriter.println("==> " + thisTestName +
1235f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes                " for ThreadReference.Status command: FINISH...");
1245f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes    }
1255f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes}
126