小白学TestNG笔记 1——简单使用Testng

TestNG是一个强大的测试框架,这篇文章主要简单说明一下使用TestNG并生成一个简单报告

SureFire插件

开始之前,我们先Maven介绍SureFIre插件(如果你还不了解Maven,请查看之前写的文章小白学Maven笔记 1——快速开始,这个插件使用来在test阶段来实行单元测试的,我们主要用它来生成报告。他可以生成两种格式的报告

  • *.txt
  • .xml (默认会生成类似于${basedir}/target/surefire-reports/Test-.xml的文件)

1.首先我们在pom.xml文件添加surefire插件和加入testNG框架的依赖


        
            org.testng
            testng
            6.9.8
            test
        
    

    
        
            
                
                    org.apache.maven.plugins
                    maven-surefire-plugin
                    2.20
                
            
        
    

2.在src/main/java下面创建demo类

package com.moke;

/**
 * Created by moke on 2017/4/21.
 */
public class demo {

    public String returnString() {
        return "test";
    }
}

3.在src/test/java下面创建测试类demoTest(这里要以Test结尾,默认只会识别Test结尾的文件,但是可以根据自己需要指定,这里就不多说了)

package com.moke.test;

import com.moke.demo;
import org.testng.Assert;
import org.testng.annotations.Test;

/**
 * Created by moke on 2017/4/21.
 */
public class demoTest {

    @Test
    public void testReturnString() {//这里检验了是否返回test字符串
        Assert.assertEquals("test", new demo().returnString());
    }
}

4.命令行下执行mvn test,这里可以看到执行成功了一个测试

[INFO] Running com.moke.test.demoTest
[INFO] Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 0.37 s - in com.moke.test.demoTest
[INFO] 
[INFO] Results:
[INFO] 
[INFO] Tests run: 1, Failures: 0, Errors: 0, Skipped: 0
[INFO] 
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 3.395 s
[INFO] Finished at: 2017-04-22T23:16:26+08:00
[INFO] Final Memory: 21M/300M
[INFO] ------------------------------------------------------------------------

同时生成的target目录下面我们也能看到surefire-reports目录,这里有surefire插件生成的报告

小白学TestNG笔记 1——简单使用Testng_第1张图片
屏幕快照 2017-04-22 23.23.01.png
小白学TestNG笔记 1——简单使用Testng_第2张图片
屏幕快照 2017-04-22 23.31.39.png

到目前为止你已经使用TestNG完成了一个简单的测试并且生成了一份报告,接下来我们具体讲解一下TestNG框架

生命周期

我们在src/test/java目录下面创建另外一个文件吧

package com.moke.test;

import org.testng.Assert;
import org.testng.annotations.*;

/**
 * Created by moke on 2017/4/20.
 */
public class TestLifeCircle {

    @BeforeSuite
    public void beforSuite() {
        System.out.println("我是beforesuit在整个suit之前只会运行一次");
    }

    @AfterSuite
    public void afterSuit() {
        System.out.println("我是aftersuit在整个suit之后只会运行一次");
    }

    @BeforeTest
    public void beforeTest() {
        System.out.println("我是beforeTest,在所有标签中类的所有方法运行之前运行一次");
    }

    @AfterTest
    public void afterTest() {
        System.out.println("我是afterTest,,在所有标签中类的所有方法运行之后运行一次");
    }

    @BeforeClass
    public void beforeClass() {
        System.out.println("我是beforeCLass,在当前class中第一个方法运行前运行一次");
    }

    @AfterClass
    public void afterClass() {
        System.out.println("我是afterCLass,在当前class中所有方法运行后运行一次");
    }

    @BeforeMethod
    public void beforeMethod() {
        System.out.println("我是beforemethod,在每个测试方法前运行一次");
    }

    @AfterMethod
    public void afterMethod() {
        System.out.println("我是aftermethod,在每个测试方法后运行一次");
    }

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

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

看到这里,熟悉Junit的朋友应该已经知道什么情况了吧,我们运行一下可以看到类似下面的输出

我是beforesuit在整个suit之前只会运行一次
我是beforeTest,在所有标签中类的所有方法运行之前运行一次
我是beforeCLass,在当前class中第一个方法运行前运行一次
我是beforemethod,在每个测试方法前运行一次
testEmailGenerator
我是aftermethod,在每个测试方法后运行一次
我是beforemethod,在每个测试方法前运行一次
testStringGenerator
我是aftermethod,在每个测试方法后运行一次
我是afterCLass,在当前class中所有方法运行后运行一次
我是afterTest,,在所有标签中类的所有方法运行之后运行一次
我是aftersuit在整个suit之后只会运行一次

刚刚发生了什么?TestNG使用Annotation的方式来指定了一些生命周期,在这些阶段我们可以做各自需要的一些操作,例如每个测试方法必须使用@Test来标记。看了上面的例子相信TestNG的生命周期你应该有一定了解了吧,关于TestNG中的Annotation更多的可以点击TestNG

关于TestNG的其他知识以后有空了在慢慢整理

你可能感兴趣的:(小白学TestNG笔记 1——简单使用Testng)