Spock是什么?它和JUnit,JMock有什么区别?

这是Spock系列的第一篇文章,整个专辑会介绍Spock的用途,为什么使用Spock?它能给我们带来什么好处?它和JUnit、JMock、Mockito有什么区别?我们平时写单元测试代码的常见问题和痛点,Spock又是如何解决的,Spock的代码怎么编写以及Spock的优势和缺点等内容,让大家对Spock有个客观的了解。

Spock是什么?

斯波克是国外一款优秀的测试框架,基于BDD思想,功能强大,能够让我们的测试代码规范化,结构层次清晰,结合groovy动态语言的特点以及自身提供的各种标签让编写测试代码更加高效简洁,提供一种通用、简单、结构化的描述语言
引用官网的介绍如下(http://spockframework.org)
“ Spock是一个Java和Groovy应用程序的测试和规范框架。
它之所以能在人群中脱颖而出,是因为它优美而富有表现力的规范语言。
斯波克的灵感来自JUnit、RSpec、jMock、Mockito、Groovy、Scala、Vulcans ”
简单说Spock的特点如下:
  • 让我们的测试代码更规范,内置多种标签来规范单测代码的语义,从而让我们的测试代码结构清晰,更具可读性,降低后期维护难度
  • 提供多种标签,比如: where、with、thrown... 帮助我们应对复杂的测试场景
  • 再加上使用groovy这种动态语言来编写测试代码,可以让我们编写的测试代码更简洁,适合敏捷开发,提高编写单测代码的效率
  • 遵从BDD行为驱动开发模式,不单是为了测试覆盖率而测试,有助于提升代码质量
  • IDE兼容性好,自带mock功能
为什么使用Spock?  Spock和JUnit、JMock、Mockito的区别在哪里?
现有的单测框架比如junit、jmock、mockito都是相对独立的工具,只是针对不同的业务场景提供特定的解决方案。
Junit单纯用于测试,不提供mock功能
微服务已经是互联网公司的主流技术架构,大部分的系统都是分布式,服务与服务之间一般通过接口的方式交互,甚至服务内部也划分成多个module,很多业务功能需要依赖底层接口返回的数据才能继续剩下的流程,或者从数据库/Redis等存储设备上获取,或是从配置中心的某个配置获取。
这样就导致如果我们想要测试代码逻辑是否正确,就必须把这些依赖项(接口、Redis、DB、配置中心...)给mock掉。
如果接口不稳定或有问题则会影响我们代码的正常测试,所以我们要把调用接口的地方给模拟掉,让它返回指定的结果(提前准备好的数据),这样才能往下验证我们自己的代码是否正确,符合预期逻辑和结果。
JMock或Mockito虽然提供了mock功能,可以把接口等依赖屏蔽掉,但不提供对静态类静态方法的mock,PowerMock或Jmockit虽然提供静态类和方法的mock,但它们之间需要整合(junit+mockito+powermock),语法繁琐,而且这些工具并没有告诉你“单元测试代码到底应该怎么写?
工具多了也会导致不同的人写出的单元测试代码五花八门,风格迥异。。。
Spock通过提供规范描述,定义多种标签(given、when、then、where等)去描述代码“应该做什么”,输入条件是什么,输出是否符合预期,从语义层面规范代码的编写。
Spock自带Mock功能,使用简单方便(也支持扩展其他mock框架,比如power mock),再加上groovy动态语言的强大语法,能写出简洁高效的测试代码,同时更方便直观的验证业务代码行为流转,增强我们对代码执行逻辑的可控性。
下一篇文章会详细讲解我们平时在编写单元测试代码过程中遇到的痛点,并结合实际的代码案例来说明Spock是如何解决这些问题的。比如单测开发的效率和成本问题,可读性以及后期维护的问题,单测如何提升业务代码质量等。
背景和初衷
网上关于Spock的资料比较简单,包括官网的demo,无法解决我们项目中的复杂业务场景,需要找到一套适合自己项目的成熟解决方案,所以觉得有必要把我们项目中使用Spock的经验分享出来, 帮助大家提升单测开发的效率和验证代码质量。
在熟练掌握Spock后我们项目组整体的单测开发效率提升了50%以上,代码可读性和维护性都得到了改善和提升。
适合人群
写Java单元测试的开发小伙伴和测试同学,所有的演示代码运行在IntelliJ IDEA中,spring-boot项目,基于Spock 1.3-groovy-2.5版本
(0)

相关推荐

  • 单元测试难?来试试这些套路

    阿里妹导读:测试不应该是一门很高大尚的技术,应该是我们技术人的基本功.但现在好像慢慢地,单元测试已经脱离了基本功的范畴.笔者曾经在不同团队中推过单元测试,要求过覆盖率,但发现实施下去很难.后来在不停地 ...

  • 小白搞 Spring Boot单元测试

    内容是:Spring Boot 中的单元测 前言 何为单元测试 单元测试的目的: 测试当前所写的代码是否是正确的, 例如输入一组数据, 会输出期望的数据; 输入错误数据, 会产生错误异常等. 在单元测 ...

  • 一文让你快速上手 Mockito 单元测试框架

    前言 在计算机编程中,单元测试是一种软件测试方法,通过该方法可以测试源代码的各个单元功能是否适合使用.为代码编写单元测试有很多好处,包括可以及早的发现代码错误,促进更改,简化集成,方便代码重构以及许多 ...

  • JUnit 5 集成 Allure 测试报告

    前面的文章我们介绍过 JUnit 5 单元测试框架: [干货]JUnit5快速指南 利用这个单元测试框架完成单元测试来帮助提高代码质量,但是对于测试结果而言 JUnit 5 提供的测试报告不够美观,所 ...

  • Android studio之Error:(23, 17) Failed to resolve: junit:junit:4.12

    Android studio之Error:(23, 17) Failed to resolve: junit:junit:4.12

  • Android Studio之package org.junit does not exist解决办法

    Android Studio之package org.junit does not exist解决办法

  • 儒、释、道三家文化的七大区别

    闲云谷 峰下闲云云上松,珍兰奇蕙伴节丛:不忍移爱进瓦罐,卷书抱坛迁谷中. 994篇原创内容 公众号 一.文化主旨 儒家文化--积极进取的文化 儒家倡导知识的获取和品德的培养,是一种积极向上的文化. 道 ...

  • 招摇撞骗罪和诈骗罪有什么区别

    招摇撞骗罪和诈骗罪都表现为欺骗行为,招摇撞骗罪也可以像诈骗罪一样骗取财物,两者容易混淆,大家知道招摇撞骗罪和诈骗罪有什么区别吗? 律师解答: 招摇撞骗罪侵犯的客体主要是国家机关的威信及其正常活动,而诈 ...

  • 香港服务器托管和租用有什么区别?

    香港服务器托管和租用有什么区别?托管和租用都是服务器选择使用方式,想要知道香港服务器托管和租用两种方式有什么区别以及哪种方式比较好,就需要深入了解它们,下面我们就聊聊香港服务器托管和租用的区别. 什么 ...

  • “全款”和“贷款”买房有什么区别?内行:10年后,差距一目了然

    因为现在国内的房价总体上呈现出不断上涨的趋势,尤其是在一二线城市靠近市中心的房子更是高到令现在的不少家庭都有着很大的生活重担,对于现在的年轻人来说也很难能够在他们的承受范围之内. 所以,如果高房价持续 ...

  • “普通人vs 女网红的区别...” 哈哈哈哈哈哈哈哈哈过于真实!

    网上冲浪久了 不得不感叹 现在的女网红真的很努力 为了拍出 前凸后翘的照片 不管何时何地 都执着地凹着浮夸的摆拍造型 网友甚至总结出了当网红的精髓 普通人vs 女网红的区别 学废了 离网红就差一个骨盆 ...