TestNG 入门

1 篇文章 0 订阅
  • 我前段时间加班太多了,每天忙碌工作,都没精力去管自己的学习新技能的计划, 博客也没写几篇,很多想做的事情都因为工作太忙而耽搁了。 所以工作太忙了也不好,没有精力关注工作以外的事情。   

    最近写自动化测试每天都用到TestNG,  把常用的TestNG的用法总结下。

    阅读目录

    TestNG介绍 在Eclipse 中安装TestNG插件 TestNG最简单的测试 TestNG的基本注解 TestNG中如何执行测试 TestNG中按顺序执行Case TestNG异常测试 TestNG组测试 TestNG参数化测试 TestNG忽略测试 TestNG 依赖测试 TestNG测试报告

    TestNG介绍

    TestNG是Java中的一个测试框架, 类似于JUnit 和NUnit,   功能都差不多, 只是功能更加强大,使用也更方便

    Java中已经有一个JUnit的测试框架了。  TestNG比JUnit功能强大的多。  测试人员一般用TestNG来写自动化测试。  开发人员一般用JUnit写单元测试。

    官方网站: http://testng.org/doc/index.html

    在Eclipse中安装TestNG

    打开Eclipse   Help ->Install New Software ,   然后Add   "http://beust.com/eclipse"

    TestNG最简单的测试

     下面是TestNG的最简单的一个例子

    01. package TankLearn2.Learn;
    02.  
    03. import org.junit.AfterClass;
    04. import org.junit.BeforeClass;
    05. import org.testng.annotations.Test;
    06.  
    07. public class TestNGLearn1 {
    08.  
    09. @BeforeClass
    10. public void beforeClass() {
    11. System.out.println("this is before class");
    12. }
    13.  
    14. @Test
    15. public void TestNgLearn() {
    16. System.out.println("this is TestNG test case");
    17. }
    18.  
    19. @AfterClass
    20. public void afterClass() {
    21. System.out.println("this is after class");
    22. }
    23. }

    TestNG的基本注解

注解描述
@BeforeSuite注解的方法将只运行一次,运行所有测试前此套件中。
@AfterSuite注解的方法将只运行一次此套件中的所有测试都运行之后。
@BeforeClass注解的方法将只运行一次先行先试在当前类中的方法调用。
@AfterClass注解的方法将只运行一次后已经运行在当前类中的所有测试方法。
@BeforeTest注解的方法将被运行之前的任何测试方法属于内部类的 <test>标签的运行。
@AfterTest注解的方法将被运行后,所有的测试方法,属于内部类的<test>标签的运行。
@BeforeGroups组的列表,这种配置方法将之前运行。此方法是保证在运行属于任何这些组第一个测试方法,该方法被调用。
@AfterGroups组的名单,这种配置方法后,将运行。此方法是保证运行后不久,最后的测试方法,该方法属于任何这些组被调用。
@BeforeMethod注解的方法将每个测试方法之前运行。
@AfterMethod被注释的方法将被运行后,每个测试方法。
@DataProvider标志着一个方法,提供数据的一个测试方法。注解的方法必须返回一个Object[] [],其中每个对象[]的测试方法的参数列表中可以分配。 该@Test 方法,希望从这个DataProvider的接收数据,需要使用一个dataProvider名称等于这个注解的名字。
@Factory作为一个工厂,返回TestNG的测试类的对象将被用于标记的方法。该方法必须返回Object[]。
@Listeners定义一个测试类的监听器。
@Parameters介绍如何将参数传递给@Test方法。
@Test标记一个类或方法作为测试的一部分。

TestNG中如何执行测试

第一种直接执行:右键要执行的方法,  点Run As ->TestNG Test

第二种:  通过testng.xml文件来执行. 把要执行的case, 放入testng.xml文件中。 右键点击testng.xml,   点Run As

testng.xml

1. <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
2. <suite name="Suite1">
3. <test name="test12">
4. <classes>
5. <class name="TankLearn2.Learn.TestNGLearn1" />
6. </classes>
7. </test>
8. </suite>

TestNG按顺序执行Case

在testng.xml中,可以控制测试用例按顺序执行。  当preserve-order="true"是,可以保证节点下面的方法是按顺序执行的

01. <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
02. <suite name="Suite1">
03. <test name="test12" preserve-order="true">
04. <classes>
05. <class name="TankLearn2.Learn.TestNGLearn1">
06. <methods>
07. <include name="TestNgLearn3" />
08. <include name="TestNgLearn1" />
09. <include name="TestNgLearn2" />
10. </methods>
11. </class>
12. </classes>
13. </test>
14. </suite>

TestNG异常测试

测试中,有时候我们期望某些代码抛出异常。

TestNG通过@Test(expectedExceptions)  来判断期待的异常, 并且判断Error Message

01. package TankLearn2.Learn;
02.  
03. import org.testng.annotations.Test;
04.  
05. public class ExceptionTest {
06.  
07. @Test(expectedExceptions = IllegalArgumentException.class, expectedExceptionsMessageRegExp="NullPoint")
08. public void testException(){
09. throw new IllegalArgumentException("NullPoint");
10. }
11. }

TestNG组测试

TestNG中可以把测试用例分组,这样可以按组来执行测试用例比如:

01. package TankLearn2.Learn;
02.  
03. import org.testng.annotations.Test;
04.  
05. public class GroupTest {
06.  
07. @Test(groups = {"systemtest"})
08. public void testLogin(){
09. System.out.println("this is test login");
10. }
11.  
12. @Test(groups = {"functiontest"})
13. public void testOpenPage(){
14. System.out.println("this is test Open Page");
15. }
16. }

然后在testng.xml中 按组执行测试用例

01. <?xml version="1.0" encoding="UTF-8"?>
02. <!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
03. <suite name="Suite1">
04. <test name="test1">
05. <groups>
06. <run>
07. <include name="functiontest" />
08. </run>
09. </groups>
10. </test>
11. </suite>

TestNG参数化测试

软件测试中,经常需要测试大量的数据集。 测试代码的逻辑完全一样,只是测试的参数不一样。  这样我们就需要一种 “传递测试参数的机制”。 避免写重复的测试代码

TestNG提供了2种传递参数的方式。

第一种: testng.xml 方式使代码和测试数据分离,方便维护

第二种:@DataProvider能够提供比较复杂的参数。 (也叫data-driven testing)

方法一: 通过testng.xml 传递参数给测试代码

01. package TankLearn2.Learn;
02.  
03. import org.testng.annotations.Parameters;
04. import org.testng.annotations.Test;
05.  
06. public class ParameterizedTest1 {
07.  
08. @Test
09. @Parameters("test1")
10. public void ParaTest(String test1){
11. System.out.println("This is " + test1);
12. }
13. }

testng.xml

01. <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
02. <suite name="Suite1">
03. <parameter name="test1" value="Tank" />
04. <parameter name="test1" value="Xiao" />
05. <test name="test12">
06. <classes>
07. <class name="TankLearn2.Learn.ParameterizedTest1" />
08. </classes>
09. </test>
10. </suite>

方式二:   通过DataProvider传递参数

01. package TankLearn2.Learn;
02.  
03. import org.testng.annotations.DataProvider;
04. import org.testng.annotations.Test;
05.  
06. public class DataProviderLearn {
07.  
08. @DataProvider(name="user")
09. public Object[][] Users(){
10. return new Object[][]{
11. {"root","passowrd"},
12. {"cnblogs.com""tankxiao"},
13. {"tank","xiao"}
14. };
15. }
16.  
17. @Test(dataProvider="user")
18. public void verifyUser(String userName, String pass<a href="http://www.it165.net/edu/ebg/" target="_blank" class="keylink">word</a>){
19. System.out.println("Username: "+ userName + " Pass<a href="http://www.it165.net/edu/ebg/" target="_blank" class="keylink">word</a>: "+ password);
20. }
21. }

TestNG忽略测试

有时候测试用例还没准备好, 可以给测试用例加上@Test(enable = false),  来禁用此测试用例

01. package TankLearn2.Learn;
02.  
03. import org.testng.annotations.Test;
04.  
05. public class TesgNGIgnore {
06.  
07. @Test(enabled = false)
08. public void testIgnore(){
09. System.out.println("This test case will ignore");
10. }
11. }

TestNG 依赖测试

有时候,我们需要按顺序来调用测试用例,  那么测试用例之间就存在依赖关系。 TestNG支持测试用例之间的依赖

01. package TankLearn2.Learn;
02.  
03. import org.testng.annotations.Test;
04.  
05. public class DependsTest {
06.  
07. @Test
08. public void setupEnv(){
09. System.out.println("this is setup Env");
10. }
11.  
12. @Test(dependsOnMethods = {"setupEnv"})
13. public void testMessage(){
14. System.out.println("this is test message");
15. }
16. }

TestNG测试结果报告

测试报告是测试非常重要的部分.  

TestNG默认情况下,会生产两种类型的测试报告HTML的和XML的。 测试报告位于 "test-output" 目录下.

当然我们也可以设置测试报告的内容级别. 

verbose="2" 标识的就是记录的日志级别,共有0-10的级别,其中0表示无,10表示最详细

1. <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
2. <suite name="Suite1">
3. <test name="test12" verbose="2">
4. <classes>
5. <class name="TankLearn2.Learn.TestNGLearn1" />
6. </classes>
7. </test>
8. </suite>
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值