TestNG介绍

TestNG介绍TestNG 介绍 TestNG 是 Java 中的一个测试框架 类似于 JUnit 和 NUnit 功能都差不多 只是功能更加强大 使用也更方便 Java 中已经有一个 JUnit 的测试框架了 TestNG 比 JUnit 功能强大的多 测试人员一般用 TestNG 来写自动化测试 开发人员一般用 JUnit 写单元测试 官方网站 http testng org doc index html 在 Eclip

TestNG介绍

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

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

官方网站: http://testng.org/doc/index.html

在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的基本注解

这里写图片描述

TestNG中如何执行测试
第一种直接执行:右键要执行的方法,  点Run As ->TestNG Test
这里写图片描述




使用testng.xml 文件执行 case
第二种: 通过testng.xml文件来执行. 把要执行的case, 放入testng.xml文件中。 右键点击testng.xml, 点Run As
testng.xml




 
    <suite name="Suite1"> <test name="test12"> <classes> <class name="TankLearn2.Learn.TestNGLearn1" />  
   classes>  
   test>  
   suite>

这里写图片描述

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

 
    <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异常测试

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中 按组执行测试用例

 
     <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

 
    <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测试结果报告
测试报告是测试非常重要的部分.

 
    <suite name="Suite1"> <test name="test12" verbose="2"> <classes> <class name="TankLearn2.Learn.TestNGLearn1" />  
   classes>  
   test>  
   suite>

转自:http://www.cnblogs.com/TankXiao/p/3888070.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/217733.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 上午8:53
下一篇 2026年3月18日 上午8:53


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号