Testng 与 Junit 测试框架浅谈

本贴最后更新于 3047 天前,其中的信息可能已经天翻地覆

      对于测试人员来说,如何提高测试效率、保证测试质量始终是我们关注的重点。尤其是代码级的测试,面对开发人员完成的各种接口方法,我们应该如何去有效地进行测试验证呢,是否已经有测试框架供我们使用呢?答案是肯定的。下面我们主要介绍TestNG的常见用法以及和JUnit的对比。

一、 TestNG介绍

      TestNG是一个设计用于简化广泛测试需求的开源自动化测试框架,从最简单的单元测试到较为复杂的集成测试。它的灵感来自于JUnit,在尽量保持后者简单性的同时,消除了大部分原有测试框架的限制,使开发人员能够编写更加灵活强大的测试。TestNG不仅强大、创新、可扩展、灵活,还大量借用了Java 注解来定义测试。

TestNG的官方文档网址为http://testng.org/doc/documentation-main.html

二、 TestNG用法

   使用TestNG比较简单,通常我们采用IDE进行代码编写和测试,比如在eclipse中我们只要安装相应的插件并在具体的测试项目中导入TestNG相关包就可以了下面是TestNG的一个简单例子;

1

1 TestNG的简单例子

   这个例子虽然没有什么实质上的内容,但基本上已经包括TestNG所要涉及到的知识点。首先测试类是一个普通的java类,但是和一般的java类不同的是,已经没有了常见的main()函数作为入口其次使用了注解的方式,这是TestNG核心的功能注解下对应具体的测试方法,并控制方法的执行顺序和策略,使用这些注解需要引入类包。最后运行这个测试类,便可以看到输出结果了 

  1. 基本注解

   常用的TestNG注解有以下几个:

 

 

2 TestNG常用注解及描述

   从注解名称可以知道有些注解方法会在特定的时刻执行,比如在所有测试方法之前(之后)、分组方法之前(之后)等。那么具体各注解方法之间的执行顺序又是怎样的呢,我们通过下面的例子来看。

   

3 注解方法执行顺序举例  

 

                   

                              图4 测试执行结果

   图3为测试代码,图4为执行结果。从中可以知道,beforeTest注解方法会在所有方法之前执行,而afterTest注解方法在所有方法之后执行。具体的测试执行流程如图所示:

 

5 TestNg测试执行流程

   由于有些方法仅在整个测试类的起始和结尾处会执行一遍,所以可以在@beforeClass注解方法中对数据进行配置、对象初始化和文件打开工作,在@afterClass注解方法中进行数据清理和文件关闭等扫尾工作。

  1. 断言与分组

   我们测试的目的是及时发现软件设计过程中的错误与缺陷,但是在具体的测试过程中如何去比较预期的结果和实际运行的结果是否一致呢?在TestNG中使用断言机制。常用的断言有以下几种:assertEquals相等断言)、assertNotEquals不等断言)、assertTrue为真断言)、assertFalse为假断言)、assertNull空断言)、assertNotNull非空断言)、assertSame相同断言)、assertNotSame不同断言)。基本的断言使用方法如下图所示:

 

6 测试断言

  其他的断言方法可以利用eclipse的自动补全帮助看到它们的函数原型和使用方式。通过在测试方法中合理正确地设置断言,可以及时并有效发现程序中的错误与设计问题,提高测试的准确性。

    TestNG中另外的一个特性是分组。在具体的测试过程中,如果需要测试的功能模块过多,经常会对测试用例进行分类,有时候又想针对某一部分进行测试,这时可以使用分组测试。分组测试的原则是:保留最小集合。因为运行测试类默认执行所有的测试方法,因此想要选择分组测试就需要通过xml配置文件的设置来实现。具体的配置方法如下:

 

7 分组测试

 

8 testng.xml分组配置

  首先通过@Test注解中的groups属性对测试方法进行分组,然后在xml配置文件的<groups>标签中对需要执行的分组方法进行设置<include>表示执行包含的组方法,<exclude>表示执行排除的组方法因为分组测试取最小集合执行,所以本例中只有group_method2方法会被执行。

  1. 参数化测试

  我们经常需要大量的测试数据集,以保证测试的覆盖率和其软件程序的稳定性。此时仅仅是输入的测试参数有所不同,代码逻辑基本一样。如果按每条数据编写一个测试用例,将会出现很多重复的代码。TestNG提供了两种传递参数的方法,可以有效避免测试代码的重复,同时有利于整体的维护管理。

1) @DataProvider注释可以提供数据参数,供测试方法调用。

 

9 Dataprovider传递测试数据

  标注的方法返回object二维数组,数组内为相应的测试数据,可以是基本数据类型,也可以是复杂的对象类型。在测试方法中添加dataProvider属性,方法中的参数与返回的测试数据需要相互匹配。该标注方法只能TestNG调用,且可以传递参数,如Method类型,这样就可以通过反射机制获取测试方法类型,然后根据不同的调用方法来传递特定的数据。使用这种方式的好处在于除了intString等基本数据类型之外,还可以提供复杂的对象,不足之处是在代码中存在大量测试数据,修改数据后需要重新编译代码。

2)使用@Parameters结合testng.xml文件,将具体的数据放置在该文件中,然后在测试方法中进行调用。

 

                                                                                      10 Parameters传递测试数据

 

11 testng.xml参数配置

  通过xml配置文件中的<parameter>标签来设置name-value,然后在测试类中添加相应name就能把value值传递到对应的参数当中。该方法需要通过执行xml文件来实现测试,很好地做到了代码和数据的分离但是这种方法只能传递基本类型数据。不过我们可以使用间接的方式传递复杂数据。

  上述两种传递测试参数的方式有各自的优缺点,然而无论是使用@DataProvider还是@Parameters注解,如果在代码内提供数据,不利于测试代码的整体维护和扩展。更好的方案是将测试数据放置在外部文件当中,然后在测试过程中读取相应的文件,解析出数据传入到测试方法当中,这样当需要修改或者添加数据时就只要在文件中按照相应的格式进行调整就行,而不必再去关心代码具体的实现这里就不再展开。

三、 TestNGJUnit对比

  前面主要介绍了TestNG的一些基本用法,其实在TestNG之前,我们使用更多的是JUnit测试框架。JUnitTestNG 之间有一些共同的特性,这两个框架都可以让测试工作变得简单便利JUnit一个单元测试框架,其构建目的主要是为了单个对象的测试,而 TestNG 则是用来解决更高级别的测试问题,可以测试单个类,也可以测试有多个类多个包甚至多个外部框架组成的系统。

  1.两者都支持BeforeAfter注解方法。但是相对于JUnitTestNG进行了更为详细的划分。JUnit中只有beforebeforeClassTestNG则包含beforeSuitebeforeTestbeforeClassbeforeMethodbeforeGroups,以在不同的时刻执行,其中JUnit中的beforeTestNG中的beforeMethod类似。After方法亦然。在JUnit 4中,必须把@BeforeClass修饰的方法声明为public static,这样就限制了该方法中使用的变量必须是static。相对的,TestNG中就没有这种限制,可以使用普通的函数。

  2. 在常用的断言中,除了TestNG中的几个以外,JUnit4中还有一个常用的assertThat断言,可以替代其他的断言方法。assertThat使用了 Hamcrest Matcher 匹配符,用户可以使用匹配符规定的匹配准则更加精确地去指定需要的条件,具有很强的易读性和灵活性。

  3. JUnit中,如果测试套件运行失败,将会重新运行整个测试套件,无论其中的测试方法原来是否通过,这将会耗费大量的时间。而在TestNG中可以进行失败测试重运行,集中执行失败的测试,而不是整个测试套件中的所有方法。当有测试方法执行失败时,TestNG会创建一个testng-failed.xml文件,对失败的测试加以说明,运行该文件可以只执行失败用例。这对于规模较大的测试套件来说简化了执行工作,能够快速定位出错方法,提高整体测试效率。

  4. JUnit 测试的依赖性很强,测试方法之间有严格的先后执行顺序。如果前一个测试不成功,后续所有的依赖测试都会失败。这样带来的一个问题就是很难发现到底哪些测试是真正失败的,而哪些测试只是因为依赖失败引起的。在这一点上,TestNG进行了改进,利用@Test dependsOnMethods属性来应对测试依赖性问题。某方法依赖的方法失败,它将被跳过,而不是标记为失败,这样我们可以集中精力关注那些跳过的用例方法,有利于排查失败原因。

  5.其他的区别还有TestNG支持分组而JUnit不支持,JUnit中还有假设机制和理论机制等,由于这块涉及的内容较多,有兴趣的话可以查阅相关资料。

  从以上的几点对比可以看出,TestNG在某些测试方面显得更加的灵活,但是JUnit也有自己特有的一些方法,在实际的使用过程当中,我们可以把这两种框架结合起来,提高测试效率。

四、 总结

  本文主要介绍了TestNG测试框架的基本用法,包括注解、断言与分组以及参数化测试,然后将TestNGJUnit的特性进行了对比。对于这两个测试框架更深刻的认识与掌握,需要我们可以从平时的实践中不断地去积累。

 

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    143 引用 • 442 回帖
  • jsDelivr

    jsDelivr 是一个开源的 CDN 服务,可为 npm 包、GitHub 仓库提供免费、快速并且可靠的全球 CDN 加速服务。

    5 引用 • 31 回帖 • 112 关注
  • 运维

    互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。

    150 引用 • 257 回帖 • 1 关注
  • Excel
    31 引用 • 28 回帖
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 56 关注
  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖
  • sts
    2 引用 • 2 回帖 • 228 关注
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖
  • JetBrains

    JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA

    18 引用 • 54 回帖
  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    556 引用 • 675 回帖
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    730 引用 • 1280 回帖 • 4 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 726 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 590 关注
  • 安全

    安全永远都不是一个小问题。

    203 引用 • 818 回帖
  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    495 引用 • 931 回帖 • 1 关注
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    7 引用 • 30 回帖 • 385 关注
  • danl
    163 关注
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    79 引用 • 431 回帖 • 1 关注
  • ActiveMQ

    ActiveMQ 是 Apache 旗下的一款开源消息总线系统,它完整实现了 JMS 规范,是一个企业级的消息中间件。

    19 引用 • 13 回帖 • 679 关注
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    168 引用 • 597 回帖
  • React

    React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。

    192 引用 • 291 回帖 • 375 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 46 关注
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 633 关注
  • abitmean

    有点意思就行了

    36 关注
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    21 引用 • 31 回帖
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖 • 1 关注
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖