author | jjg |
Thu, 31 Mar 2016 15:20:50 -0700 | |
changeset 36778 | e04318f39f92 |
permissions | -rw-r--r-- |
36778
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
1 |
/* |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
2 |
* Copyright (c) 2013, 2016, Oracle and/or its affiliates. All rights reserved. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
3 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
4 |
* |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
5 |
* This code is free software; you can redistribute it and/or modify it |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
6 |
* under the terms of the GNU General Public License version 2 only, as |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
7 |
* published by the Free Software Foundation. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
8 |
* |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
9 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
10 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
11 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
12 |
* version 2 for more details (a copy is included in the LICENSE file that |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
13 |
* accompanied this code). |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
14 |
* |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
15 |
* You should have received a copy of the GNU General Public License version |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
16 |
* 2 along with this work; if not, write to the Free Software Foundation, |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
17 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
18 |
* |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
20 |
* or visit www.oracle.com if you need additional information or have any |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
21 |
* questions. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
22 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
23 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
24 |
package toolbox; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
25 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
26 |
import java.io.BufferedReader; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
27 |
import java.io.ByteArrayOutputStream; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
28 |
import java.io.File; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
29 |
import java.io.IOException; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
30 |
import java.io.InputStream; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
31 |
import java.io.InputStreamReader; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
32 |
import java.io.PrintStream; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
33 |
import java.io.PrintWriter; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
34 |
import java.io.StringWriter; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
35 |
import java.util.EnumMap; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
36 |
import java.util.HashMap; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
37 |
import java.util.Map; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
38 |
import static toolbox.ToolBox.lineSeparator; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
39 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
40 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
41 |
* A utility base class to simplify the implementation of tasks. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
42 |
* Provides support for running the task in a process and for |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
43 |
* capturing output written by the task to stdout, stderr and |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
44 |
* other writers where applicable. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
45 |
* @param <T> the implementing subclass |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
46 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
47 |
abstract class AbstractTask<T extends AbstractTask<T>> implements Task { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
48 |
protected final ToolBox toolBox; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
49 |
protected final Mode mode; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
50 |
private final Map<OutputKind, String> redirects = new EnumMap<>(OutputKind.class); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
51 |
private final Map<String, String> envVars = new HashMap<>(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
52 |
private Expect expect = Expect.SUCCESS; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
53 |
int expectedExitCode = 0; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
54 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
55 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
56 |
* Create a task that will execute in the specified mode. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
57 |
* @param mode the mode |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
58 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
59 |
protected AbstractTask(ToolBox tb, Mode mode) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
60 |
toolBox = tb; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
61 |
this.mode = mode; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
62 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
63 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
64 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
65 |
* Sets the expected outcome of the task and calls {@code run()}. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
66 |
* @param expect the expected outcome |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
67 |
* @return the result of calling {@code run()} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
68 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
69 |
public Result run(Expect expect) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
70 |
expect(expect, Integer.MIN_VALUE); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
71 |
return run(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
72 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
73 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
74 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
75 |
* Sets the expected outcome of the task and calls {@code run()}. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
76 |
* @param expect the expected outcome |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
77 |
* @param exitCode the expected exit code if the expected outcome |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
78 |
* is {@code FAIL} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
79 |
* @return the result of calling {@code run()} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
80 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
81 |
public Result run(Expect expect, int exitCode) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
82 |
expect(expect, exitCode); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
83 |
return run(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
84 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
85 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
86 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
87 |
* Sets the expected outcome and expected exit code of the task. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
88 |
* The exit code will not be checked if the outcome is |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
89 |
* {@code Expect.SUCCESS} or if the exit code is set to |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
90 |
* {@code Integer.MIN_VALUE}. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
91 |
* @param expect the expected outcome |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
92 |
* @param exitCode the expected exit code |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
93 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
94 |
protected void expect(Expect expect, int exitCode) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
95 |
this.expect = expect; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
96 |
this.expectedExitCode = exitCode; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
97 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
98 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
99 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
100 |
* Checks the exit code contained in a {@code Result} against the |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
101 |
* expected outcome and exit value |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
102 |
* @param result the result object |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
103 |
* @return the result object |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
104 |
* @throws TaskError if the exit code stored in the result object |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
105 |
* does not match the expected outcome and exit code. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
106 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
107 |
protected Result checkExit(Result result) throws TaskError { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
108 |
switch (expect) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
109 |
case SUCCESS: |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
110 |
if (result.exitCode != 0) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
111 |
result.writeAll(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
112 |
throw new TaskError("Task " + name() + " failed: rc=" + result.exitCode); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
113 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
114 |
break; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
115 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
116 |
case FAIL: |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
117 |
if (result.exitCode == 0) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
118 |
result.writeAll(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
119 |
throw new TaskError("Task " + name() + " succeeded unexpectedly"); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
120 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
121 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
122 |
if (expectedExitCode != Integer.MIN_VALUE |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
123 |
&& result.exitCode != expectedExitCode) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
124 |
result.writeAll(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
125 |
throw new TaskError("Task " + name() + "failed with unexpected exit code " |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
126 |
+ result.exitCode + ", expected " + expectedExitCode); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
127 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
128 |
break; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
129 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
130 |
return result; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
131 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
132 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
133 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
134 |
* Sets an environment variable to be used by this task. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
135 |
* @param name the name of the environment variable |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
136 |
* @param value the value for the environment variable |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
137 |
* @return this task object |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
138 |
* @throws IllegalStateException if the task mode is not {@code EXEC} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
139 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
140 |
public T envVar(String name, String value) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
141 |
if (mode != Mode.EXEC) |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
142 |
throw new IllegalStateException(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
143 |
envVars.put(name, value); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
144 |
return (T) this; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
145 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
146 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
147 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
148 |
* Redirects output from an output stream to a file. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
149 |
* @param outputKind the name of the stream to be redirected. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
150 |
* @param path the file |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
151 |
* @return this task object |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
152 |
* @throws IllegalStateException if the task mode is not {@code EXEC} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
153 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
154 |
public T redirect(OutputKind outputKind, String path) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
155 |
if (mode != Mode.EXEC) |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
156 |
throw new IllegalStateException(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
157 |
redirects.put(outputKind, path); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
158 |
return (T) this; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
159 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
160 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
161 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
162 |
* Returns a {@code ProcessBuilder} initialized with any |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
163 |
* redirects and environment variables that have been set. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
164 |
* @return a {@code ProcessBuilder} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
165 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
166 |
protected ProcessBuilder getProcessBuilder() { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
167 |
if (mode != Mode.EXEC) |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
168 |
throw new IllegalStateException(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
169 |
ProcessBuilder pb = new ProcessBuilder(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
170 |
if (redirects.get(OutputKind.STDOUT) != null) |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
171 |
pb.redirectOutput(new File(redirects.get(OutputKind.STDOUT))); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
172 |
if (redirects.get(OutputKind.STDERR) != null) |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
173 |
pb.redirectError(new File(redirects.get(OutputKind.STDERR))); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
174 |
pb.environment().putAll(envVars); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
175 |
return pb; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
176 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
177 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
178 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
179 |
* Collects the output from a process and saves it in a {@code Result}. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
180 |
* @param tb the {@code ToolBox} containing the task {@code t} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
181 |
* @param t the task initiating the process |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
182 |
* @param p the process |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
183 |
* @return a Result object containing the output from the process and its |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
184 |
* exit value. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
185 |
* @throws InterruptedException if the thread is interrupted |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
186 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
187 |
protected Result runProcess(ToolBox tb, Task t, Process p) throws InterruptedException { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
188 |
if (mode != Mode.EXEC) |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
189 |
throw new IllegalStateException(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
190 |
ProcessOutput sysOut = new ProcessOutput(p.getInputStream()).start(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
191 |
ProcessOutput sysErr = new ProcessOutput(p.getErrorStream()).start(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
192 |
sysOut.waitUntilDone(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
193 |
sysErr.waitUntilDone(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
194 |
int rc = p.waitFor(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
195 |
Map<OutputKind, String> outputMap = new EnumMap<>(OutputKind.class); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
196 |
outputMap.put(OutputKind.STDOUT, sysOut.getOutput()); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
197 |
outputMap.put(OutputKind.STDERR, sysErr.getOutput()); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
198 |
return checkExit(new Result(toolBox, t, rc, outputMap)); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
199 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
200 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
201 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
202 |
* Thread-friendly class to read the output from a process until the stream |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
203 |
* is exhausted. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
204 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
205 |
static class ProcessOutput implements Runnable { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
206 |
ProcessOutput(InputStream from) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
207 |
in = new BufferedReader(new InputStreamReader(from)); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
208 |
out = new StringBuilder(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
209 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
210 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
211 |
ProcessOutput start() { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
212 |
new Thread(this).start(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
213 |
return this; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
214 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
215 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
216 |
@Override |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
217 |
public void run() { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
218 |
try { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
219 |
String line; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
220 |
while ((line = in.readLine()) != null) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
221 |
out.append(line).append(lineSeparator); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
222 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
223 |
} catch (IOException e) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
224 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
225 |
synchronized (this) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
226 |
done = true; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
227 |
notifyAll(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
228 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
229 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
230 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
231 |
synchronized void waitUntilDone() throws InterruptedException { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
232 |
boolean interrupted = false; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
233 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
234 |
// poll interrupted flag, while waiting for copy to complete |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
235 |
while (!(interrupted = Thread.interrupted()) && !done) |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
236 |
wait(1000); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
237 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
238 |
if (interrupted) |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
239 |
throw new InterruptedException(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
240 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
241 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
242 |
String getOutput() { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
243 |
return out.toString(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
244 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
245 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
246 |
private final BufferedReader in; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
247 |
private final StringBuilder out; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
248 |
private boolean done; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
249 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
250 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
251 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
252 |
* Utility class to simplify the handling of temporarily setting a |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
253 |
* new stream for System.out or System.err. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
254 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
255 |
static class StreamOutput { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
256 |
// Functional interface to set a stream. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
257 |
// Expected use: System::setOut, System::setErr |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
258 |
interface Initializer { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
259 |
void set(PrintStream s); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
260 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
261 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
262 |
private final ByteArrayOutputStream baos = new ByteArrayOutputStream(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
263 |
private final PrintStream ps = new PrintStream(baos); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
264 |
private final PrintStream prev; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
265 |
private final Initializer init; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
266 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
267 |
StreamOutput(PrintStream s, Initializer init) { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
268 |
prev = s; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
269 |
init.set(ps); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
270 |
this.init = init; |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
271 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
272 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
273 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
274 |
* Closes the stream and returns the contents that were written to it. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
275 |
* @return the contents that were written to it. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
276 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
277 |
String close() { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
278 |
init.set(prev); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
279 |
ps.close(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
280 |
return baos.toString(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
281 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
282 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
283 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
284 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
285 |
* Utility class to simplify the handling of creating an in-memory PrintWriter. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
286 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
287 |
static class WriterOutput { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
288 |
private final StringWriter sw = new StringWriter(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
289 |
final PrintWriter pw = new PrintWriter(sw); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
290 |
|
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
291 |
/** |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
292 |
* Closes the stream and returns the contents that were written to it. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
293 |
* @return the contents that were written to it. |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
294 |
*/ |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
295 |
String close() { |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
296 |
pw.close(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
297 |
return sw.toString(); |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
298 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
299 |
} |
e04318f39f92
8152897: refactor ToolBox to allow reduced documented dependencies
jjg
parents:
diff
changeset
|
300 |
} |