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 RuntimeAdditionalTest28 extends TestCase {
41: /**
42: * wait for (via exitValue loop) finish of the java process then destroy,
43: * get jvm process' streams, read err stream, then exitValue
44: */
45: public void test_28() {
46: System.out.println("==test_28===");
47: if (RuntimeAdditionalTest0.os.equals("Unk")) {
48: fail("WARNING (test_28): unknown operating system.");
49: }
50: try {
51: String cmnd = RuntimeAdditionalTest0.javaStarter + " MAIN";
52: Process pi3 = Runtime.getRuntime().exec(cmnd);
53: while (true) {
54: try {
55: Thread.sleep(50);
56: /*System.out.println(*/pi3.exitValue()/*)*/;
57: break;
58: } catch (IllegalThreadStateException e) {
59: continue;
60: }
61: }
62: pi3.destroy();
63: Thread.sleep(100);
64: pi3.getOutputStream();
65: java.io.InputStream es = pi3.getErrorStream();
66: pi3.getInputStream();
67: /*System.out.println(*/pi3.waitFor()/*)*/;
68: int ia;
69: while (true) {
70: while ((ia = es.available()) != 0) {
71: byte[] bbb = new byte[ia];
72: es.read(bbb);
73: //System.out.println(new String(bbb));
74: }
75: try {
76: pi3.exitValue();
77: while ((ia = es.available()) != 0) {
78: byte[] bbb = new byte[ia];
79: es.read(bbb);
80: //System.out.println(new String(bbb));
81: }
82: break;
83: } catch (IllegalThreadStateException e) {
84: continue;
85: }
86: }
87: /*System.out.println(*/pi3.exitValue()/*)*/;
88: } catch (Exception eeee) {
89: eeee.printStackTrace();
90: fail("ERROR (test_28): unexpected exception.");
91: }
92: }
93:
94: }
|