View Javadoc

1   /*
2    * Copyright 2005-2007 The Kuali Foundation
3    * 
4    * 
5    * Licensed under the Educational Community License, Version 2.0 (the "License");
6    * you may not use this file except in compliance with the License.
7    * You may obtain a copy of the License at
8    * 
9    * http://www.opensource.org/licenses/ecl2.php
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  package org.kuali.rice.kew.util;
18  
19  /**
20   * Records and logs performance information about an elapsed time period.
21   * 
22   * @author Kuali Rice Team (rice.collab@kuali.org)
23   */
24  public class PerformanceLogger {
25  
26      private static final org.apache.log4j.Logger LOG =
27          org.apache.log4j.Logger.getLogger(PerformanceLogger.class);
28      private long startTime;
29      private String documentId;
30      
31      public PerformanceLogger() {
32          recordStartTime();
33      }
34      
35      public PerformanceLogger(String documentId) {
36          this();
37          this.documentId = documentId;
38      }
39      
40      private void recordStartTime() {
41          this.startTime = System.currentTimeMillis();
42      }
43      
44      public void log(String message) {
45          log(message, false);
46      }
47  
48      public void log(String message, boolean terminalPoint) {
49      	if ( LOG.isInfoEnabled() ) {
50  	        long endTime = System.currentTimeMillis();
51  	        long totalTime = endTime - startTime;
52  	        String logMessage = "Time: "+totalTime+" ms, ";
53  	        if (documentId != null) {
54  	            logMessage+="docId="+documentId+", ";
55  	        }
56  	        logMessage += message;
57  	        if (terminalPoint) {
58  	            logMessage += "\n";
59  	        }
60  	        LOG.info(logMessage);
61      	}
62      }
63      
64  }