[基于Selenium2+Java的UI自动化(15)]-日志:Log4j.xml
Posted 软件测试部落
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[基于Selenium2+Java的UI自动化(15)]-日志:Log4j.xml相关的知识,希望对你有一定的参考价值。
前边有说过,监控和调试脚本,除了截图之外(
(见网页http://hordehome.com/t/selenium2-java-ui-9/1222?u=solowang)
在 自动化用例脚本调试的时候,刚开始我们使用控制台输入语句:System.out.println() 的方式,但是调试通了又需要逐条删除,有时比较麻烦;其实还有另外的方式去定位脚本运行情况: (1)使用日志输出的方式,日志可以详细定位哪一步执行出现异常; (2)失败截图,并保存;webdriver提供了截图功能,今天探讨一下这个功能; package com.automation.screenshot; import java.io.File; importjava.io.IOException; import org.apache.commons.io.FileUtils; importorg.openqa.selenium.By; import org.openqa.selenium.NoSuchElementException;import org.openqa.selenium.OutputType; importorg.openqa.selenium.TakesScreenshot; import org.openqa.selenium.WebDriver…
),还有一种方式,就是在脚本中增加执行的日志的代码,将日志输出到不同的地方,以便调试和监控。
设置Log4J
(1)、下载Log4j.jar 包,并将jar包添加到Eclipse项目的Build path中;
(2)、设置Log4j的配置文件,有两种方式设置,分别是Log4j.xml、Log4J.properties,可以任意选择一种文件配置即可,今天说说Log4j.xml这种方式;
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM"log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<!-- 输出日志到控制台 ConsoleAppender -->
<appendername="console" class="org.apache.log4j.ConsoleAppender">
<paramname="Threshold" value="info"></param>
<layoutclass="org.apache.log4j.TTCCLayout">
<paramname="ConversionPattern"value="TTCCLayout"></param>
</layout>
</appender>
<!-- 输出日志到文件 每天一个文件 -->
<appender name="dailyRollingFile"class="org.apache.log4j.DailyRollingFileAppender">
<paramname="Threshold" value="info"></param>
<paramname="ImmediateFlush" value="true"></param>
<paramname="File"value="./logs/dailyRollingFile.log"></param>
<param name="DatePattern"value="'.'yyyy-MM-dd'.log'"></param>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss} %-5p][%t] {%c:%L}-%m%n"></param>
</layout>
</appender>
<!-- 输出日志到文件 文件大小到达指定尺寸的时候产生一个新的文件-->
<appender name="railyFile"class="org.apache.log4j.RollingFileAppender">
<paramname="File" value="./logs/railyFile.log"></param>
<paramname="ImmediateFlush" value="true"/>
<paramname="Threshold" value="info"></param>
<paramname="Append" value="true"></param>
<paramname="MaxFileSize" value="30KB"></param>
<paramname="MaxBackupIndex" value="100"></param>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss} %-5p][%t] {%c:%L}-%m%n"></param>
</layout>
</appender>
<!-- 输出日志到文件-->
<appender name="file"class="org.apache.log4j.FileAppender">
<paramname="File" value="./logs/file.log"></param>
<paramname="Threshold" value="info"></param>
<layoutclass="org.apache.log4j.PatternLayout">
<paramname="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss} %-5p][%t] {%c:%L}-%m%n"></param>
</layout>
</appender>
<!--
定义全局的日志输出级别,但是在输出目的地的配置中配置的具体输出级别优先级高于全局定义的优先级。
如果在railyFile中定义<param name="Threshold"value="info"></param>,那么将会把info以上级别的信息输出
-->
<root>
<priorityvalue="debug" />
<appender-refref="console" />
<appender-ref ref="dailyRollingFile" />
<appender-ref ref="railyFile" />
<appender-ref ref="file" />
</root>
1.在上边的Log4j.xml配置文件中,可以看到,有四种方式输入日志:
(1)控制台;
(2)输出到一个日志文件存储;
(3)输出日志文件并指定文件大小,超过容量后产生一个新文件;
(4)每日一个日志文件,使用日期作为文件名区分;
其实还有一种输出方式是输出到邮件,也是一种相似的配置;
这几种日志输出方式,可以都设置,也可以设置一种或多种;
对上边的不同的配置,这里解释一下是什么意思:
(1)
这部分的内容,是Log4j.xml文件的头部分,指定了文件的编码是:UTF-8, 约束文件是:log4j.dtd;
(2)
这里边,是log4j的具体配置,上边说的4种方式,都是写在log4j:configuration标签里边;
(3)
1>在appender标签中,设置日志输出的目的地,由class属性设置:
1.org.apache.log4j.ConsoleAppender(控制台)
2.org.apache.log4j.FileAppender(文件)
3.org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
4.org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
5.org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
2>配置日志信息的格式:Layout标签,必须需要指定格式;
1.org.apache.log4j.htmlLayout(以HTML表格形式布局),
2.org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
3.org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
4.org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
3>对上边四种不同的日志输出配置具体说明;
控制台选项
Threshold=DEBUG:指定日志消息的输出最低层次。
ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
Target=System.err:默认情况下是:System.out,指定输出控制台
FileAppender 选项
Threshold=DEBUF:指定日志消息的输出最低层次。
ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
File=mylog.txt:指定消息输出到mylog.txt文件。
Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。
RollingFileAppender 选项
Threshold=DEBUG:指定日志消息的输出最低层次。
ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
File=mylog.txt:指定消息输出到mylog.txt文件。
Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。
MaxFileSize=100KB:后缀可以是KB, MB 或者是GB. 在日志文件到达该大小时,将会自动滚动,即将原来的内容移到mylog.log.1文件。
MaxBackupIndex=2:指定可以产生的滚动文件的最大数。
单独解释以上代码的共同部分:
1. Threshold=DEBUG:指定日志消息的输出最低层次。------->级别分别有:FATAL 、ERROR、WARN、INFO、DEBUG等;
FATAL 为可能导致应用中止的严重事件错误
ERROR 为严重错误 主要是程序的错误
WARN 为一般警告,比如session丢失
INFO 为一般要显示的信息,比如登录登出
DEBUG 为程序的调试信息
2.输出到日志文件的格式:log4j.appender.A1.layout.ConversionPattern=%-4r %-5p %d{yyyy-MM-dd HH:mm:ssS}%c %m%n
以上符号的解释:
%p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL,
%d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
%r: 输出自应用启动到输出该log信息耗费的毫秒数
%c: 输出日志信息所属的类目,通常就是所在类的全名
%t: 输出产生该日志事件的线程名
%l: 输出日志事件的发生位置,相当于%C.%M(%F:%L)的组合,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main (TestLog4.java:10)
%x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。
%F: 输出日志消息产生时所在的文件名称
%L: 输出代码中的行号
%m: 输出代码中指定的消息,产生的日志具体信息
%n: 输出一个回车换行符,Windows平台为"/r/n",Unix平台为"/n"输出日志信息换行
可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如:
1)%20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,默认的情况下右对齐。
2)%-20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,"-"号指定左对齐。
3)%.30c:指定输出category的名称,最大的宽度是30,如果category的名称大于30的话,就会将左边多出的字符截掉,但小于30的话也不会有空格。
4)%20.30c:如果category的名称小于20就补空格,并且右对齐,如果其名称长于30字符,就从左边较远输出的字符截掉。
举个例子:
现在Log4j.xml文件配置完成了;
那么在代码中怎么使用呢?
package com.automation.log4j;
import org.apache.log4j.Logger;
public class Log4j_XML {
//声明日志对象;
private staticLogger logger = Logger.getLogger(Logger.class);
public staticvoid main(String[] args) {
//输出四种级别的日志;
logger.fatal("1.fatal为可能导致应用中止的严重事件错误");
logger.error("2.ERROR为严重错误 主要是程序的错误 ");
logger.warn("3.WARN为一般警告,比如session丢失 ");
logger.info("4.INFO为一般要显示的信息,比如登录登出 ");
logger.debug("5.DEBUG为程序的调试信息 ");
}
}
执行之后,可以看到四种日志:
(1)控制台:
(2)其他三种输出到文件中:
----------------
本文转自测试部落论坛:http://www.hordehome.com/t/selenium2-java-ui-15-log4j-xml/1263
感谢大神的无私奉献!
欢迎在 官方论坛发帖,审核通过的好文会有红包呦~~
以上是关于[基于Selenium2+Java的UI自动化(15)]-日志:Log4j.xml的主要内容,如果未能解决你的问题,请参考以下文章
基于Selenium2+Java的PC自动化 - 启动浏览器