十分简单的scala单元测试

在编写性能要求高的模块的时候,单元测试是有必要的,通过搜索,我找到了一套提供单元功能测试和性能测试的可行方案,该方案简单好用,推荐给大家。

测试工具

首先找到适用于scala的好的测试工具是有必要的,通过搜索我找到了以下两个:

  1. scalaCheck:提供单元功能测试功能。
  2. scalaMeter:提供单元性能测试功能,测试局部代码的性能并给出报告。

这两个工具提供scala语言的api,集成和使用起来非常简单,下面就给出代码样例提供参考,首先找到需要的依赖包

sbt依赖:

"org.scalacheck" %% "scalacheck" % "1.14.0"% Test,
"com.storm-enroute" %% "scalameter" % "0.8.2" % Test

  

依赖包找到后根据官网提供的代码样例,我修改后用来测试不同序列化协议的序列化性能,这里主要测试json和protostuff。

代码样例

import java.sql.Timestamp

import org.json4s.jackson.Serialization.write
import org.scalameter.api._
import util.json.KafkaJsonFormat
import util.protostuff.ProtostuffUtil case class SerialTestCase(a: String, b: Timestamp) object TestPerf extends Bench.LocalTime {
implicit val formats: KafkaJsonFormat.type = KafkaJsonFormat // Brings in default date formats etc.
val y = "yisen"
val sa = Array(SerialTestCase(y, new Timestamp(System.currentTimeMillis())),
SerialTestCase(y, new Timestamp(System.currentTimeMillis())),
SerialTestCase(y, new Timestamp(System.currentTimeMillis())),
SerialTestCase(y, new Timestamp(System.currentTimeMillis())),
SerialTestCase(y, new Timestamp(System.currentTimeMillis())))
val indexes: Gen[Int] = Gen.range("model")(0, 4, 1)
performance of "Range" in {
measure method "json" in {
using(indexes) in {
r => {
write(sa(r))
}
}
}
}
performance of "Range" in {
measure method "protostuff" in {
using(indexes) in {
r => {
ProtostuffUtil.serialize(sa(r))
}
}
}
}
}

  

伴生类继承了Bench.LocalTime后就成为了可运行的scala类,直接运行,运行好后控制台会输出测试报告。

测试报告

::Benchmark Range.json::
cores: 4
hostname: ***
name: Java HotSpot(TM) 64-Bit Server VM
osArch: amd64
osName: Windows 7
vendor: Oracle Corporation
version: 25.121-b13
Parameters(model -> 0): 0.081482
Parameters(model -> 1): 0.073783
Parameters(model -> 2): 0.069933
Parameters(model -> 3): 0.070254
Parameters(model -> 4): 0.065122 ::Benchmark Range.protostuff::
cores: 4
hostname: ***
name: Java HotSpot(TM) 64-Bit Server VM
osArch: amd64
osName: Windows 7
vendor: Oracle Corporation
version: 25.121-b13
Parameters(model -> 0): 0.00385
Parameters(model -> 1): 0.003528
Parameters(model -> 2): 0.003529
Parameters(model -> 3): 0.003528
Parameters(model -> 4): 0.003528

  

报告给出了机器cpu核心数量,操作系统信息,局部代码运行时间。

通过对比发现protostuff比json的速度快20-30倍。

scalameter和scalacheck提供了scala风格的api,写起来顺手,不会感觉到去调用java的api时候的别扭。如果有其他更好的工具欢迎留言。

scala单元测试,包括功能测试和性能测试的更多相关文章

  1. Go 功能测试与性能测试

    1.功能测试 calcTriangle.go // 需要被测试的函数 func calcTriangle(a, b int) int { return int(math.Sqrt(float64(a* ...

  2. Android-jacoco代码覆盖率:单元测试覆盖率+功能测试覆盖率

    参考:https://docs.gradle.org/current/dsl/org.gradle.testing.jacoco.tasks.JacocoCoverageVerification.ht ...

  3. Python3的单元测试模块Mock与性能测试模块CProfile

    原文转载自「刘悦的技术博客」https://v3u.cn/a_id_92 我们知道写完了代码需要自己跑一跑进行测试,一个写好的程序如果连测试都没有就上到生产环境是不敢想象的,这么做的人不是太自信就是太 ...

  4. [Go] 单元测试/性能测试 (go test)

    特征 Golang 单元测试对文件名和方法名,参数都有很严格的要求.例如: 1.文件名必须以 _test.go 结尾 2.方法名必须是 Test 开头 3.方法参数必须是 t *testing.T 或 ...

  5. Web应用程序整体测试基础——单元测试

    近年来,随着基于B/S结构的大型应用越来越多,Web应用程序测试问题也在逐步完善中.但Web应用程序测试既可以在系统开发中实施,也可以独立于系统单独完成,这取决于Web应用程序的复杂性和多样性.同时程 ...

  6. 《精通移动app测试实战:技术、工具和案例》新书上市

    本书是测试专家.性能测试专家.专业畅销书作者--于涌,多年实战经验的总结,涵盖主流的测试工具,包括众多的测试实例,涵盖单元测试.功能测试.性能测试.UI测试.手游测试.自动化测试.测试用例管理.持续集 ...

  7. 我们需要专职的QA吗?

    [ 引用评论里的一句话:hurt but true  抛开作者某些偏激的想法外,作者暴露出来的问题还是需要测试思考的: 1.TestCase,TestData,TestConfiguration 没有 ...

  8. Android(Java)利用findbugs进行代码静态检查

    主要介绍利用java静态代码检查工具findbugs进行代码检查,包括其作用.安装.使用.高级功能(远程review和bug同步). 虽然Android提供了Test Project工程以及instr ...

  9. 【Android 应用开发】GitHub 优秀的 Android 开源项目

    原文地址为http://www.trinea.cn/android/android-open-source-projects-view/,作者Trinea 主要介绍那些不错个性化的View,包括Lis ...

随机推荐

  1. 前端-javascript-BOM-浏览器对象模型

    BOM的介绍---浏览器对象模型. 操作浏览器部分功能的API.比如让浏览器自动滚动. -------------------------------------------------------- ...

  2. UI5-文档-4.38-Accessibility

    作为本教程的最后一步,我们将改进应用程序的可访问性. 为此,我们将添加ARIA属性.屏幕阅读器使用ARIA属性识别应用程序结构并正确解释UI元素.通过这种方式,我们可以让我们的应用程序对那些使用电脑有 ...

  3. UI5-文档-4.16-Dialogs and Fragments

    在这一步中,我们将进一步研究另一个可以用来组装视图的元素:the fragment. 片段是轻量级UI部件(UI子树),可以重用,但是没有任何控制器.这意味着,每当你想定义一个特定UI的一部分是跨多个 ...

  4. 行矩阵列矩阵D3D&GL&U3D

    void Start () { //矩阵函数原型:Matrix4x4(Vector4 colum0, Vector4 colum1, Vector4 colum2, Vector4 colum3),这 ...

  5. EXCEL保存提示“隐私问题警告:此文档中包含宏……”解决办法

    先点击“禁止宏运行”的那个按钮.打开文件后,按alt + F11 进入宏编辑器,在“工程”里查看是什么宏.如果是你需要的,就留着.否则右击这个宏名称,选择“移除”. 另外,如果是你需要的,还需要在 工 ...

  6. Pandas数据规整

    Pandas数据规整 数据分析和建模方面的大量编程工作都是用在数据准备上的,有时候存放在文件或数据库中的数据并不能满足数据处理应用的要求 Pandas提供了一组高级的.灵活的.高效的核心函数和算法,它 ...

  7. SPARK数据类型

    转自: http://www.cnblogs.com/tuitui1989/p/5331113.html 一.本地向量 有如下几个类: Vector(基类),DenseVector,SparseVec ...

  8. 内核线程和用户线程(SMP)

    用户级和内核级线程 用户级线程:任何应用程序都可以通过使用线程库设计成多线程程序.线程库是用于用户级线程管理的一个例程句,它包含用于创建和销毁线程的代码.在线程间传递消息和数据的代码.调度线程执行的代 ...

  9. kubeadmin 部署(centos 7)

    安装指定版本docker:# yum list docker-ce --showduplicates | sort -ryum install docker-ce-18.06.1.ce-3.el7vi ...

  10. invalid self-signed ssl certificate

    down voteaccepted Cheap and insecure answer: Add process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0& ...