8.1使用Log4j在测试过程中打印日志

  目的:在测试过程中,使用Log4j打印日志,用于监控和后续调试测试脚本

  被测网页的网址:

  http://www.baidu.com

  环境准备:

  (1)访问https://archive.apache.org/dist/logging/log4j/1.2.17/  下载log4j-1.2.17.jar

  (2)将log4j-1.2.17.jar添加至Eclipse的Build Path中即可

  (3)需在工程根目录新建一个Log4j.xml文件,Log工具类文件和一个测试类文件TestLog4j。

  Java语言版本的API实例代码 

  Log4j.xml的内容如下

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">
<appender name="fileAppender" class="org.apache.log4j.FileAppender">
<param name = "Threshold" value="INFO"/>
<param name = "File" value="logfile.log"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %-5p [%c{1}] %m %n"/>
</layout>
</appender>
<root>
<level value="INFO" />
<appender-ref ref="fileAppender"/>
</root>
</log4j:configuration>

Log工具类的代码如下:

import org.apache.log4j.Logger;

public class Log {
//初始化一个Logger对象
private static Logger Log = Logger.getLogger(Log.class.getName());
//定义一个静态方法,可以打印自定义的,某个测试用例开始执行的的日志信息
public static void startTestCase(String sTestCaseName){
Log.info("------------------------------------------");
Log.info("*********** "+sTestCaseName+" **************");
}
//定义一个静态方法,可以打印自定义的,某个测试用例结束执行的日志信息
public static void endTestCase(String sTestCaseName){
Log.info("***********"+"测试用例执行结束"+"**************");
Log.info("------------------------------------------");
}
//定义一个静态的info方法,打印info级别日志信息
public static void info(String message){
Log.info(message);
}
//定义一个静态warn方法,打印自定义级别warn级别日志信息
public static void warn(String message){
Log.warn(message);
}
//定义一个静态error方法,打印自定义的error级别日志信息
public static void error(String message){
Log.error(message);
}
//定义一个静态fatal方法,打印自定义fatal级别日志信息
public static void fatal(String message){
Log.fatal(message);
}
//定义一个静态debug方法,打印自定义debug级别日志信息
public static void debug(String message){
Log.debug(message);
}
}

TestLog4j测试类代码如下

import org.testng.annotations.Test;
import org.testng.annotations.BeforeMethod;
import org.apache.log4j.xml.DOMConfigurator;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeClass; public class TestLog4j {
WebDriver driver;
String url = "http://www.baidu.com";
@Test
public void testSearch() {
//向日志文件中打印搜索测试用例开始执行的日志信息
Log.startTestCase("搜索");
driver.get(url);
Log.info("打开百度首页");
//在搜索框中输入seleium
driver.findElement(By.id("kw")).sendKeys("seleium");
Log.info("输入搜索关键字“seleium”");
//单击搜索
driver.findElement(By.id("su")).click();
Log.info("单击搜索按钮");
Log.endTestCase("搜索");
}
@BeforeMethod
public void beforeMethod() {
System.setProperty("webdriver.chrome.driver", "D:\\WebDriver\\chromedriver_win32\\chromedriver.exe");
driver = new ChromeDriver();
driver.manage().window().maximize(); } @AfterMethod
public void afterMethod() {
driver.quit();
}
@BeforeClass
public void beforeClass(){
DOMConfigurator.configure("log4j.xml");
}
}

执行结果:

执行测试类之后,会在当前测试工程的根目录生成一个日志文件logfile.log,生成日志如下

代码解释:

(1)日志信息的优先级从高到低有ERROR、WARN、INFO、DEBUG,分别用来指这条日志的重要程度

(2)Log4j支持两种配置文件格式,一种是XML格式的文件,一种是Java特性文件(键=值)

(3)XML文件中的语句<appender name="fileAppender" class="org.apache.log4j.FileAppender">定义了log4j将日志信息打入日志文件中

(4)xml文件中的语句<param name = "Threshold" value="INFO"/>定义了日志信息的级别为info级别

(5)XML文件中的语句<param name = "File" value="logfile.log"/>定义了日志文件名为logfile.log,日志文件与xml文件在同一文件夹下,若不存在则自动创建此日志文件

(6)XML文件中的语句<param name="ConversionPattern" value="%d %-5p [%c{1}] %m %n"/>定义了日志的格式信息,%d表示打印日志时候的年月日时分秒毫秒信息,%-5p表示日志的级别,%c{1}表示Logger对象的名字(在Log类中定义类名Log作为logger的名字),%m表示打印具体的日志内容,%n表示打印一个回车

WebDriver高级应用实例(8)的更多相关文章

  1. WebDriver高级应用实例(10)

    10.1控制HTML5语言实现的视频播放器 目的:能够获取html5语言实现的视频播放器视频文件的地址.时长.控制进行播放暂停 被测网页的网址: http://www.w3school.com.cn/ ...

  2. WebDriver高级应用实例(9)

    9.1封装操作表格的公用类 目的:能够使自己编写操作表格的公用类,并基于公用类进行表格中的元素的各类操作 被测网页的网址的HTML代码: <html> <body> <t ...

  3. WebDriver高级应用实例(7)

    7.1在测试中断言失败的步骤进行屏幕截图 目的:在测试过程中,在断言语句执行失败时,对当前的浏览器进行截屏,并在磁盘上新建一个yyyy-mm-dd格式的目录,并在断言失败时新建一个已hh-mm-ss格 ...

  4. WebDriver高级应用实例(6)

    6.1精确比较网页截图图片 目的:对于核心界面进行截屏,并且使用测试过程中的截图和以前测试过程中的截图进行比较.确认页面是否发生了改变 被测网页的网址: http://www.baidu.com Ja ...

  5. WebDriver高级应用实例(5)

    5.1对象库(UI Map) 目的:能够使用配置文件存储被测试页面上的元素的定位方式和定位表达式,做到定位数据和程序的分离.方便不具备编码能力的测试人员进行修改和配置. 被测网页的网址: http:/ ...

  6. WebDriver高级应用实例(4)

    4.1操作web页面的滚动条 被测网页的网址: http://v.sogou.com Java语言版本的API实例代码 import org.testng.annotations.Test; impo ...

  7. WebDriver高级应用实例(3)

    3.1自动化下载某个文件 被测网页的网址: https://pypi.org/project/selenium/#files Java语言版本的API实例代码 import java.util.Has ...

  8. WebDriver高级应用实例(2)

    2.1在日期选择器上进行日期选择 被测网页的网址: https://www.html5tricks.com/demo/Kalendae/index.html Java语言版本的API实例代码 impo ...

  9. WebDriver高级应用实例(1)

    1.1使用JavaScriptExecutor单击元素 被测网页的网址: http://www.baidu.com Java语言版本的API实例代码 import org.testng.annotat ...

随机推荐

  1. 2019.02.07 bzoj4784: [Zjoi2017]仙人掌(仙人掌+树形dp)

    传送门 题意:给一个无向连通图,问给它加边形成仙人掌的方案数. 思路: 先考虑给一棵树加边形成仙人掌的方案数. 这个显然可以做树形dp. fif_ifi​表示把iii为根的子树加边形成仙人掌的方案数. ...

  2. windows下Oracle数据库完全删除

    1.1   停止所有oracle的服务 1.2   删除安装路径 app及其下所有文件 1.3   删除注册表 regedit 进入 在下列列表中找到与oracle相关的注册表项删除 1.HKEY_L ...

  3. flex布局中的主轴和侧轴的确定

    1.主轴和侧轴是通过flex-direction确定的 如果flex-direction是row或者row-reverse,那么主轴就是justify-contain 如果flex-direction ...

  4. 更新源pip

    国内镜像源列表 豆瓣(douban) http://pypi.douban.com/simple/清华大学 https://pypi.tuna.tsinghua.edu.cn/simple/阿里云 h ...

  5. pipenv知识积累

    pip install pipenv 安装pipenv pipenv --python 3.6 指定某一Python版本创建环境 pipenv --py 显示Python解释器信息 pipenv -- ...

  6. vue的cli中自定义router

    1.安装router npm install vue-router 2.为了方便管理在components同级创建router文件夹 3.在文件夹中创建index.js文件,就是router文件 im ...

  7. window+R

    好记性不如烂笔头, window+R:打开运行 等同于:所有程序-->附件-->运行

  8. noip第4课资料

  9. MapReduce_架构

    架构 MapReduce1.x JobTracker:JT(作业管理者) 将作业分解成一堆的任务:Task(MapTask和ReduceTask) 将任务分派给TaskTracker运行 作业的监控. ...

  10. int与String互转

    1.把String转化为int类型 Integer.valueOf(i); 2.把int转化为String 1)String.valueOf(i) 2)Integer.toString(i) 3)i+ ...