mirror of
https://gitee.com/chinabugotech/hutool.git
synced 2025-08-18 20:38:02 +08:00
clean history
This commit is contained in:
105
hutool-log/src/test/java/cn/hutool/log/test/CustomLogTest.java
Normal file
105
hutool-log/src/test/java/cn/hutool/log/test/CustomLogTest.java
Normal file
@@ -0,0 +1,105 @@
|
||||
package cn.hutool.log.test;
|
||||
|
||||
import org.junit.Test;
|
||||
|
||||
import cn.hutool.log.Log;
|
||||
import cn.hutool.log.LogFactory;
|
||||
import cn.hutool.log.dialect.commons.ApacheCommonsLogFactory;
|
||||
import cn.hutool.log.dialect.console.ConsoleLogFactory;
|
||||
import cn.hutool.log.dialect.jboss.JbossLogFactory;
|
||||
import cn.hutool.log.dialect.jdk.JdkLogFactory;
|
||||
import cn.hutool.log.dialect.log4j.Log4jLogFactory;
|
||||
import cn.hutool.log.dialect.log4j2.Log4j2LogFactory;
|
||||
import cn.hutool.log.dialect.slf4j.Slf4jLogFactory;
|
||||
import cn.hutool.log.dialect.tinylog.TinyLogFactory;
|
||||
|
||||
/**
|
||||
* 日志门面单元测试
|
||||
* @author Looly
|
||||
*
|
||||
*/
|
||||
public class CustomLogTest {
|
||||
|
||||
private static final String LINE = "----------------------------------------------------------------------";
|
||||
|
||||
@Test
|
||||
public void consoleLogTest(){
|
||||
LogFactory factory = new ConsoleLogFactory();
|
||||
LogFactory.setCurrentLogFactory(factory);
|
||||
Log log = LogFactory.get();
|
||||
|
||||
log.info(null);
|
||||
log.info("This is custom '{}' log\n{}", factory.getName(), LINE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void commonsLogTest(){
|
||||
LogFactory factory = new ApacheCommonsLogFactory();
|
||||
LogFactory.setCurrentLogFactory(factory);
|
||||
Log log = LogFactory.get();
|
||||
|
||||
log.info(null);
|
||||
log.info("This is custom '{}' log\n{}", factory.getName(), LINE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void tinyLogTest(){
|
||||
LogFactory factory = new TinyLogFactory();
|
||||
LogFactory.setCurrentLogFactory(factory);
|
||||
Log log = LogFactory.get();
|
||||
|
||||
log.info(null);
|
||||
log.info("This is custom '{}' log\n{}", factory.getName(), LINE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void log4j2LogTest(){
|
||||
LogFactory factory = new Log4j2LogFactory();
|
||||
LogFactory.setCurrentLogFactory(factory);
|
||||
Log log = LogFactory.get();
|
||||
|
||||
log.info(null);
|
||||
log.info("This is custom '{}' log\n{}", factory.getName(), LINE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void log4jLogTest(){
|
||||
LogFactory factory = new Log4jLogFactory();
|
||||
LogFactory.setCurrentLogFactory(factory);
|
||||
Log log = LogFactory.get();
|
||||
|
||||
log.info(null);
|
||||
log.info("This is custom '{}' log\n{}", factory.getName(), LINE);
|
||||
|
||||
}
|
||||
|
||||
@Test
|
||||
public void jbossLogTest(){
|
||||
LogFactory factory = new JbossLogFactory();
|
||||
LogFactory.setCurrentLogFactory(factory);
|
||||
Log log = LogFactory.get();
|
||||
|
||||
log.info(null);
|
||||
log.info("This is custom '{}' log\n{}", factory.getName(), LINE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void jdkLogTest(){
|
||||
LogFactory factory = new JdkLogFactory();
|
||||
LogFactory.setCurrentLogFactory(factory);
|
||||
Log log = LogFactory.get();
|
||||
|
||||
log.info(null);
|
||||
log.info("This is custom '{}' log\n{}", factory.getName(), LINE);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void slf4jTest(){
|
||||
LogFactory factory = new Slf4jLogFactory();
|
||||
LogFactory.setCurrentLogFactory(factory);
|
||||
Log log = LogFactory.get();
|
||||
|
||||
log.info(null);
|
||||
log.info("This is custom '{}' log\n{}", factory.getName(), LINE);
|
||||
}
|
||||
}
|
||||
40
hutool-log/src/test/java/cn/hutool/log/test/LogTest.java
Normal file
40
hutool-log/src/test/java/cn/hutool/log/test/LogTest.java
Normal file
@@ -0,0 +1,40 @@
|
||||
package cn.hutool.log.test;
|
||||
|
||||
import org.junit.Ignore;
|
||||
import org.junit.Test;
|
||||
|
||||
import cn.hutool.log.Log;
|
||||
import cn.hutool.log.LogFactory;
|
||||
import cn.hutool.log.level.Level;
|
||||
|
||||
/**
|
||||
* 日志门面单元测试
|
||||
* @author Looly
|
||||
*
|
||||
*/
|
||||
public class LogTest {
|
||||
|
||||
@Test
|
||||
public void logTest(){
|
||||
Log log = LogFactory.get();
|
||||
|
||||
// 自动选择日志实现
|
||||
log.debug("This is {} log", Level.DEBUG);
|
||||
log.info("This is {} log", Level.INFO);
|
||||
log.warn("This is {} log", Level.WARN);
|
||||
|
||||
// Exception e = new Exception("test Exception");
|
||||
// log.error(e, "This is {} log", Level.ERROR);
|
||||
}
|
||||
|
||||
/**
|
||||
* 兼容slf4j日志消息格式测试,既第二个参数是异常对象时正常输出异常信息
|
||||
*/
|
||||
@Test
|
||||
@Ignore
|
||||
public void logWithExceptionTest() {
|
||||
Log log = LogFactory.get();
|
||||
Exception e = new Exception("test Exception");
|
||||
log.error("我是错误消息", e);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,13 @@
|
||||
package cn.hutool.log.test;
|
||||
|
||||
import org.junit.Test;
|
||||
|
||||
import cn.hutool.log.StaticLog;
|
||||
|
||||
public class StaticLogTest {
|
||||
@Test
|
||||
public void test() {
|
||||
StaticLog.debug("This is static {} log", "debug");
|
||||
StaticLog.info("This is static {} log", "info");
|
||||
}
|
||||
}
|
||||
72
hutool-log/src/test/resources/example/log4j2.xml
Normal file
72
hutool-log/src/test/resources/example/log4j2.xml
Normal file
@@ -0,0 +1,72 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
|
||||
<!-- @see http://www.cnblogs.com/hanfight/p/5721855.html -->
|
||||
<!-- status : 这个用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时,会看到log4j2内部各种详细输出 monitorInterval : Log4j能够自动检测修改配置文件和重新配置本身, 设置间隔秒数。 -->
|
||||
<Configuration status="WARN" monitorInterval="600">
|
||||
|
||||
<Properties>
|
||||
<!-- 配置日志文件输出目录 -->
|
||||
<Property name="LOG_HOME">/home/logs</Property>
|
||||
</Properties>
|
||||
|
||||
<Appenders>
|
||||
|
||||
<!--这个输出控制台的配置 -->
|
||||
<Console name="Console" target="SYSTEM_OUT">
|
||||
<!-- 控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch) -->
|
||||
<ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY" />
|
||||
<!-- 输出日志的格式 -->
|
||||
<PatternLayout pattern="[%d{HH:mm:ss.SSS}][%-5level] %class{36}:%L %M - %msg%xEx%n" />
|
||||
</Console>
|
||||
|
||||
<!-- 设置日志格式并配置日志压缩格式(service.log.年份.gz) -->
|
||||
<RollingRandomAccessFile name="service_appender" immediateFlush="false" fileName="${LOG_HOME}/service.log" filePattern="${LOG_HOME}/service.log.%d{yyyy-MM-dd}.log.gz">
|
||||
<!-- %d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生产时间 %p : 日志输出格式 %c : logger的名称 %m : 日志内容,即 logger.info("message") %n : 换行符 %C : Java类名 %L : 日志输出所在行数 %M : 日志输出所在方法名 hostName : 本地机器名 hostAddress : 本地ip地址 -->
|
||||
<PatternLayout>
|
||||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %class{36}:%L %M -- %msg%xEx%n</pattern>
|
||||
</PatternLayout>
|
||||
<Policies>
|
||||
<TimeBasedTriggeringPolicy interval="1" modulate="true" />
|
||||
</Policies>
|
||||
</RollingRandomAccessFile>
|
||||
|
||||
|
||||
<!-- DEBUG日志格式 -->
|
||||
<RollingRandomAccessFile name="service_debug_appender" immediateFlush="false" fileName="${LOG_HOME}/service.log" filePattern="${LOG_HOME}/service.log.%d{yyyy-MM-dd}.debug.gz">
|
||||
<PatternLayout>
|
||||
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %class{36}:%L %M -- %msg%xEx%n</pattern>
|
||||
</PatternLayout>
|
||||
<Policies>
|
||||
<TimeBasedTriggeringPolicy interval="1" modulate="true" />
|
||||
</Policies>
|
||||
</RollingRandomAccessFile>
|
||||
</Appenders>
|
||||
|
||||
<Loggers>
|
||||
<!-- 配置日志的根节点 -->
|
||||
<root level="debug">
|
||||
<appender-ref ref="Console" />
|
||||
</root>
|
||||
|
||||
<!-- 第三方日志系统 -->
|
||||
<logger name="org.springframework.core" level="info" />
|
||||
<logger name="org.springframework.beans" level="info" />
|
||||
<logger name="org.springframework.context" level="info" />
|
||||
<logger name="org.springframework.web" level="info" />
|
||||
<logger name="org.jboss.netty" level="warn" />
|
||||
<logger name="org.apache.http" level="warn" />
|
||||
|
||||
<!-- 日志实例(info),其中'service-log'继承root,但是root将日志输出控制台,而'service-log'将日志输出到文件,通过属性'additivity="false"'将'service-log'的 的日志不再输出到控制台 -->
|
||||
<!-- logger name类似于java package一样 -->
|
||||
<logger name="service_log" level="info" includeLocation="true" additivity="true">
|
||||
<appender-ref ref="service_appender" />
|
||||
</logger>
|
||||
|
||||
<!-- 日志实例(debug) -->
|
||||
<logger name="service_log" level="debug" includeLocation="true" additivity="false">
|
||||
<appender-ref ref="service_debug_appender" />
|
||||
</logger>
|
||||
|
||||
</Loggers>
|
||||
|
||||
</Configuration>
|
||||
6
hutool-log/src/test/resources/log4j.properties
Normal file
6
hutool-log/src/test/resources/log4j.properties
Normal file
@@ -0,0 +1,6 @@
|
||||
log4j.rootLogger=debug,STDOUT
|
||||
|
||||
log4j.additivity.org.apache=true
|
||||
log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender
|
||||
log4j.appender.STDOUT.layout=org.apache.log4j.PatternLayout
|
||||
log4j.appender.STDOUT.layout.ConversionPattern=[%d{HH:mm:ss,SSS}][%5p] %c:%L - %m%n
|
||||
24
hutool-log/src/test/resources/log4j2.xml
Normal file
24
hutool-log/src/test/resources/log4j2.xml
Normal file
@@ -0,0 +1,24 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
|
||||
<!-- @see http://www.cnblogs.com/hanfight/p/5721855.html -->
|
||||
<!-- status : 这个用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时,会看到log4j2内部各种详细输出 monitorInterval : Log4j能够自动检测修改配置文件和重新配置本身, 设置间隔秒数。 -->
|
||||
<Configuration status="WARN" monitorInterval="600">
|
||||
|
||||
<Appenders>
|
||||
<!--这个输出控制台的配置 -->
|
||||
<Console name="Console" target="SYSTEM_OUT">
|
||||
<!-- 控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch) -->
|
||||
<ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY" />
|
||||
<!-- 输出日志的格式 -->
|
||||
<PatternLayout pattern="[%d{HH:mm:ss.SSS}][%-5level] %class{36}:%L %M - %msg%xEx%n" />
|
||||
</Console>
|
||||
</Appenders>
|
||||
|
||||
<Loggers>
|
||||
<!-- 配置日志的根节点 -->
|
||||
<root level="debug">
|
||||
<appender-ref ref="Console" />
|
||||
</root>
|
||||
</Loggers>
|
||||
|
||||
</Configuration>
|
||||
17
hutool-log/src/test/resources/logback.xml
Normal file
17
hutool-log/src/test/resources/logback.xml
Normal file
@@ -0,0 +1,17 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
|
||||
<configuration scan="false">
|
||||
<property name="format" value="%d{HH:mm:ss.SSS} [%thread] %-5level %c:%L- %msg%n" />
|
||||
|
||||
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
|
||||
<!-- encoder 默认配置为PatternLayoutEncoder -->
|
||||
<encoder>
|
||||
<pattern>${format}</pattern>
|
||||
</encoder>
|
||||
</appender>
|
||||
|
||||
<root level="debug">
|
||||
<appender-ref ref="STDOUT" />
|
||||
</root>
|
||||
|
||||
</configuration>
|
||||
39
hutool-log/src/test/resources/logging.properties
Normal file
39
hutool-log/src/test/resources/logging.properties
Normal file
@@ -0,0 +1,39 @@
|
||||
#-----------------------------------------------------------------------------------------------------------
|
||||
# == JDK Logging \u914d\u7f6e\u6587\u4ef6 ==
|
||||
#Level\u7684\u4e94\u4e2a\u7b49\u7ea7
|
||||
# SEVERE
|
||||
# WARNING
|
||||
# INFO
|
||||
# CONFIG
|
||||
# FINE
|
||||
# FINER
|
||||
# FINEST
|
||||
#
|
||||
#-----------------------------------------------------------------------------------------------------------
|
||||
|
||||
# \u65e5\u5fd7\u683c\u5f0f
|
||||
#java.util.logging.SimpleFormatter.format=%4$s: %5$s [%1$tc]%n
|
||||
|
||||
#\u6307\u5b9aRoot Logger\u7ea7\u522b
|
||||
.level= ALL
|
||||
#\u4e3a Handler \u6307\u5b9a\u9ed8\u8ba4\u7684\u7ea7\u522b\uff08\u9ed8\u8ba4\u4e3a Level.INFO\uff09\u3002
|
||||
java.util.logging.ConsoleHandler.level=ALL
|
||||
# \u6307\u5b9a\u8981\u4f7f\u7528\u7684 Formatter \u7c7b\u7684\u540d\u79f0\uff08\u9ed8\u8ba4\u4e3a java.util.logging.SimpleFormatter\uff09\u3002
|
||||
java.util.logging.ConsoleHandler.formatter=logging.formatter.MySimpleFormatter
|
||||
|
||||
# \u4e3a Handler \u6307\u5b9a\u9ed8\u8ba4\u7684\u7ea7\u522b\uff08\u9ed8\u8ba4\u4e3a Level.ALL\uff09\u3002
|
||||
java.util.logging.FileHandler.level=ALL
|
||||
# \u6307\u5b9a\u8981\u4f7f\u7528\u7684 Formatter \u7c7b\u7684\u540d\u79f0\uff08\u9ed8\u8ba4\u4e3a java.util.logging.XMLFormatter\uff09\u3002
|
||||
java.util.logging.FileHandler.formatter=java.util.logging.SimpleFormatter
|
||||
# \u6307\u5b9a\u8981\u5199\u5165\u5230\u4efb\u610f\u6587\u4ef6\u7684\u8fd1\u4f3c\u6700\u5927\u91cf\uff08\u4ee5\u5b57\u8282\u4e3a\u5355\u4f4d\uff09\u3002\u5982\u679c\u8be5\u6570\u4e3a 0\uff0c\u5219\u6ca1\u6709\u9650\u5236\uff08\u9ed8\u8ba4\u4e3a\u65e0\u9650\u5236\uff09\u3002
|
||||
java.util.logging.FileHandler.limit=1024000
|
||||
# \u6307\u5b9a\u6709\u591a\u5c11\u8f93\u51fa\u6587\u4ef6\u53c2\u4e0e\u5faa\u73af\uff08\u9ed8\u8ba4\u4e3a 1\uff09\u3002
|
||||
java.util.logging.FileHandler.count=1
|
||||
# \u4e3a\u751f\u6210\u7684\u8f93\u51fa\u6587\u4ef6\u540d\u79f0\u6307\u5b9a\u4e00\u4e2a\u6a21\u5f0f\u3002\u6709\u5173\u7ec6\u8282\u8bf7\u53c2\u89c1\u4ee5\u4e0b\u5185\u5bb9\uff08\u9ed8\u8ba4\u4e3a "%h/java%u.log"\uff09\u3002
|
||||
java.util.logging.FileHandler.pattern=demo.log
|
||||
# \u6307\u5b9a\u662f\u5426\u5e94\u8be5\u5c06 FileHandler \u8ffd\u52a0\u5230\u4efb\u4f55\u73b0\u6709\u6587\u4ef6\u4e0a\uff08\u9ed8\u8ba4\u4e3a false\uff09\u3002
|
||||
java.util.logging.FileHandler.append=true
|
||||
|
||||
# \u6267\u884c\u7684LogHandler\uff0c\u4f7f\u7528\u9017\u53f7\u9694\u5f00
|
||||
#handlers= java.util.logging.ConsoleHandler,java.util.logging.FileHandler
|
||||
handlers= java.util.logging.ConsoleHandler
|
||||
11
hutool-log/src/test/resources/tinylog.properties
Normal file
11
hutool-log/src/test/resources/tinylog.properties
Normal file
@@ -0,0 +1,11 @@
|
||||
#-----------------------------------------------------------------------------------------------------------
|
||||
# == TinyLog \u914d\u7f6e\u6587\u4ef6 ==
|
||||
# \u914d\u7f6e\u89c1\uff1ahttp://www.tinylog.org/configuration#file
|
||||
#-----------------------------------------------------------------------------------------------------------
|
||||
|
||||
# \u65e5\u5fd7\u5199\u51fa\u65b9\u5f0f\uff1a[console] [file] [jdbc] [logcat] [rollingfile] [sharedfile] [null]
|
||||
tinylog.writer = console
|
||||
# \u65e5\u5fd7\u5199\u51fa\u7ea7\u522b\uff1aTRACE < DEBUG < INFO < WARNING < ERROR < OFF
|
||||
tinylog.level = debug
|
||||
# \u65e5\u5fd7\u6253\u5370\u683c\u5f0f
|
||||
tinylog.format = [{date:HH:mm:ss}][{level}] {class}:{line} - {message}
|
||||
Reference in New Issue
Block a user