com.applitools.eyes.Logger Maven / Gradle / Ivy
package com.applitools.eyes;
/**
* Logs trace messages.
*/
public class Logger {
private LogHandler logHandler;
private String sessionId;
public Logger() {
logHandler = new NullLogHandler();
sessionId = "";
}
public void setSessionId(String sessionId) {
this.sessionId = sessionId;
}
/**
* @return The currently set log handler.
*/
public LogHandler getLogHandler() {
return logHandler;
}
/**
* Sets the log handler.
* @param handler The log handler to set. If you want a log handler which
* does nothing, use {@link
* com.applitools.eyes.NullLogHandler}.
*/
public void setLogHandler(LogHandler handler) {
logHandler = handler == null ? NullLogHandler.instance : handler;
}
/**
*
* @return The name of the method which called the logger, if possible,
* or an empty string.
*/
private String getPrefix() {
StackTraceElement[] stackTraceElements =
Thread.currentThread().getStackTrace();
String prefix = "{" + sessionId + "} ";
// getStackTrace()<-getPrefix()<-log()/verbose()<-"actual caller"
if (stackTraceElements.length >= 4) {
prefix += stackTraceElements[3].getClassName() + "."+ stackTraceElements[3].getMethodName() + "(): ";
}
return prefix;
}
/**
* Writes a verbose write message.
* @param message The message to log as verbose.
*/
public void verbose(String message) {
logHandler.onMessage(true, "[VERBOSE] " + getPrefix() + message);
}
/**
* Writes a (non-verbose) write message.
* @param message The message to log.
*/
public void log(String message) {
logHandler.onMessage(false, "[LOG ] " + getPrefix() + message);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy