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: * See the License for the specific language governing permissions and
15: * limitations under the License.
16: */
17:
18: /**
19: * @author Serguei S.Zapreyev
20: * @version $Revision$
21: */package java.lang;
22:
23: import junit.framework.TestCase;
24:
25: /*
26: * Created on March 29, 2006
27: *
28: * This RuntimeAdditionalTest class is used to test the Core API Runtime class
29: *
30: */
31:
32: /**
33: * ###############################################################################
34: * ###############################################################################
35: * TODO: 1.
36: * ###############################################################################
37: * ###############################################################################
38: */
39:
40: public class RuntimeAdditionalTest2 extends TestCase {
41: /**
42: * 1. destroy java process then Process.exitValue 2. waitFor java process
43: * then Process.exitValue, Process.exitValue 3. destroy "java -version"
44: * process then Process.exitValue, Process.exitValue
45: */
46: public void test_3() {
47: System.out.println("==test_3===");
48: if (RuntimeAdditionalTest0.os.equals("Unk")) {
49: fail("WARNING (test_3): unknown operating system.");
50: }
51: Process pi3 = null;
52: try {
53:
54: String cmnd = RuntimeAdditionalTest0.javaStarter;
55: pi3 = Runtime.getRuntime().exec(cmnd);
56: pi3.destroy();
57: /*System.out.println(*/pi3.exitValue()/*)*/;
58: } catch (Exception eeee) {
59: //eeee.printStackTrace();
60: while (true) {
61: try {
62: /*System.out.println(=ntln("XXX: " + */pi3
63: .exitValue()/*)*/;
64: break;
65: } catch (IllegalThreadStateException e) {
66: continue;
67: }
68: }
69: }
70: /*System.out.println("YYY: " + */pi3.exitValue()/*)*/;
71: try {
72:
73: String cmnd = RuntimeAdditionalTest0.javaStarter;
74: pi3 = Runtime.getRuntime().exec(cmnd);
75: /*System.out.println(*/pi3.waitFor()/*)*/;
76: /*System.out.println(*/pi3.exitValue()/*)*/;
77: /*System.out.println(*/pi3.exitValue()/*)*/;
78: } catch (Exception eeee) {
79: eeee.printStackTrace();
80: fail("ERROR (test_3): unexpected exception.");
81: }
82: try {
83:
84: String cmnd = RuntimeAdditionalTest0.javaStarter
85: + " -version";
86: pi3 = Runtime.getRuntime().exec(cmnd);
87: /*System.out.println(*/pi3.waitFor()/*)*/;
88: /*System.out.println(*/pi3.exitValue()/*)*/;
89: /*System.out.println(*/pi3.exitValue()/*)*/;
90: } catch (Exception eeee) {
91: eeee.printStackTrace();
92: fail("ERROR (test_3): unexpected exception.");
93: }
94: }
95: }
|