zoukankan      html  css  js  c++  java
  • TestNG--入门介绍教程

    阅读目录
    TestNG介绍
    在Eclipse中在线安装TestNG
    在Eclipse中离线安装Testng
    TestNG最简单的测试
    TestNG的基本注释
    TestNG中如何执行测试
    使用testtng.xml 文件执行 case
    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的最简单的一个例子

    package TankLearn2.Learn;
    import org.junit.AfterClass;
    import org.junit.BeforeClass;
    import org.testng.annotations.Test;
    public class TestNGLearn1 {
        @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");
        }
    }

    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
    使用testtng.xml 文件执行 case
    第二种: 通过testng.xml文件来执行. 把要执行的case, 放入testng.xml文件中。 右键点击testng.xml, 点Run As testng.xml 内容:

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

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

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

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

    package TankLearn2.Learn;
    import org.testng.annotations.Test;
    public class ExceptionTest {  
        @Test(expectedExceptions = IllegalArgumentException.class, expectedExceptionsMessageRegExp="NullPoint")
        public void testException(){
            throw new IllegalArgumentException("NullPoint");
        }
    }
    //TestNG组测试
    //TestNG中可以把测试用例分组,这样可以按组来执行测试用例比如:
    package TankLearn2.Learn;
    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>

    TestNG参数化测试
    软件测试中,经常需要测试大量的数据集。
    测试代码的逻辑完全一样,只是测试的参数不一样。
    这样我们就需要一种 “传递测试参数的机制”。 避免写重复的测试代码
    TestNG提供了2种传递参数的方式。
    第一种: testng.xml 方式使代码和测试数据分离,方便维护
    第二种:@DataProvider能够提供比较复杂的参数。 (也叫data-driven testing)

    /////////////////////////////////////////
    //方法一: 通过testng.xml 传递参数给测试代码
    package TankLearn2.Learn;
    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="TankLearn2.Learn.ParameterizedTest1" />
            </classes>
        </test>
    </suite>
    ///////////////////////////////////////////////////////////
    // 方式二:   通过DataProvider传递参数
    
    package TankLearn2.Learn;
    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);
        }
    }

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

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

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

    package TankLearn2.Learn;
    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");
        }
    }

    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="TankLearn2.Learn.TestNGLearn1" />
            </classes>
        </test>
    </suite>
  • 相关阅读:
    上传github代码
    git 代码更新
    linux 遇见的问题
    How to stop pycharm show files in project in red color?
    Linux下动态库查找路径的问题
    centos7 建立虚拟目录
    [BZOJ3747] Kinoman
    [BZOJ2169] 连边
    [洛谷P4251] 小凸玩矩阵
    [洛谷P2764] 最小路径覆盖
  • 原文地址:https://www.cnblogs.com/xiaofeifei-wang/p/6734744.html
Copyright © 2011-2022 走看看