测试并发应用(九)MultithreadedTC测试并发代码
MultithreadedTC 是一个 Java 库用来测试并发应用。它的主要目的是为了解决并发应用的不确定的问题。你不能控制他们的执行顺序。为了这个目睹,它包含了内部节拍器来控制应用的不同线程的执行顺序。这些测试线程作为类的方法来实现的。
在这个指南,你将学习如何使用 MultithreadedTC 库来为LinkedTransferQueue 实现一个测试。
准备
你必须从 http://code.google.com/p/ multithreadedtc/ 下载 MultithreadedTC library,并从 http://www.junit.org/ 下载 JUnit library, Version 4.10。把 junit-4.10.jar 和 MultithreadedTC-1.01.jar文件加入项目的库中。
怎么做呢…
按照这些步骤来实现下面的例子::
//3. 实现 initialize() 方法。此方法不接收任何参数,也不返回任何值。它调用父类的 initialize() 方法,然后初始化 queue 属性。
//4. 实现 thread1() 方法。它将实现的逻辑是第一个consumer。调用 queue 的 take() 方法,然后把返回值写入操控台。
//5. 实现 thread2() 方法。它将实现的逻辑是第二个consumer。首先,使用 waitForTick() 方法,一直等到第一个线程在 take() 方法中进入休眠。然后,调用queue的 take() 方法,并把返回值写入操控台。
//6. 实现 thread3() 方法。它将实现的逻辑是producer。 首先,使用 waitForTick() 两次一直等到2个consumers被阻塞。然后,调用 queue的 put() 方法插入2个String 到queue中。
//7. 最后,实现 finish() 方法。写信息到操控台表明测试结束执行。使用assertEquals() 方法检查2个事件已经被consumed(queue的大小为0)。
它是如何工作的…
在这个指南,你使用MultithreadedTC库为 LinkedTransferQueue 类实现了一个测试。你可以使用这个库和它的节拍器为任何并发应用或者类实现测试。在例子中,你实现经典的 producer/ consumer 问题,2个consumers 和一个producer。 你想要测试的是 在buffer里的第一个介绍的 String 对象会被第一个consumer 消耗,和在buffer里第二个介绍的String对象会被第二个到达的consumer消耗。
MultithreadedTC库是基于JUnit 库的。JUnit库是在Java中最经常用来实现unit测试时使用的库。使用 MultithreadedTC 库来实现一个基本测试,你必须扩展 MultithreadedTestCase 类。这个类扩展了 junit.framework.AssertJUnit 类,包含了全部检查测试结果的方法。它并没有扩展 junit.framework.TestCase 类,使用你不能在其他 JUnit 测试中导入MultithreadedTC测试。
然后,你实现了以下这些方法:
initialize(): 此方法的实现是可选的。当你开始测试时,它就会执行,为了初始化测试中使用的对象而使用它。
finish(): 此方法的实现是可选的。当测试结束时,它就会执行。你可以使用它在测试或者检查测试结果期间来关闭或者释放资源。
实现测试的方法:这些方法的主要逻辑就是测试你的实现。他们用thread作为始关键词连接着字符串 例如, thread1()。
使用 waitForTick() 方法来控制线程的执行顺序。此方法接收一个整数type作为参数,把正在执行的thread放入休眠直到全部在测试里运行的线程都被阻塞。等他们被阻塞时, MultithreadedTC 库调用 waitForTick() 方法 恢复被阻塞的线程。
传递给 waitForTick() 方法作为参数的整数是用来控制执行顺序的。MultithreadedTC 库的节拍器有个内部计数器。当全部线程被阻塞时,库增加计数器到下个在 waitForTick() 调用中的数字,那么被阻塞的。
从内部来说,当 MultithreadedTC 库 执行测试,首先它执行 方法。然后,它创建每个用thread作为关键词开头的方法的线程(例子中是,方法 thread1(), thread2(), 和 thread3()),当全部线程都结束运行后,就执行 finish() 方法。为了运行测试,你要使用 TestFramework 类的 runOnce() 方法。
更多…
如果 MultithreadedTC library 检测的全部线程都被阻塞,但是没有一个是被 waitForTick() 方法阻塞的,那么测试就会被认为在deadlock状态,并抛出 java.lang.IllegalStateException 异常。
参见
第八章,测试并发应用:FindBugs分析并发代码
阿里云服务器ECS共享型s6和n4性能对比CPU、内存、网络PPS和应用测试 阿里云服务器ECS共享型n4实例CPU采用2.5 GHz主频的Intel ® Xeon ® E5-2682 v4(Broadwell);ECS共享型s6实例2.5 GHz主频的Intel ® Xeon ® Platinum 8269CY(Cascade Lake),睿频3.2 GHz,计算性能稳定
测试必会 | 通过容器化 Python Web 应用掌握 Docker 容器核心技能 - 当多个窗口同时 attach 到同一个容器时,所有的窗口都会同步的显示,假如其中的一个窗口发生阻塞时,其它的窗口也会阻塞。 - attach 必须是登陆到一个已经运行的容器里,如果从这个容器中 exit 退出的话,会导致容器停止。 - 容器里进程新建的文件,怎么才能让宿主机获取到? - 宿主机上的文件和目录,怎么才能让容器里的进程访问到? - CONTAINER ID:容器 ID,唯一标识容
首先来看业界用的较早也是经常听过的一款工具—— Monkey。这是 Android 官方提供的一个工具。谷歌原本设计这款工具是为了对 App 进行压力测试的。谷歌早期在设计 Android 的时候,Android 需要响应滑动、输入、音量、电话等事件,早期 activity 设计不完善的时候,谷歌希望测试 activity 的性能,把所有的数据批量化的输出给 activity,看 activ
ali清英 方腾飞,花名清英,英文名kiral,并发编程网创始人,支付宝技术专家,《Java并发编程的艺术》作者。
相关文章
- 测试并发应用(四)监控Fork/Join池
- 测试并发应用(三)监控Executor框架
- 测试并发应用 (一)监控Lock接口
- SAP UI5 应用开发教程之七十九 - 采用测试驱动开发理念(Test Driven Development)进行 SAP UI5 应用的功能开发(一)的试读版
- SAP UI5 应用开发教程之八十五 - 如何用 OPA5 编写测试用例来测试用户输入文本的功能试读版
- SAP Fiori 应用的本地 sandbox Launchpad - 出于测试用途
- ML之FE:数据处理—特征工程之数据集划分成训练集、验证集、测试集三部分简介、代码实现、案例应用之详细攻略
- 〖Python WEB 自动化测试实战篇⑪〗- 实战 - 利用 unittest 框架设计应用改写脚本
- 【Android 插件化】Hook 插件化框架 ( 创建插件应用 | 拷贝插件 APK | 初始化插件包 | 测试插件 DEX 字节码 )
- 初学者教程:如何学习渗透测试?
- 业务?技术?身为测试的你,该如何看待?(上)
- 这几本测试书籍强烈推荐!还有这必须关注的网站...
- 自动化测试技术分享 | 敏捷开发、瀑布与迭代模型的项目应用分析
- 应用| 基于VT的桌面式VCU HiL及BMS HiL测试系统
- 移动应用测试篇(7)——APP测试辅助工具
- 怎样正确做 Web 应用的压力测试?字节8年测试5个步骤给我看师了
- 实战应用 —— ApiTesting全链路接口自动化测试框架
- JS执行器在UI自动化测试中的应用
- 薪资很高的自动化接口测试,3分钟带你入门!
- 自动化测试===Macaca环境搭建,自我总结
- 风格迁移0-02:stylegan-目录讲解与预训练模型测试
- 启动hdfs时,报错 不良 : Canary 测试无法在目录 /tmp/.cloudera_health_monitoring_canary_files 中写入文件。
- 应用| 基于VT的桌面式VCU HiL及BMS HiL测试系统
- C-V2X仿真测试之虚拟场景设计