封装log4j支持记录到testng
一、初始方案
自动化中需要把日志通过testng的Reporter.log来记录日志在报告中展示。开始是新增了一个日志类:
ReporterLog.class
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.testng.Reporter; public class ReporterLogger {
private Logger LOGGER; public ReporterLogger(Class<?> clazz){
LOGGER= LoggerFactory.getLogger(clazz);
} public void info(String message){
//使用slf4j打印到控制台或者文件
LOGGER.info(message);
//记录到Reporter
Reporter.log(message);
} }
这样会有2个问题:
1、LOGGER.info(message);这句话打印出来的类名、方法名、行号等不是调用ReporterLogger方法info的类,二是ReporterLogger类。
2、Reporter.log记录的日志,没有时间、类名、方法名、行号。
第一个问题测试:
import com.sqe.sas.test.service.ReporterLogger;
public class LogTest {
private static final ReporterLogger LOGGER = new ReporterLogger(LogTest.class);
public static void main(String[] args) {
LOGGER.info("processing。。。。");
}
}
打印结果:
[main][2019-01-29 18:28:14] [INFO] [LogTest.info:25] processing。。。。
类名打印的是对的,但是方法名和行号打印的都是ReporterLogger中的
二、改进方案:
第一个问题:
使用log4j的log方法
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import org.testng.Reporter; public class ReporterLogger {
private Logger LOGGER; //使用org.apache.log4j.Logger 而不是org.slf4j.Logger;
static final String FQCN = ReporterLogger.class.getName(); // log4j把传递进来的callerFQCN在堆栈中一一比较,相等后,再往上一层即认为是用户的调用类 public ReporterLogger(Class<?> clazz){
LOGGER= Logger.getLogger(clazz); // 这里也要改
} public void info(String message){
//使用slf4j打印到控制台或者文件
LOGGER.log(FQCN, Level.INFO,message,null);
//记录到Reporter
Reporter.log(message);
} }
再次测试,打印结果如下:
[main][2019-01-30 10:44:23] [INFO] [LogTest.main:7] processing。。。。
已经可以了打印正确的方法名和行号了
第二个问题:
在打印的字符串前加上时间、类名、方法名、行号
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import org.testng.Reporter; import java.text.SimpleDateFormat;
import java.util.Date; public class ReporterLogger {
private Logger LOGGER; //使用org.apache.log4j.Logger 而不是org.slf4j.Logger;
static final String FQCN = ReporterLogger.class.getName(); // og4j把传递进来的callerFQCN在堆栈中一一比较,相等后,再往上一层即认为是用户的调用类 public ReporterLogger(Class<?> clazz){
LOGGER= Logger.getLogger(clazz); // 这里也要改
} public void info(String message){
//使用slf4j打印到控制台或者文件
LOGGER.log(FQCN, Level.INFO,message,null);
message = getLogTag()+message;
//记录到Reporter
Reporter.log(message);
}
//根据堆栈信息,拿到调用类的名称、方法名、行号
public String getLogTag(){
String logTag = "";
Long timeStamp = System.currentTimeMillis();
String dateString = timestampToDate(timeStamp);
StackTraceElement stack[] = (new Throwable()).getStackTrace();
for(int i=0;i<stack.length;i++) {
StackTraceElement s = stack[i];
if(s.getClassName().equals(LOGGER.getName())){
logTag= "["+dateString+"]"+"["+classNameDeal(s.getClassName())+":"+s.getMethodName()+":"+s.getLineNumber()+"]";
}
}
return logTag;
} //时间戳转date字符串
public static String timestampToDate(Long timestamp){
if(timestamp.toString().length() <13){
timestamp = Long.valueOf(timestamp.toString().substring(0,10)+"000");
}
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
Date date = new Date(timestamp);
String dateStr = sdf.format(date);
return dateStr;
} //去掉包名,只保留类名
private String classNameDeal(String allName){
String[] className = allName.split("\\.");
return className[className.length-1];
}
}
封装log4j支持记录到testng的更多相关文章
- 项目中添加Log4J支持
首先,在项目中的classes 中新建立一个log4j.properties文件即可: 在实际编程时,要使Log4j真正在系统中运行事先还要对配置文件进行定义.定义步骤就是对Logger.Append ...
- ELK环境配置+log4j日志记录
ELK环境配置+log4j日志记录 1. 背景介绍 在大数据时代,日志记录和管理变得尤为重要. 以往的文件记录日志的形式,既查询起来又不方便,又造成日志在服务器上分散存储,管理起来相当麻烦, 想根据一 ...
- 基于SqlSugar的数据库访问处理的封装,支持.net FrameWork和.net core的项目调用
由于我们有时候需要在基于.net framework的项目上使用(如Winform端应用),有时候有需要在.net core的项目上使用(如.net core的WebAPI),那么我们把基于SQLSu ...
- Hibernate 使用log4j日志记录
日志记录使程序员能够将日志详细信息永久写入文件.这是我们以后在开发当中非常重要的一步. Hibernate使用log4j日志记录,我们需要以下几个步骤: 1.导入jar包: (1)这是hibernat ...
- 小票打印机指令集封装(支持EPSON指令)
最近写了一些关于小票打印机的程序,不难,但是记录下来,作为足迹吧. 现在市场上的小票机基本都支持EPSON指令.指令集文档 对指令集进行了自己的封装,方便以后调用: package aheiziUti ...
- ELK菜鸟手记 (一) 环境配置+log4j日志记录
1. 背景介绍 在大数据时代,日志记录和管理变得尤为重要. 以往的文件记录日志的形式,既查询起来又不方便,又造成日志在服务器上分散存储,管理起来相当麻烦, 想根据一个关键字查询日志中某个关键信息相当困 ...
- 在android中配置 slf4j + log4j 日志记录框架
需求: 在项目开发中,需要记录 操作日志 .起初自己写了个简单的日志记录文本写入到文本的方法,后来随着项目的膨胀,需要考虑更多的操作,开始考虑性能问题. 实现: 考虑使用 slf4j + log4j ...
- Hibernate使用Log4j日志记录(使用properties文件)
我们知道,Log4j和Logback框架可用于支持日志记录hibernate,使用log4j有两种执行日志记录的方法: 通过log4j.xml文件(或) 通过log4j.properties文件 在这 ...
- Hibernate使用Log4j日志记录(使用xml文件)
日志记录使程序员能够将日志详细信息永久写入文件. Log4j和Logback框架可以在hibernate框架中使用来支持日志记录. 使用log4j执行日志记录有两种方法: 通过log4j.xml文件( ...
随机推荐
- LoadRunner11学习记录二 -- 进行cookie模拟
1.LoadRunner录制打开一个网页的脚本,会生成脚本夹杂迅雷,迅雷看看,百度等链接地址,这是因为ie打开之后会加载未禁用的加载项.需要把相关的加载项禁用掉. 禁用ie加载项步骤,工具--管理加载 ...
- [Training Video - 4] [Groovy] Optional parameter in groovy
Employee.log=log Employee e1 = new Employee() log.info e1.add(1,2,3,4) // optional parameters in gro ...
- PHP中PSR
PSR 是 PHP Standard Recommendations 的简写,由 PHP FIG 组织制定的 PHP 规范,是 PHP 开发的实践标准. 文档整理 PSR-0: Autoloading ...
- AutoComplete的extraParams动态传递参数
AutoComplete可利用extraParams传递参数,如 extraParams:{para1:'参数1',para2:'参数2'} 但是,如需动态取值作为参数值时却无法达到期望目的,可改为配 ...
- javascript -window与document 待整理
window对象和document对象的区别一般来讲,一个window里就是一个document,但是,iframe里面也可以装个document,在iframe里面就有区别了 alert(docum ...
- matrix derivatives
来源:cs229 stanford Machine Learning Notes
- slice,substr和substring方法的区别
slice(start[,end])方法需要提供至少一个整数参数,作用是返回从start的位置开始到end位置的字符子串.当参数start为负数的时候他将从字符串尾部开始计算,当end没有指定时,en ...
- Smarty的基本语法------变量调节器
(1)首字母大写capitalize示例:{$articleTitle|capitalize}(2)字符串连接 cat示例:{$articleTitle|cat:" yesterday.&q ...
- MongoDB与CouchDB全方位对比(转)
出处:http://www.csdn.net/article/2011-03-21/294226 本文见于MongoDB官方网站,MongoDB与CouchDB很相似,他们都是文档型存储,数据存储格式 ...
- 结构光和ToF