测试并发应用(九)MultithreadedTC测试并发代码

简介:

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文件加入项目的库中。

怎么做呢…

按照这些步骤来实现下面的例子::

01 //1.   创建一个类,名为 ProducerConsumerTest,扩展 MultithreadedTestCase 类。
02 public class ProducerConsumerTest extends MultithreadedTestCase {
03  
04 //2.   声明一个私有 LinkedTransferQueue 属性,用 String 类为参数,名为 queue。
05 private LinkedTransferQueue<String> queue;
06  
07 //3.   实现 initialize() 方法。此方法不接收任何参数,也不返回任何值。它调用父类的 initialize() 方法,然后初始化 queue 属性。
08 @Override
09 public void initialize() {
10     super.initialize();
11     queue=new LinkedTransferQueue<String>();
12     System.out.printf("Test: The test has been initialized\n");
13 }
14  
15 //4.   实现 thread1() 方法。它将实现的逻辑是第一个consumer。调用 queue 的 take() 方法,然后把返回值写入操控台。
16 public void thread1() throws InterruptedException {
17     String ret=queue.take();
18     System.out.printf("Thread 1: %s\n",ret);
19 }
20  
21 //5.   实现 thread2() 方法。它将实现的逻辑是第二个consumer。首先,使用 waitForTick() 方法,一直等到第一个线程在 take() 方法中进入休眠。然后,调用queue的 take() 方法,并把返回值写入操控台。
22 public void thread2() throws InterruptedException {
23     waitForTick(1);
24     String ret=queue.take();
25     System.out.printf("Thread 2: %s\n",ret);
26 }
27  
28 //6.   实现 thread3() 方法。它将实现的逻辑是producer。 首先,使用 waitForTick() 两次一直等到2个consumers被阻塞。然后,调用 queue的 put() 方法插入2个String 到queue中。
29 public void thread3() {
30     waitForTick(1);
31     waitForTick(2);
32     queue.put("Event 1");
33     queue.put("Event 2");
34     System.out.printf("Thread 3: Inserted two elements\n");
35 }
36  
37 //7.    最后,实现 finish() 方法。写信息到操控台表明测试结束执行。使用assertEquals() 方法检查2个事件已经被consumed(queue的大小为0)。
38 public void finish() {
39     super.finish();
40     System.out.printf("Test: End\n");
41     assertEquals(true, queue.size()==0);
42     System.out.printf("Test: Result: The queue is empty\n");
43 }
44  
45 //8.   创建例子的主类通过创建一个类,名为 Main 并添加 main()方法。
46 public class Main {
47  
48 public static void main(String[] args) throws Throwable {
49  
50 //9.   创建 ProducerConsumerTest 对象,名为 test。
51 ProducerConsumerTest test=new ProducerConsumerTest();
52  
53 //10. 使用 TestFramework 类的 runOnce()方法来执行测试。
54 System.out.printf("Main: Starting the test\n");
55 TestFramework.runOnce(test);
56 System.out.printf("Main: The test has finished\n");

它是如何工作的…

在这个指南,你使用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分析并发代码 

目录
相关文章
|
2天前
|
JSON 前端开发 JavaScript
快照测试在前端自动化测试中的应用
在前端自动化测试中,快照测试常用于检验组件渲染与布局。
|
4天前
|
敏捷开发 JavaScript 测试技术
深入理解与应用软件测试中的Mock技术
【5月更文挑战第5天】 在现代软件开发过程中,单元测试作为保障代码质量的重要环节,其独立性和可靠性至关重要。Mock技术应运而生,为开发者提供了一种在隔离环境下模拟外部依赖的方法。本文将深入探讨Mock技术的概念、实现方式及其在软件测试中的应用,旨在帮助读者更好地理解和运用这一强大的测试工具,以提升测试效率和软件质量。
|
4天前
|
测试技术
使用CLion创建Cmake项目,使用GoogleTest和GoogleMock对代码进行测试
使用CLion创建Cmake项目,使用GoogleTest和GoogleMock对代码进行测试
17 3
|
7天前
|
安全 IDE Java
Java串口通信技术探究2:RXTX库单例测试及应用
Java串口通信技术探究2:RXTX库单例测试及应用
25 4
|
7天前
|
数据采集 机器学习/深度学习 人工智能
探索AI在软件测试中的应用与挑战
【5月更文挑战第2天】本文将探讨人工智能(AI)在软件测试领域的应用及其带来的挑战。我们将详细讨论AI如何改变软件测试的方式,包括自动化测试、预测性测试、智能化缺陷检测等。同时,我们也将探讨AI在软件测试中面临的挑战,如数据质量问题、模型的可解释性、以及对现有测试流程的影响等。
|
8天前
|
Java 测试技术 开发者
深入理解与应用单元测试:软件质量的守护者
【4月更文挑战第30天】 在现代软件开发过程中,单元测试作为保障代码健康的重要环节,其地位日益凸显。本文将探讨单元测试的核心概念、实施单元测试的重要性以及如何高效地设计并执行单元测试。通过实例分析,我们将揭示单元测试在确保软件产品质量和加速开发周期中的关键作用。
|
18天前
|
网络协议 安全 测试技术
性能工具之emqtt-bench BenchMark 测试示例
【4月更文挑战第19天】在前面两篇文章中介绍了emqtt-bench工具和MQTT的入门压测,本文示例 emqtt_bench 对 MQTT Broker 做 Beachmark 测试,让大家对 MQTT消息中间 BenchMark 测试有个整体了解,方便平常在压测工作查阅。
109 7
性能工具之emqtt-bench BenchMark 测试示例
|
1月前
|
测试技术 C语言
网站压力测试工具Siege图文详解
网站压力测试工具Siege图文详解
29 0
|
12天前
|
机器学习/深度学习 数据采集 人工智能
【专栏】利用AI辅助工具提高软件测试效率与准确性
【4月更文挑战第27天】本文探讨了AI在软件测试中的应用,如自动执行测试用例、识别缺陷和优化测试设计。AI辅助工具利用机器学习、自然语言处理和图像识别提高效率,但面临数据质量、模型解释性、维护更新及安全性挑战。未来,AI将更注重用户体验,提升透明度,并在保护隐私的同时,通过联邦学习等技术共享知识。AI在软件测试领域的前景广阔,但需解决现有挑战。
|
3天前
|
测试技术 API
探索软件测试中的自动化工具与挑战
本文探讨了软件测试领域中自动化工具的应用与挑战。通过分析目前主流的自动化测试工具,探讨了其在提高测试效率、减少人工成本、增强测试覆盖率等方面的优势。然而,自动化测试也面临着诸如脆弱性、维护成本高等挑战。最后,提出了一些应对挑战的建议,以期为软件测试领域的自动化工作提供一些启示。
11 1

热门文章

最新文章