背景:
采用Rest-assured,日志采用log4j,发现Rest-assured本身只支持打印日志到控制台,但期望打印到文件中以便排查问题
请求打印的语句只能输出到控制台
given().log().all()
|
(Rest-assured的官方文档:https://github.com/rest-assured/rest-assured)
解决方法:
1.翻阅资料,可以通过RestAssured.config来改变日志方面的配置,因此尝试从这里入手
RestAssured.config = RestAssured.config().logConfig(
new
LogConfig());
|
2.发现一种解决方法,PrintStream支持 字符串路径/File对象/outputstream,可以通过新建file来可以将日志输出到file中,但这种不能append,只能保存最新的一次记录,而且没有log4j格式
PrintStream ps =
new
PrintStream(
new
File(
"test.txt"
));
RestAssured.config = config().logConfig(
new
LogConfig(ps));
|
3.继续google,发现了通过重写方法来解决该问题(http://stackoverflow.com/questions/14476112/how-to-get-rest-assured-log-into-something-printable-in-a-text-file),需要新建一个类来将logger转为outputstream
ToLoggerPrintStream loggerPrintStream =
new
ToLoggerPrintStream(logger);
RestAssured.config = RestAssured.config().logConfig(
new
LogConfig(loggerPrintStream.getPrintStream(),
true
));
|
ToLoggerPrintStream类源码:
虽千万人,吾往矣!