xref: /AOO42X/main/qadevOOo/runner/helper/LoggingThread.java (revision b0efeae40e43e6d4ccd561d22ec612d42773857b)
1ef39d40dSAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3ef39d40dSAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4ef39d40dSAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5ef39d40dSAndrew Rist  * distributed with this work for additional information
6ef39d40dSAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7ef39d40dSAndrew Rist  * to you under the Apache License, Version 2.0 (the
8ef39d40dSAndrew Rist  * "License"); you may not use this file except in compliance
9ef39d40dSAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11ef39d40dSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13ef39d40dSAndrew Rist  * Unless required by applicable law or agreed to in writing,
14ef39d40dSAndrew Rist  * software distributed under the License is distributed on an
15ef39d40dSAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16ef39d40dSAndrew Rist  * KIND, either express or implied.  See the License for the
17ef39d40dSAndrew Rist  * specific language governing permissions and limitations
18ef39d40dSAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20ef39d40dSAndrew Rist  *************************************************************/
21ef39d40dSAndrew Rist 
22ef39d40dSAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir package helper;
25cdf0e10cSrcweir 
26cdf0e10cSrcweir import share.*;
27cdf0e10cSrcweir import lib.TestParameters;
28cdf0e10cSrcweir import util.PropertyName;
29cdf0e10cSrcweir import util.utils;
30cdf0e10cSrcweir 
31cdf0e10cSrcweir /**
32bb6af6bcSPedro Giffuni  * This class is printing to a <CODE>LogWriter</CODE>. This could be useful if a UNO-API
33*fb0b81f5Smseidel  * function runs longer than the time out. To avoid the assumption of death application
34cdf0e10cSrcweir  * a simple string is logged for 100 times of time out.</br>
35cdf0e10cSrcweir  * Example:</br>
36cdf0e10cSrcweir  *          logger = new LoggingThread((LogWriter)log, tParam);
37cdf0e10cSrcweir  *          logger.start();
38cdf0e10cSrcweir  *          oObj.longRunningFunction();
39cdf0e10cSrcweir  *          logger.finish();
40cdf0e10cSrcweir  *
41cdf0e10cSrcweir  */
42cdf0e10cSrcweir public class LoggingThread extends Thread {
43cdf0e10cSrcweir 
44cdf0e10cSrcweir     TestParameters param;
45cdf0e10cSrcweir     LogWriter log = null;
46cdf0e10cSrcweir     boolean finished = false;
47cdf0e10cSrcweir     boolean debug = false;
48cdf0e10cSrcweir 
49cdf0e10cSrcweir     /**
50cdf0e10cSrcweir      *
51cdf0e10cSrcweir      * @param log
52cdf0e10cSrcweir      * @param tParam
53cdf0e10cSrcweir      */
LoggingThread(LogWriter log, TestParameters tParam)54cdf0e10cSrcweir     public LoggingThread(LogWriter log, TestParameters tParam) {
55cdf0e10cSrcweir         this.log = log;
56cdf0e10cSrcweir         this.param = tParam;
57cdf0e10cSrcweir         this.debug = tParam.getBool(PropertyName.DEBUG_IS_ACTIVE);
58cdf0e10cSrcweir     }
59cdf0e10cSrcweir 
run()60cdf0e10cSrcweir     public void run() {
61cdf0e10cSrcweir         final int timeOut = param.getInt(PropertyName.TIME_OUT) / 2;
62cdf0e10cSrcweir         int count = 0;
63cdf0e10cSrcweir         finished = false;
64cdf0e10cSrcweir         if (debug) log.println("TimeOutLogger: " + utils.getDateTime() + " start");
65cdf0e10cSrcweir         while (!finished && count < 200) {
66cdf0e10cSrcweir             try {
67cdf0e10cSrcweir                 if (debug) log.println("TimeOutLogger: "+utils.getDateTime() + count);
68cdf0e10cSrcweir                 synchronized (this) {
69cdf0e10cSrcweir                     wait(timeOut);
70cdf0e10cSrcweir                 }
71cdf0e10cSrcweir                 count++;
72cdf0e10cSrcweir             } catch (InterruptedException ex) {
73cdf0e10cSrcweir             }
74cdf0e10cSrcweir         }
75cdf0e10cSrcweir         if (debug) log.println("TimeOutLogger: " + utils.getDateTime() + " finished");
76cdf0e10cSrcweir     }
77cdf0e10cSrcweir 
78cdf0e10cSrcweir     /**
79cdf0e10cSrcweir      * finished the LoggingThread
80cdf0e10cSrcweir      */
finish()81cdf0e10cSrcweir     public void finish() {
82cdf0e10cSrcweir         try {
83cdf0e10cSrcweir             finished = true;
84cdf0e10cSrcweir             synchronized (this) {
85cdf0e10cSrcweir                 notify();
86cdf0e10cSrcweir             }
87cdf0e10cSrcweir             if (debug) log.println("TimeOutLogger: " + utils.getDateTime() + " try to finish ");
88cdf0e10cSrcweir             sleep(1000);
89cdf0e10cSrcweir         } catch (InterruptedException ex) {
90cdf0e10cSrcweir         }
91cdf0e10cSrcweir     }
92cdf0e10cSrcweir }
93