01: /*
02: * Licensed to the Apache Software Foundation (ASF) under one or more
03: * contributor license agreements. See the NOTICE file distributed with
04: * this work for additional information regarding copyright ownership.
05: * The ASF licenses this file to You under the Apache License, Version 2.0
06: * (the "License"); you may not use this file except in compliance with
07: * the License. You may obtain a copy of the License at
08: *
09: * http://www.apache.org/licenses/LICENSE-2.0
10: *
11: * Unless required by applicable law or agreed to in writing, software
12: * distributed under the License is distributed on an "AS IS" BASIS,
13: * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14: *
15: * See the License for the specific language governing permissions and
16: * limitations under the License.
17: */
18:
19: /**
20: * @author Aleksander V. Budniy
21: * @version $Revision: 1.5 $
22: */
23:
24: /**
25: * Created on 8.7.2005
26: */package org.apache.harmony.jpda.tests.jdwp.MultiSession;
27:
28: import org.apache.harmony.jpda.tests.framework.TestOptions;
29: import org.apache.harmony.jpda.tests.jdwp.share.JDWPSyncTestCase;
30: import org.apache.harmony.jpda.tests.jdwp.share.JDWPUnitDebuggeeWrapper;
31: import org.apache.harmony.jpda.tests.share.JPDADebuggeeSynchronizer;
32:
33: /**
34: * JDWP Unit test for verifying auto resuming debuggee after re-connection.
35: */
36: public class ResumeTest extends JDWPSyncTestCase {
37:
38: protected String getDebuggeeClassName() {
39: return "org.apache.harmony.jpda.tests.jdwp.MultiSession.ResumeDebuggee";
40: }
41:
42: /**
43: * This testcase verifies auto resuming debuggee after re-connection.
44: * <BR>It runs ResumeDebuggee, suspends debuggee with VirtualMachine.Suspend
45: * commands and re-connects.
46: * <BR>It is expected that debuggee is auto resumed after re-connection.
47: */
48: public void testResume() {
49: synchronizer
50: .receiveMessage(JPDADebuggeeSynchronizer.SGNL_READY);
51:
52: for (int i = 0; i < 3; i++) {
53: debuggeeWrapper.vmMirror.suspend();
54: }
55:
56: logWriter.println("");
57: logWriter.println("CLOSE CONNECTION");
58: closeConnection();
59: logWriter.println("CONNECTION IS CLOSED");
60:
61: logWriter.println("");
62: logWriter.println("OPEN NEW CONNECTION");
63: openConnection();
64: logWriter.println("CONNECTION IS OPENED");
65:
66: synchronizer
67: .sendMessage(JPDADebuggeeSynchronizer.SGNL_CONTINUE);
68: synchronizer
69: .receiveMessage(JPDADebuggeeSynchronizer.SGNL_READY);
70: logWriter.println("DEBUGGEE WAS RESUMED");
71:
72: logWriter.println("TEST PASSED");
73: }
74:
75: protected void beforeDebuggeeStart(
76: JDWPUnitDebuggeeWrapper debuggeeWrapper) {
77: settings.setAttachConnectorKind();
78: if (settings.getTransportAddress() == null) {
79: settings
80: .setTransportAddress(TestOptions.DEFAULT_ATTACHING_ADDRESS);
81: }
82: logWriter.println("ATTACH connector kind");
83: super .beforeDebuggeeStart(debuggeeWrapper);
84: }
85:
86: public static void main(String[] args) {
87: junit.textui.TestRunner.run(ResumeTest.class);
88: }
89: }
|