1
2
3
4
5
6
7
8
9
10
11
12
13 package com.eviware.soapui.support.log;
14
15 import java.util.HashSet;
16 import java.util.Set;
17
18 import org.apache.log4j.Level;
19 import org.apache.log4j.Logger;
20
21 import com.eviware.soapui.SoapUI;
22 import com.eviware.soapui.model.testsuite.LoadTestRunner;
23 import com.eviware.soapui.monitor.support.TestMonitorListenerAdapter;
24 import com.eviware.soapui.settings.UISettings;
25
26 /***
27 * Disables httpclient and groovy logs during loadtests
28 *
29 * @author ole
30 */
31
32 public final class LogDisablingTestMonitorListener extends TestMonitorListenerAdapter
33 {
34 private Set<LoadTestRunner> loadTestRunners = new HashSet<LoadTestRunner>();
35
36 public void loadTestStarted( LoadTestRunner runner )
37 {
38 if( loadTestRunners.isEmpty() )
39 {
40 Logger.getLogger( SoapUI.class ).info( "Disabling logs during loadtests" );
41 Logger.getLogger( "httpclient.wire" ).setLevel( Level.OFF );
42
43 if( !SoapUI.getSettings().getBoolean( UISettings.DONT_DISABLE_GROOVY_LOG ) )
44 Logger.getLogger( "groovy.log" ).setLevel( Level.OFF );
45 }
46
47 loadTestRunners.add( runner );
48 }
49
50 public void loadTestFinished( LoadTestRunner runner )
51 {
52 loadTestRunners.remove( runner );
53
54 if( loadTestRunners.isEmpty() )
55 {
56 Logger.getLogger( "httpclient.wire" ).setLevel( Level.DEBUG );
57 Logger.getLogger( "groovy.log" ).setLevel( Level.DEBUG );
58 Logger.getLogger( SoapUI.class ).info( "Enabled logs after loadtests" );
59 }
60 }
61 }