关于eclipse中testNG的安装与入门

来源:互联网 发布:网络综合布线实训室 编辑:程序博客网 时间:2024/05/30 22:43

testNG的安装

现在testNG的安装从网上百度全是在“Help ->Install New Software”路径下安装,但是我自己亲自测试没有安装成功。这里写图片描述
还有那些网站什么的,我都没有成功的安装下来。最后我在eclipse中的markspace中搜索了一下testNG,然后点击安装,他自动安装完成后会提示你重启eclipse
这里写图片描述
重启eclipse后,点击file–>new–>other–>TestNg,验证是否安装成功。
这里写图片描述

testNG的入门

1.基本注解

  • @BeforeSuite 注解的方法将只运行一次,运行所有测试前此套件中。
  • @AfterSuite 注解的方法将只运行一次此套件中的所有测试都运行之后。
  • @BeforeClass 注解的方法将只运行一次先行先试在当前类中的方法调用。
  • @AfterClass 注解的方法将只运行一次后已经运行在当前类中的所有测试方法。
  • @BeforeTest 注解的方法将被运行之前的任何测试方法属于内部类的 标签的运行。
  • @AfterTest 注解的方法将被运行后,所有的测试方法,属于内部类的标签的运行。
  • @BeforeGroups 组的列表,这种配置方法将之前运行。此方法是保证在运行属于任何这些组第一个测试方法,该方法被调用。
  • @AfterGroups 组的名单,这种配置方法后,将运行。此方法是保证运行后不久,最后的测试方法,该方法属于任何这些组被调用。
  • @BeforeMethod 注解的方法将每个测试方法之前运行。
  • @AfterMethod 被注释的方法将被运行后,每个测试方法。
  • @DataProvider 标志着一个方法,提供数据的一个测试方法。注解的方法必须返回一个Object[] [],其中每个对象[]的测试方法的参数列表中可以分配。该@Test 方法,希望从这个DataProvider的接收数据,需要使用一个dataProvider名称等于这个注解的名字。
  • @Factory 作为一个工厂,返回TestNG的测试类的对象将被用于标记的方法。该方法必须返回Object[]。
  • @Listeners 定义一个测试类的监听器。
  • @Parameters 介绍如何将参数传递给@Test方法。
  • @Test 标记一个类或方法作为测试的一部分。
    例子
package practice01;import org.junit.BeforeClass;import org.junit.Test;import org.testng.annotations.AfterClass;public class test01 {        @BeforeClass        public void beforeClass() {            System.out.println("this is before class");        }        @Test        public void TestNgLearn() {            System.out.println("this is TestNG test case");        }        @AfterClass        public void afterClass() {            System.out.println("this is after class");        }}

2.testNG的运行

选择要运行的程序点击 右键,选择运行方式为testNG,如下图:
这里写图片描述

3.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="practice01.TestNGLearn1">                <methods>                    <include name="TestNgLearn3" />                    <include name="TestNgLearn1" />                    <include name="TestNgLearn2" />                </methods>            </class>        </classes>    </test></suite>

4.TestNG异常测试

测试中,有时候我们期望某些代码抛出异常。
TestNG通过@Test(expectedExceptions) 来判断期待的异常, 并且判断Error Message

package practice01;import org.testng.annotations.Test;public class ExceptionTest {    @Test(expectedExceptions = IllegalArgumentException.class, expectedExceptionsMessageRegExp="NullPoint")    public void testException(){        throw new IllegalArgumentException("NullPoint");    }}

5.TestNG组测试

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

package practice01;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");    }}

然后在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>    </test></suite>

6.TestNG参数化测试

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

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

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

package parctice01;import org.testng.annotations.Parameters;import org.testng.annotations.Test;public class ParameterizedTest1 {    @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" />        <parameter name="test1" value="Xiao" />    <test name="test12">        <classes>            <class name="practice01.ParameterizedTest1" />        </classes>    </test></suite>

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

package practice01;import org.testng.annotations.DataProvider;import org.testng.annotations.Test;public class DataProviderLearn {    @DataProvider(name="user")    public Object[][] Users(){        return new Object[][]{                {"root","passowrd"},                {"cnblogs.com", "tankxiao"},                {"tank","xiao"}        };    }    @Test(dataProvider="user")    public void verifyUser(String userName, String password){        System.out.println("Username: "+ userName + " Password: "+ password);    }}

7.TestNG忽略测试

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

package practice01;import org.testng.annotations.Test;public class TesgNGIgnore {    @Test(enabled = false)    public void testIgnore(){        System.out.println("This test case will ignore");    }}

8.TestNG 依赖测试

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

package practice01;import org.testng.annotations.Test;public class DependsTest {    @Test    public void setupEnv(){        System.out.println("this is setup Env");    }    @Test(dependsOnMethods = {"setupEnv"})    public void testMessage(){        System.out.println("this is test message");    }}

9.TestNG测试结果报告

测试报告是测试非常重要的部分.
TestNG默认情况下,会生产两种类型的测试报告HTML的和XML的。 测试报告位于 “test-output” 目录下。当然我们也可以设置测试报告的内容级别。
verbose=”2” 标识的就是记录的日志级别,共有0-10的级别,其中0表示无,10表示最详细。

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" ><suite name="Suite1">    <test name="test12" verbose="2">        <classes>            <class name="practice02.TestNGLearn1" />        </classes>    </test></suite>
1 0