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> - returned thread status is SLEEPING status; 665f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * <BR> - 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