测试是系统开发中的重中之重,而多线程并发的测试则是其中的难点。
并发测试目的
一个功能的实现可以用串行方式也可以用并发方式,并发程序可以用编写串行程序是采用的设计原则和设计模式,同样在串行程序的测试方法也可以用到并发程序的测试中,但是并发程序由于共享数据,所以存在一定程度的不确定性,一些潜在错误的发生并不具有确定下,而是随机发生的。
并发测试主要分两个方向:安全性测试与活跃性测试。其中安全性测试是为了保证程序不发生任务错误的行为;比如集合的size与真实存储的元素数量是否一致。
活跃性测试则是希望程序能够良好的运行,更多考量是在于性能方面,而在性能测试的衡量标准主要有以下3个方面:
吞吐量:一组并发任务中已完成任务所占的比例;
响应性:指请求从发出到完成之间的时间(延迟);
可伸缩性:在增加资源比如CPU情况下,吞吐量提升情况;
并发测试手段
并发程序的测试与串行程序测试需要测试的点会更多,首先是与串行程序一样要有基本的测试,保证程序的基本正确性,主要是保证不变性条件和后验条件,比如前面提到的集合的size与真实存储的数量是否相同这类不变性条件。
在保存程序的基本正确性后就要保证并发方面的问题,首先是阻塞操作的测试,对于共享数据的获取是否有正常的阻塞,还有比如生产者-消费者模式当队列中没有元素时&#