官方地址:http://testng.org/doc/documentation-main.html
testNG是一个测试框架,旨在商业化广泛的测试需求,从单元测试到集成测试
特性:
①注释@
②多线程化
③支持数据驱动
④参数化
总结:灵活配置,注释,多线程安全,参数化及数据驱动
testNG三步过程:
①编写测试的业务逻辑,并在代码中插入TestNG注释。
②在testng的.xml文件或build.xml中添加关于测试的信息(例如类名、您希望运行的组等等。)
③运行testNG
配置完成testNG
在pom.xml中添加testNG的配置:
<!-- testng配置 -->
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>6.9.9</version>
</dependency>
仓库中下载所需jar包即完成配置
①编写测试的业务逻辑,并在代码中插入TestNG注释。
操作:在src/test/java中创建testNG类——>引入A,B
注:当testNG class文件创建完成后,即①②即完成,余下步骤是继续完善①②两步
新建testng类 File-new-Other-TestNG-TestNG.class
详解——testNG类文件
1.1查看注解相关
1.@DataProvider
@DataProvider(name)1)属性设置name="XX",@Test(dataProvider="XX")
2)属性不设置name,@Test(dataProvider="方法名")
@DataProvidername(parallel)数量大时使用,需在testng.xml配置
data-provider-thread-count="20"
数据驱动的好处:数据和代码分离,代码耦合度低
ExcelUtil-->TestRun
2.@Test:官方文档
@Test(dataProvider)对应上面两种情况,@Test自己会循环每行数据
Object[][]有N列即需要有N个入参对应
@Test(dataProviderClass) :多个数据驱动
@Test(depandsOnGroups):先执行依赖的组
@Test(depandsOnMehods)
@Test(invocationCount) 方法执行的次数
@Test(invocationTimeOut) 必须和invocationCount一起用,规定时间内完成,否则超时报错
@Test(threadPoolSize)与invocationCout有关
@Test(timeOut)平时一般用timeout限制用例执行时间
@Test(successPercentage)用例单执行1次没必要设置,当设置invocation时可设置此属性
@Test(singleThread) 失效
以上解决执行效率的问题
@Test(invocationCount=100,invocationTimeOut=10000,successPercentage=99,threadPoolSize=4) //设置一个方法由四个线程共同调用100次,其中99%成功(实际生活中,需保证用例全部执行正确才算成功)
@Test(enabled)
@Test(priority)
②在testng的.xml文件或build.xml中添加关于测试的信息(例如类名、您希望运行的组等等)
1. 执行方式
基于类文件执行的好处:指定某类文件即执行某个类文件
不足:当包下类文件较多,用此方法效率较低
基于包执行
<packages>
<package nane = "test.sample">
</packages>
类文件-include/exclude方式
<classes>
<class name="com.youceedu.api.test.TestRun"/>
<methods>
<exclude name="testExclude"/>
</methods>
</classes>
总结:@Test用例不想执行的方法有哪些?1)@Test(enable=false)
2)testng.xml配置include或exclude
3)代码注释
parallel 4种设置+thread-count="n"
methods tests classes instances
类中所有方法 @Test 类 类的实例
注:invocationCount和thread-count选一种,是否用多线程执行要根据业务用例来定,当前的接口自动化不需要多线程
面试题:对方法执行parallel选用注解配置invocationCount还是对.xml配置thread-count?
③运行testNG
默认报告 autost\test-output\index.html(右键-属性-resources 复制目录路径,查看test-output)
(存在问题:基本信息都有,但不没关,缺少数据统计)
优化报告(引入reporter)
配置:pom.xml
配置:pom.xml配置(reporter.guice)
注:reporng开源维护到1.1.4版本 报告地址:testng'项目名\test-output\heml\index.html
guice是测试报告UI方面
优化:testng.xml配置→配置listener
report.jar 优化出现圆饼图
参数配置位置
解决办法:在@beforeTest的方法下增加赋值,将参数传至testNG中