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 Thread waiting for time. 385f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */ 395f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughespublic class Status003Test 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.Status003Debuggee"; 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 Thread waiting for time. 595f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * <BR>At first the test starts Status003Debuggee which runs 605f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * the tested thread and blocks it in invocation of 615f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * the 'Object.wait(mlsecTime)' 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 WAIT status; 665f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes * <BR> - returned suspend status is not SUSPEND_STATUS_SUSPENDED status; 675f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes */ 685f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes public void testStatus004() { 695f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes String thisTestName = "testStatus004"; 705f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("==> " + thisTestName + " for ThreadReference.Status command: START..."); 715f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("==> This " + thisTestName 725f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + " checks command for TIMED_WAITING Thread: which is waiting in Object.wait(Time) method..."); 735f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes String checkedThreadName = synchronizer.receiveMessage(); 745f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> checkedThreadName = " + checkedThreadName); 755f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 765f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes long checkedThreadID = debuggeeWrapper.vmMirror.getThreadID(checkedThreadName); 775f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> checkedThreadID = " + checkedThreadID); 785f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 795f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println 805f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes ("=> Send ThreadReference.Status command for checked Thread and check reply..."); 815f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes CommandPacket checkedCommand = new CommandPacket( 825f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes JDWPCommands.ThreadReferenceCommandSet.CommandSetID, 835f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes JDWPCommands.ThreadReferenceCommandSet.StatusCommand); 845f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes checkedCommand.setNextValueAsThreadID(checkedThreadID); 855f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 865f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes ReplyPacket checkedReply = debuggeeWrapper.vmMirror.performCommand(checkedCommand); 875f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes checkReplyPacket(checkedReply, "ThreadReference.Status command"); 885f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 895f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes int threadStatus = checkedReply.getNextValueAsInt(); 905f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes int suspendStatus = checkedReply.getNextValueAsInt(); 915f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 925f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("\n=> Returned thread status = 0x" + Integer.toHexString(threadStatus) 935f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + "(" + JDWPConstants.ThreadStatus.getName(threadStatus) + ")"); 945f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes if (threadStatus != JDWPConstants.ThreadStatus.WAIT) { 955f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes finalSyncMessage = JPDADebuggeeSynchronizer.SGNL_CONTINUE; 965f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes printErrorAndFail("Unexpected thread status is returned:" 975f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + "\nExpected thread status = 0x" 985f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + Integer.toHexString(JDWPConstants.ThreadStatus.WAIT) 995f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + "(" + JDWPConstants.ThreadStatus.getName(JDWPConstants.ThreadStatus.WAIT) + ")"); 1005f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } else { 1015f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> OK - Expected thread status is returned"); 1025f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1035f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 1045f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println 1055f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes ("\n=> Returned thread suspend status = 0x" + Integer.toHexString(suspendStatus) 1065f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + "(" + getThreadSuspendStatusName(suspendStatus) + ")"); 1075f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes if (suspendStatus == JDWPConstants.SuspendStatus.SUSPEND_STATUS_SUSPENDED) { 1085f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes finalSyncMessage = JPDADebuggeeSynchronizer.SGNL_CONTINUE; 1095f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes printErrorAndFail("Unexpected thread status is returned:" 1105f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + "## Expected thread status = 0x" 1115f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + Integer.toHexString(0) 1125f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes + "(" + getThreadSuspendStatusName(0) + ")"); 1135f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } else { 1145f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> OK - Expected thread suspend status is returned"); 1155f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1165f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 1175f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("=> Send to Debuggee signal to funish ..."); 1185f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes synchronizer.sendMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE); 1195f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes 1205f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes logWriter.println("==> " + thisTestName + " for ThreadReference.Status command: FINISH..."); 1215f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes } 1225f0a23683aa603d8c50b6dd071a565821b76067bElliott Hughes} 123