xref: /AOO41X/main/qadevOOo/runner/helper/LoggingThread.java (revision ef39d40d3f5e66cf3f035b3e93783012b340500d)
1*ef39d40dSAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*ef39d40dSAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*ef39d40dSAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*ef39d40dSAndrew Rist  * distributed with this work for additional information
6*ef39d40dSAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*ef39d40dSAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*ef39d40dSAndrew Rist  * "License"); you may not use this file except in compliance
9*ef39d40dSAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11*ef39d40dSAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13*ef39d40dSAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*ef39d40dSAndrew Rist  * software distributed under the License is distributed on an
15*ef39d40dSAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*ef39d40dSAndrew Rist  * KIND, either express or implied.  See the License for the
17*ef39d40dSAndrew Rist  * specific language governing permissions and limitations
18*ef39d40dSAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20*ef39d40dSAndrew Rist  *************************************************************/
21*ef39d40dSAndrew Rist 
22*ef39d40dSAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir package helper;
25cdf0e10cSrcweir 
26cdf0e10cSrcweir import share.*;
27cdf0e10cSrcweir import lib.TestParameters;
28cdf0e10cSrcweir import util.PropertyName;
29cdf0e10cSrcweir import util.utils;
30cdf0e10cSrcweir 
31cdf0e10cSrcweir /**
32cdf0e10cSrcweir  * This class is printing to a <CODE>LogWriter</CODE>. This could be usefull if a UNO-API
33cdf0e10cSrcweir  * function runns longer the the time out. To avoid the assumption of death applikation
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