summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRüdiger Timm <rt@openoffice.org>2008-06-13 11:45:59 +0000
committerRüdiger Timm <rt@openoffice.org>2008-06-13 11:45:59 +0000
commit3b106531b84021e3419ef838c26e95142a91a4bc (patch)
treee7e6551e5e0751a463b41a8550f2c573d7b1ca39
parentbae3824dd7ae034c9aea209ae1f49b91a03c7b8b (diff)
INTEGRATION: CWS qadev32 (1.12.2); FILE MERGED
2008/05/28 12:17:02 cn 1.12.2.8: #i87389# optimize waiting while process is ongoing, enhance logging 2008/05/05 09:23:49 cn 1.12.2.7: #i85370# enhance logging 2008/04/17 11:40:37 cn 1.12.2.6: RESYNC: (1.12-1.13); FILE MERGED 2008/04/17 07:56:15 cn 1.12.2.5: #i87389# enhance logging 2008/04/03 07:57:36 cn 1.12.2.4: #i87389# enhance logging 2008/03/05 11:18:40 cn 1.12.2.3: #i85370# new constructor 2008/01/22 11:46:49 cn 1.12.2.2: #i85370#: runCommand(): validation of param != null 2008/01/21 16:29:19 cn 1.12.2.1: #i85370# new method runCommand()
-rw-r--r--qadevOOo/runner/helper/ProcessHandler.java341
1 files changed, 228 insertions, 113 deletions
diff --git a/qadevOOo/runner/helper/ProcessHandler.java b/qadevOOo/runner/helper/ProcessHandler.java
index 85b95eaf2b38..0e2638b7f1be 100644
--- a/qadevOOo/runner/helper/ProcessHandler.java
+++ b/qadevOOo/runner/helper/ProcessHandler.java
@@ -7,7 +7,7 @@
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: ProcessHandler.java,v $
- * $Revision: 1.13 $
+ * $Revision: 1.14 $
*
* This file is part of OpenOffice.org.
*
@@ -27,18 +27,18 @@
* for a copy of the LGPLv3 License.
*
************************************************************************/
-
package helper;
import java.io.InputStream;
import java.io.File;
-import java.io.FileFilter;
-import java.util.ArrayList;
import java.io.PrintWriter;
import java.io.PrintStream;
import java.io.LineNumberReader;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
+import lib.TestParameters;
+import util.PropertyName;
+import util.utils;
/**
* Class collect information from input stream in
@@ -52,10 +52,11 @@ import java.io.OutputStreamWriter;
* internally only.
*/
class Pump extends Thread {
+
private LineNumberReader reader;
- private String pref ;
+ private String pref;
private StringBuffer buf = new StringBuffer(256);
- private PrintWriter log ;
+ private PrintWriter log;
/**
* Creates Pump for specified <code>InputStream</code>.
@@ -69,23 +70,23 @@ class Pump extends Thread {
* beginning of each output line.
*/
public Pump(InputStream is, PrintWriter log, String outPrefix) {
- this.pref = outPrefix == null ? "" : outPrefix ;
+ this.pref = outPrefix == null ? "" : outPrefix;
reader = new LineNumberReader(new InputStreamReader(is));
- this.log = log ;
- start() ;
+ this.log = log;
+ start();
}
public void run() {
try {
- String line = reader.readLine() ;
+ String line = reader.readLine();
while (line != null) {
log.println(pref + line);
log.flush();
buf.append(line).append('\n');
- line = reader.readLine() ;
+ line = reader.readLine();
}
} catch (java.io.IOException e) {
- log.println(pref + "Exception occured: " + e) ;
+ log.println(pref + "Exception occured: " + e);
}
}
@@ -105,29 +106,30 @@ class Pump extends Thread {
* should create a new instance for this.
*/
public class ProcessHandler {
+
private String cmdLine;
private String[] cmdLineArray;
private String[] envVars = null;
private File workDir = null;
private PrintWriter log;
-
private int exitValue = -1;
private boolean isFinished = false;
private boolean isStarted = false;
private boolean mbTimedOut = false;
private long mTimeOut = 0;
-
private String stdInBuff = "";
- private Pump stdout = null ;
- private Pump stderr = null ;
- private PrintStream stdIn = null ;
-
- private Process proc = null ;
+ private Pump stdout = null;
+ private Pump stderr = null;
+ private PrintStream stdIn = null;
+ private Process proc = null;
+ private TestParameters param = null;
+ private boolean debug = false;
/**
* Creates instance with specified external command.
* Debug info and output
* of external command is printed to stdout.
+ * @param cmdLine
*/
public ProcessHandler(String cmdLine) {
this(cmdLine, null, null, null, 0);
@@ -140,11 +142,10 @@ public class ProcessHandler {
* of external command is printed to stdout.
* @param cmdLines
*/
- public ProcessHandler(String[] cmdLines)
- {
- this(null, null, null, null, 0);
- cmdLineArray = cmdLines;
- }
+ public ProcessHandler(String[] cmdLines) {
+ this(null, null, null, null, 0);
+ cmdLineArray = cmdLines;
+ }
/**
* Creates instance with specified external command
@@ -156,11 +157,10 @@ public class ProcessHandler {
* @param envVars
* @see java.lang.Runtime exec(String[], String[])
*/
- public ProcessHandler(String[] cmdLines, String[] envVars)
- {
- this(null, null, null, envVars, 0);
- cmdLineArray = cmdLines;
- }
+ public ProcessHandler(String[] cmdLines, String[] envVars) {
+ this(null, null, null, envVars, 0);
+ cmdLineArray = cmdLines;
+ }
/**
* Creates instance with specified external command
@@ -172,8 +172,8 @@ public class ProcessHandler {
* @param workDir
*/
public ProcessHandler(String[] cmdLines, File workDir) {
- this(null, null, workDir, null, 0);
- cmdLineArray = cmdLines;
+ this(null, null, workDir, null, 0);
+ cmdLineArray = cmdLines;
}
@@ -186,25 +186,37 @@ public class ProcessHandler {
* @param workDir
*/
public ProcessHandler(String[] cmdLines, PrintWriter log, File workDir) {
- this(null, log, workDir, null, 0);
- cmdLineArray = cmdLines;
+ this(null, log, workDir, null, 0);
+ cmdLineArray = cmdLines;
}
-
/**
* Creates instance with specified external command and
* log stream where debug info and output
* of external command is printed out.
+ * @param cmdLine
+ * @param log
*/
public ProcessHandler(String cmdLine, PrintWriter log) {
this(cmdLine, log, null, null, 0);
}
/**
+ * Creates instance with specified external command and set the time out for the command.
+ * @param cmdLine
+ * @param timeOut
+ */
+ public ProcessHandler(String cmdLine, int timeOut) {
+ this(cmdLine, null, null, null, timeOut);
+ }
+
+ /**
* Creates instance with specified external command which
* will be executed in the some work directory.
* Debug info and output
* of external commandis printed to stdout.
+ * @param cmdLine
+ * @param workDir
*/
public ProcessHandler(String cmdLine, File workDir) {
this(cmdLine, null, workDir, null, 0);
@@ -214,6 +226,9 @@ public class ProcessHandler {
* Creates instance with specified external command which
* will be executed in the some work directory.
* Debug info and output printed in log stream.
+ * @param cmdLine
+ * @param log
+ * @param workDir
*/
public ProcessHandler(String cmdLine, PrintWriter log, File workDir) {
this(cmdLine, log, workDir, null, 0);
@@ -231,8 +246,7 @@ public class ProcessHandler {
* @param workDir
* @param envVars
*/
- public ProcessHandler(String cmdLine, PrintWriter log,
- File workDir, String[] envVars) {
+ public ProcessHandler(String cmdLine, PrintWriter log, File workDir, String[] envVars) {
this(cmdLine, log, workDir, envVars, 0);
}
@@ -264,25 +278,99 @@ public class ProcessHandler {
*
*
*/
- public ProcessHandler(String cmdLine, PrintWriter log,
- File workDir, String[] envVars, long timeOut) {
- this.cmdLine = cmdLine ;
+ public ProcessHandler(String cmdLine, PrintWriter log, File workDir, String[] envVars, long timeOut) {
+ this.cmdLine = cmdLine;
this.workDir = workDir;
this.log = log;
- this.cmdLine = cmdLine ;
+ this.cmdLine = cmdLine;
this.envVars = envVars;
- if (log == null)
- this.log = new PrintWriter(new OutputStreamWriter(System.out));
- else
+ if (log == null) {
+ this.log = new PrintWriter(new OutputStreamWriter(System.out));
+ } else {
this.log = log;
+ }
this.mTimeOut = timeOut;
}
- public boolean isTimedOut(){
+ /**
+ * Creates instance with specified external command which
+ * will be executed in the some work directory and
+ * log stream where debug info and output of external command is printed.
+ * If log stream is null, logging is printed to stdout.
+ * From the <CODE>TestParameters</CODE> the <CODE>OfficeWachter</CODE> get a ping.
+ * @param commands
+ * @param log
+ * @param workDir
+ * @param shortWait If this parameter is ture the <CODE>mTimeOut</CODE> is set to 3000 ms, else it is set to
+ * half of time out from parameter timeout.
+ * @param param the TestParameters
+ * @see lib.TestParameters
+ * @see helper.OfficeWatcher
+ */
+ public ProcessHandler(String[] commands, PrintWriter log, File workDir, boolean shortWait, TestParameters param) {
+ this(null, log, workDir, null, 0);
+ this.cmdLineArray = commands;
+ this.param = param;
+ if (shortWait) {
+ this.mTimeOut = 5000;
+ } else {
+ this.mTimeOut = (long) (param.getInt(PropertyName.TIME_OUT) / 1.3);
+ }
+ debug = param.getBool(PropertyName.DEBUG_IS_ACTIVE);
+
+ }
+
+ /**
+ * This method do an asynchronous execution of the commands. To avoid a interruption on long running processes
+ * caused by <CODE>OfficeWatcher</CODE>, the OfficeWatcher get frequently a ping.
+ * @see helper.OfficeWatcher
+ */
+ public void runCommand() {
+
+ boolean changedText = true;
+ int count = 0;
+ String memText = "";
+
+ this.executeAsynchronously();
+
+ OfficeWatcher ow = null;
+ if (param != null) {
+ ow = (OfficeWatcher) param.get(PropertyName.OFFICE_WATCHER);
+ }
+
+ while (changedText && !this.isFinished()) {
+ count++;
+ if (ow != null) {
+ ow.ping();
+ }
+ dbg("runCommand: waiting " + mTimeOut / 1000 + " seconds while command execution is ongoing... " + count);
+ shortWait(mTimeOut);
+
+ if (ow != null) {
+ ow.ping();
+ }
+ // check for changes in the output stream. If there are no changes, the process maybe hangs
+ if (!this.isFinished()) {
+ if (this.getOutputText().equals(memText)) {
+ changedText = false;
+ dbg("runCommand Could not detect changes in output stream!!!");
+
+ }
+ memText = this.getOutputText();
+ }
+ }
+
+ if (!this.isFinished()) {
+ dbg("runCommand Process ist not finished but there are no changes in output stream.");
+ this.kill();
+ }
+ }
+
+ public boolean isTimedOut() {
return mbTimedOut;
}
- private void setTimedOut(boolean bTimedOut){
+ private void setTimedOut(boolean bTimedOut) {
mbTimedOut = bTimedOut;
}
@@ -295,8 +383,8 @@ public class ProcessHandler {
* to this result).
*/
public boolean executeSynchronously() {
- execute() ;
- return waitFor(mTimeOut) ;
+ execute();
+ return waitFor(mTimeOut);
}
/**
@@ -308,32 +396,34 @@ public class ProcessHandler {
* started.
*/
public boolean executeAsynchronously() {
- execute() ;
- return isStarted() ;
+ execute();
+ return isStarted();
}
public synchronized void kill() {
- if (!isStarted()) return;
+ if (!isStarted()) {
+ return;
+ }
boolean exit = false;
- int counter=1;
- while(counter < 3 && !exit) {
+ int counter = 1;
+ while (counter < 3 && !exit) {
proc.destroy();
- try{
- Thread.sleep(5000*counter);
+ try {
+ Thread.sleep(5000 * counter);
+ } catch (java.lang.InterruptedException e) {
}
- catch(java.lang.InterruptedException e){}
try {
- int exitValue = proc.exitValue();
- if (exitValue<1)
+ final int exit_Value = proc.exitValue();
+ if (exit_Value < 1) {
exit = true;
- else
+ } else {
counter++;
- System.out.println("# Office closed with exit code "+exitValue);
- }
- catch(java.lang.IllegalThreadStateException e) {
- if (counter<3) {
- System.out.println("# Couldn't close office after "+counter+" attempts, trying again");
+ }
+ dbg("kill: process closed with exit code " + exit_Value);
+ } catch (java.lang.IllegalThreadStateException e) {
+ if (counter < 3) {
+ dbg("kill: Couldn't close process after " + counter + " attempts, trying again");
}
counter++;
}
@@ -344,49 +434,44 @@ public class ProcessHandler {
protected void execute() {
if (isStarted()) {
throw new RuntimeException(
- "The process handler has already been executed.") ;
+ "The process handler has already been executed.");
}
- Runtime runtime = Runtime.getRuntime() ;
+ final Runtime runtime = Runtime.getRuntime();
try {
- if (cmdLine == null)
- {
- log.print("Starting command from array: " );
- for(int i = 0;i<cmdLineArray.length;i++)
- {
+ if (cmdLine == null) {
+ log.print(utils.getDateTime() + "execute: Starting command from array: ");
+ for (int i = 0; i < cmdLineArray.length; i++) {
log.print(cmdLineArray[i]);
log.print(" ");
}
- log.println();
proc = runtime.exec(cmdLineArray, envVars);
- }
- else
- {
- log.println("Starting command: " + cmdLine) ;
+ } else {
if (workDir != null) {
- log.println("Starting command: " + cmdLine + " " + workDir.getAbsolutePath()) ;
- proc = runtime.exec(cmdLine, envVars, workDir) ;
+ log.println(utils.getDateTime() + "execute: Starting command: " + cmdLine + " " +
+ workDir.getAbsolutePath());
+ proc = runtime.exec(cmdLine, envVars, workDir);
} else {
- proc = runtime.exec(cmdLine, envVars) ;
+ log.println(utils.getDateTime() + "execute: Starting command: " + cmdLine);
+ proc = runtime.exec(cmdLine, envVars);
}
}
- isStarted = true ;
- } catch (java.io.IOException e)
- {
- if (cmdLine == null)
- {
- log.println("The command array can't be started: " + e);
- }
- else
- {
- log.println("The command " + cmdLine + " can't be started: " + e);
+ isStarted = true;
+ } catch (java.io.IOException e) {
+ if (cmdLine == null) {
+ log.println(utils.getDateTime() + "execute: The command array can't be started: " + e);
+ } else {
+ log.println(utils.getDateTime() + "execute: The command " + cmdLine + " can't be started: " + e);
}
return;
}
+ dbg("execute: pump io-streams");
stdout = new Pump(proc.getInputStream(), log, "out > ");
stderr = new Pump(proc.getErrorStream(), log, "err > ");
- stdIn = new PrintStream(proc.getOutputStream()) ;
+ stdIn = new PrintStream(proc.getOutputStream());
+
+ dbg("execute: flush io-streams");
- flushInput() ;
+ flushInput();
}
/**
@@ -398,7 +483,7 @@ public class ProcessHandler {
* (exit code doesn't affect to this result).
*/
public boolean waitFor() {
- return waitFor(0) ;
+ return waitFor(0);
}
/**
@@ -406,7 +491,7 @@ public class ProcessHandler {
* asynchronously. Waits during specified time for process
* to exit and return its status.
*
- * @param timeOut > 0
+ * @param timeout > 0
* Waits specified time in miliSeconds for
* process to exit and return its status.
*
@@ -420,32 +505,37 @@ public class ProcessHandler {
* (exit code doesn't affect to this result).
*/
public boolean waitFor(long timeout) {
- if (isFinished()) return true ;
- if (!isStarted()) return false ;
+ if (isFinished()) {
+ return true;
+ }
+ if (!isStarted()) {
+ return false;
+ }
if (timeout == 0) {
try {
- proc.waitFor() ;
+ proc.waitFor();
} catch (InterruptedException e) {
log.println("The process was interrupted: " + e);
}
- isFinished = true ;
+ isFinished = true;
try {
- exitValue = proc.exitValue() ;
- } catch (IllegalThreadStateException e) {}
+ exitValue = proc.exitValue();
+ } catch (IllegalThreadStateException e) {
+ }
} else {
try {
while (!isFinished && timeout > 0) {
isFinished = true;
Thread.sleep(1000);
- timeout -= 1000 ;
+ timeout -= 1000;
try {
exitValue = proc.exitValue(); // throws exception if not finished
} catch (IllegalThreadStateException e) {
isFinished = false;
}
}
- if(timeout < 0){
+ if (timeout < 0) {
setTimedOut(true);
log.println("The process has timed out!");
}
@@ -465,36 +555,43 @@ public class ProcessHandler {
// stderr.join();
// } catch (InterruptedException e) {}
- return isFinished() ;
+ return isFinished();
}
protected void flushInput() {
- if (stdIn == null) return ;
+ if (stdIn == null) {
+ return;
+ }
- synchronized(stdInBuff) {
+ synchronized (stdInBuff) {
stdIn.print(stdInBuff);
stdIn.flush();
- stdInBuff = "" ;
+ stdInBuff = "";
}
}
/**
* Returns the text output by external command to stdout.
+ * @return the text output by external command to stdout
*/
public String getOutputText() {
- if (stdout == null)
+ if (stdout == null) {
return "";
- else
+ } else {
return stdout.getStringBuffer();
+ }
}
+
/**
* Returns the text output by external command to stderr.
+ * @return the text output by external command to stderr
*/
public String getErrorText() {
- if (stderr == null)
+ if (stderr == null) {
return "";
- else
+ } else {
return stderr.getStringBuffer();
+ }
}
/**
@@ -505,9 +602,10 @@ public class ProcessHandler {
* The method can also be called before the command
* starts its execution. Then the text is buffered
* and transfered to command when it will be started.
+ * @param str
*/
public void printInputText(String str) {
- stdInBuff += str ;
+ stdInBuff += str;
flushInput();
}
@@ -519,7 +617,7 @@ public class ProcessHandler {
* found and successfully started.
*/
public boolean isStarted() {
- return isStarted ;
+ return isStarted;
}
/**
@@ -530,7 +628,7 @@ public class ProcessHandler {
* exits and was not interrupted due to timeout.
*/
public boolean isFinished() {
- return isFinished ;
+ return isFinished;
}
/**
@@ -543,9 +641,26 @@ public class ProcessHandler {
try {
exitValue = proc.exitValue();
} catch (Exception e) {
- //System.out.println("No ExitValue available");
+ //System.out.println("No ExitValue available");
+ }
+
+ return exitValue;
+ }
+
+ /** Causes the thread to sleep some time.
+ * @param milliseconds
+ */
+ public static void shortWait(long milliseconds) {
+ try {
+ Thread.sleep(milliseconds);
+ } catch (InterruptedException e) {
+ System.out.println("While waiting :" + e);
}
+ }
- return exitValue ;
+ private void dbg(String message) {
+ if (debug) {
+ log.println(utils.getDateTime() + "PH." + message);
+ }
}
}