/**
*
* Copyright 2005 The Apache Software Foundation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.geronimo.system.logging.log4j;
import org.apache.log4j.Logger;
import org.apache.log4j.Priority;
/**
* @version $Rev$ $Date$
*/
final class MockLogger extends Logger {
final static String MOCK_NAME = "MOCK_NAME";
boolean isEnabledForCalled = false;
Priority calledWithPriority = null;
boolean logCalled = false;
Object calledWithObject;
Throwable calledWithThrowable;
String calledWithString;
boolean isDebugEnabledCalled;
boolean isInfoEnabledCalled;
private boolean debugEnabled = false;
private boolean infoEnabled = false;
private boolean enabledFor = false;
final Object isEnabledForLock = new Object();
MockLogger(String str) {
super(str);
}
public boolean isEnabledFor(Priority priority) {
synchronized (isEnabledForLock) {
isEnabledForCalled = true;
calledWithPriority = priority;
if (isEnabledForCalled && isDebugEnabledCalled && isInfoEnabledCalled) isEnabledForLock.notifyAll();
return enabledFor;
}
}
public boolean isDebugEnabled() {
synchronized (isEnabledForLock) {
isDebugEnabledCalled = true;
if (isEnabledForCalled && isDebugEnabledCalled && isInfoEnabledCalled) isEnabledForLock.notifyAll();
return debugEnabled;
}
}
public boolean isInfoEnabled() {
synchronized (isEnabledForLock) {
isInfoEnabledCalled = true;
if (isEnabledForCalled && isDebugEnabledCalled && isInfoEnabledCalled) isEnabledForLock.notifyAll();
return infoEnabled;
}
}
public void log(String s, Priority priority, Object o, Throwable throwable) {
logCalled = true;
calledWithString = s;
calledWithPriority = priority;
calledWithObject = o;
calledWithThrowable = throwable;
}
public void setEnabledFor(boolean enabledFor) {
this.enabledFor = enabledFor;
}
public void setDebugEnabled(boolean debugEnabled) {
this.debugEnabled = debugEnabled;
}
public void setInfoEnabled(boolean infoEnabled) {
this.infoEnabled = infoEnabled;
}
}