TestNG环境搭建以及框架初识
TestNG的英文为
Test Next Generation, 听上去好像下一代
测试框架已经无法正常命名了的样子,哈哈,言归正传,啥是TestNG呢,它是一套测试框架,在原来的Junit框架的思想基础上开发的新一代测试框架,既然这么牛b,那果断弄来试试。本文主要从安装步骤-->第一个测试例子-->再多一点例子-->框架分析-->suite文件的书写-->总结结束。
安装步骤:
1. 第一步,当然首先是在你的
java sdk, eclipse ide, system environment,都已经配置好了的情况下进行, 这些本人早就搭建好了,为了体现手把手教学,这里附加上本人的开发环境参数:os: win 8, java_version: 1.7, path: (added), eclipse_version: 4.3.1, 好了,其实只要装好这些就行了,版本么,再说,哈哈,开工
2. 第二步,去官网download一个TestNG插件,这个
工作在eclipse内完成,点击help->install new software,紧接着填上http://beust.com/eclipse
然后一路next到finish。好了TestNG插件装上了,为了check一下是否正常工作,新建一个空的工程,然后再新建一个一个TestNG类试一下,如果能够正常建立,那么就成功了,步骤:file->new->Other,会看到
如果这个看到了,那么okay,恭喜你,可以开工写测试的case了,至此,环境搭建完成。
第一个测试例子:
点击src包上右击,新建一个类,->new->class,包名就叫cases吧,类名就叫CaseOne吧不要main方法,然后finish
写第一个TestNG的带有@Test的方法如图
会有小error,这是因为我们还没有将TestNG加入到我们的LIB中来,点击错误,会有import Library的选项,点击便有了,如图
最后
可见方法method1写好了,在method里加一句
System.out.println("**********method1*********");
执行程序可以看到Console里打印了**********method1*********,接下来加入更多的方法
package cases;
import org.testng.annotations.Test;
public class CaseOne {
@Test
public void method1(){
//selenium code
System.out.println("**********method1*********");
// Assert.assertEquals("A", "B");
}
@Test
public void method2(){
System.out.println("**********method2*********");
}
@Test
public void method3(){
System.out.println("**********method3*********");
}
}
|
执行以上代码,程序将从上到下执行三个带有@Test的方法。结果
我们可以对这三个方法建立倚赖,所有后面的都建立在之前的case通过的情况下,标注是这样写的
package cases;
import org.testng.annotations.Test;
public class CaseOne {
@Test
public void method1(){
System.out.println("*********method1*********");
// Assert.assertEquals("A", "B");
}
@Test(dependsOnMethods={"method1"})
public void method2(){
System.out.println("*********method1*********");
}
@Test(dependsOnMethods={"method1","method1"})
public void method3(){
System.out.println("*********method1*********");
}
}
|
这样前面的case没通过,后面的当然也不会过,比如将注释掉的那句代码去掉就不会通过执行后面两case了。
我们还可以对method进行分组,如
@Test(groups={"group1"})
这样就不用像方法3那样倚赖写一大串了,只需要一个group的名字便可以了。
框架分析
再来看看别的annotation吧!上代码
package cases;
import org.testng.annotations.AfterClass;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test;
public class TestCase2 {
@BeforeTest
public void setUp(){
System.out.println("*******before********");
}
@BeforeMethod
public void beforeMethod(){
System.out.println("*******beforeMethod********");
}
@AfterMethod
public void afterMethod(){
System.out.println("*******aftermethod********");
}
@Test
public void t1(){
System.out.println("*********t1**********");
}
@Test
public void t2(){
System.out.println("*********t2**********");
}
@BeforeClass
public void beforeClass(){
System.out.println("*****beforeClass*****");
}
@AfterClass
public void afterClass(){
System.out.println("*****afterClass*****");
}
@AfterTest
public void finish(){
System.out.println("*******finish********");
}
}
|
运行得到结果如下
*******before********
*****beforeClass*****
*******beforeMethod********
*********t1**********
*******aftermethod********
*******beforeMethod********
*********t2**********
*******aftermethod********
*****afterClass*****
*******finish********
PASSED: t1
PASSED: t2
===============================================
Default test
Tests run: 2, Failures: 0, Skips: 0
===============================================
|
这样一来咱们就大概的知道了不同的annotation下的方法的执行顺序了。基本上是@BeforeTest->@BeforeClass->(@BeforeMethod->@Test->@AfterTest)->...重复()内内容...->@AfterClass->@AfterTest.好了,框架基本如下,
再多一点例子:
同时建立多个Class,如
如果全部选中,当然会从上当下的执行,但是万一有些文件我们不想执行呢,比如CaseOne中的method1我们想跳过去,那就得写一个控制文件了,在TestNG中使用xml来控制,在顶级目录下建一个build.xml文件,内容如下
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="My Sample Suite">
<test name="First test">
<classes>
<class name="cases.CaseOne"></class>
</classes>
</test>
<test name="Second test">
<classes>
<class name="cases.CaseTwo"></class>
</classes>
</test>
<test name="Third test">
<classes>
<class name="cases.CaseThree"></class>
</classes>
</test>
</suite>
这是按类写的,当然你可以写的更详细,指定方法
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="My Sample Suite">
<test name="First test">
<classes>
<class name="cases.CaseOne"></class>
<methods>
<include name="method1"/>
<include name="method2"/>
</methods>
</classes>
</test>
<test name="Second test">
<classes>
<class name="cases.CaseTwo"></class>
</classes>
</test>
<test name="Third test">
<classes>
<class name="cases.CaseThree"></class>
</classes>
</test>
</suite>
|
这样类CaseOne中的第三个方法会掠过去不执行。
总结:
在我看来,TestNG是一个非常好用的测试框架,其测试步骤顺序很规范,很强大,当然还有很多东西要去探索。笔者水平较浅,不足之处,大家海涵!