TestNG 培训

第一章 :

1.1 TestNG是什么?

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

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

TestNG按照其文档的定义是:

TestNG是一个测试框架,其灵感来自JUnit和NUnit的,但引入了一些新的功能,使其功能更强大,使用更方便。

TestNG是一个开源自动化测试框架;TestNG表示下一代。 TestNG是类似于JUnit(特别是JUnit 4),但它不是一个JUnit扩展。它的灵感来源于JUnit。它的目的是优于JUnit的,尤其是当测试集成的类。 TestNG的创造者是Cedric Beust(塞德里克·博伊斯特)

TestNG消除了大部分的旧框架的限制,使开发人员能够编写更加灵活和强大的测试。 因为它在很大程度上借鉴了Java注解(JDK5.0引入的)来定义的测试,它也可以告诉你如何使用这个新功能在真实的Java语言生产环境中。

1.2 TestNG的特点

  • 注解

  • TestNG使用Java和面向对象的功能

  • 支持综合类测试(例如,默认情况下,没有必要创建一个新的测试每个测试方法的类的实例)

  • 独立的编译时间测试代码运行时配置/数据信息

  • 灵活的运行时配置

  • 主要介绍“测试组”。当编译测试,只要问TestNG运行所有的“前端”的测试,或“快”,“慢”,“数据库”等

  • 支持依赖测试方法,并行测试,负载测试,局部故障

  • 灵活的插件API

  • 支持多线程测试

1.3 TestNG的安装

Idea自带不需要安装 使用Eclipse的同学参见http://www.yiibai.com/html/testng/2013/0914293.html安装

1.4 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 标记一个类或方法作为测试的一部分。

1.5 TestNG执行测试

第一种:

  1. 执行文件

  2. 在编辑区右击 > Run 'TestNG'

第二种:

执行文件

1.6 使用TestNG.xml 文件执行case

  • 通过testNG.xml文件来执行. 把要执行的case, 放入testNG.xml文件中。
  • 右键testNG.xml > run

1.7 TestNG按顺序执行case

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

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Suite1">
    <test name="test12" preserve-order="true">
        <classes>
            <class name="com.haomostudio.psm.service.test.TestNG">
                <methods>
                    <include name="TestNgLearn3" />
                    <include name="TestNgLearn1" />
                    <include name="TestNgLearn2" />
                </methods>
            </class>
        </classes>
    </test>
</suite>

1.8 TestNG异常测试

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

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

package com.haomostudio.psm.service.test;

import org.testng.annotations.Test;


public class ExceptionTest {

    @Test(expectedExceptions = IllegalArgumentException.class, expectedExceptionsMessageRegExp = "NullPoint")
    public void testException(){
        throw new IllegalArgumentException("NullPoint");
    }
}

1.9 TestN组测试

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

package com.haomostudio.psm.service.test;

import org.testng.annotations.Test;

public class GroupTest {

    @Test(groups = {"systemtest"})
    public void testLogin(){
        System.out.println("this is test login");
    }

    @Test(groups = {"functiontest"})
    public void testOpenPage(){
        System.out.println("this is test Open Page");
    }

    @Test(groups = {"functiontest"})
    public void testOpenPage2(){
        System.out.println("this is test Open Page2");
    }
}

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

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Suite1">
    <test name="test1">
        <groups>
            <run>
                <include name="functiontest" />
            </run>
        </groups>
        <classes>
            <class name="com.haomostudio.psm.service.test.GroupTest"></class>
        </classes>
    </test>
</suite>

2.0 TestNG参数化测试

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

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

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

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

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

package com.haomostudio.psm.service.test;

import org.testng.annotations.Parameters;
import org.testng.annotations.Test;

/**
 * Created by Administrator on 2017/3/25.
 */
public class parameterTest {
    @Test
    @Parameters("test1")
    public void ParaTest(String test1){
        System.out.println("This is " + test1);
    }
}

testng.xml

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Suite1">
    <parameter name="test1" value="Tank" />
    <test name="test12">
        <classes>
            <class name="com.haomostudio.psm.service.test.parameterTest" />
        </classes>
    </test>
</suite>

方式二: 通过DataProvider传递参数

package com.haomostudio.psm.service.test;

import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;

/**
 * Created by Administrator on 2017/3/25.
 */
public class DateProviderLearnTest {

    @DataProvider(name = "user")
    public Object[][] Users(){
        return new Object[][]{
                {"root","password"},
                {"yide","9941444745"}
        };
    }

    @Test(dataProvider="user")
    public void showUser(String userName,String password){
        System.out.println("userName:"+userName+"password:"+password);
    }
}

2.1 TestNG忽略测试

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

package com.haomostudio.psm.service.test;

import org.testng.annotations.Test;

public class IgnoredTest {

    @Test
    public void showName(){
        System.out.println("yide");
    }

    @Test(enabled = false)
    public void ignored(){
        System.out.println("忽略的");
    }
}

2.2 TestNG 依赖测试

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

package com.haomostudio.psm.service.test;

import org.testng.annotations.Test;

/**
 * Created by Administrator on 2017/3/25.
 */
public class RelyTest {

    @Test(dependsOnMethods = {"first"})
    public void last(){
        System.out.println("我必须在first方法之后执行");
    }

    @Test
    public void first(){
        System.out.println("必须我先执行");
    }

}

results matching ""

    No results matching ""