封装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文件( ...
随机推荐
- Madgwick算法详细解读
Madgwick算法详细解读 极品巧克力 前言 接上一篇文章<Google Cardboard的九轴融合算法>. Madgwick算法是另外一种九轴融合的方法,广泛应用在旋翼飞行器上,效果 ...
- linux常用的一些命令行操作(ubuntu)
软件安装 sudo apt-get install xxx 压缩和解压缩 1. *.tar 用 tar –xvf 解压 2. *.gz 用 gzip -d或者gunzip 解压 3. *.tar.gz ...
- Tomcat内存溢出及大小调整
一.在使用Java程序从数据库中查询大量的数据或是应用服务器(如tomcat.jboss,weblogic)加载jar包时会出现java.lang.OutOfMemoryError异常.这主要是由于应 ...
- loadrunner中回放log看不到参数替代后具体数值
1.打开run-time settings,找到 log - always send messages,选择 extended log--parameter substitution.
- [SoapUI] Global Scripts For Reusability
- Mybatis:动态sql
动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格 ...
- (2)WePHP 控制器与使用模板
<?php class C_index extends Action { public function __initialize() { echo"自动执行"; } pub ...
- 第02章 查询DSL进阶
本章内容 Lucene默认评分公式是如何工作的. 什么是查询重写. 查询二次评分是如何工作的. 如何在单次请求中实现批量准实时读取操作. 如何在单次请求中发送多个查询. 如何对包括嵌套文档和多值字段的 ...
- 编写高质量代码改善C#程序的157个建议——建议157:从写第一个界面开始,就进行自动化测试
建议157:从写第一个界面开始,就进行自动化测试 如果说单元测试是白盒测试,那么自动化测试就是黑盒测试.黑盒测试要求捕捉界面上的控件句柄,并对其进行编码,以达到模拟人工操作的目的.具体的自动化测试请学 ...
- Java中多对多映射关系
多对对的映射,可以用学生和课程进行演示.一个学生可以选择多个课程,一个课程又对应了多个学生 定义学生类 class Stu{ private String name; private String n ...