我有一个Java服务,现在将以批处理模式执行.多线程支持添加到服务中,因此对于每个批处理请求,线程池将专用于执行批处理.问题是我该如何测试?我有功能测试通过服务的线程版本,但不知何故,我觉得必须有一个习惯用于测试这个.
真的没有"好"的方法来做到这一点.我可以建议的最好的事情是TestNG,它允许您注释您的测试方法并使它们同时在n个线程中执行.例如:
@Test(invocationCount=10, threadPool=10) public void testSomethingConcurrently() { ... }
我的TestNG知识充其量是生锈的,但AFAIK应该同时调用该testSomethingConcurrently
方法10次.这是对您的代码运行多线程测试的一种很好的声明性方法.
您当然可以在JUnit中通过在循环中手动生成线程来执行类似的操作,但这非常难看且难以使用.对于我正在进行的项目,我不得不这样做一次; 这些测试是一个噩梦,因为他们的失败并不总是可重复的.
由于其不确定性,并发性测试很难并且容易受挫.这就是为什么现在有这么大的推动使用更好的并发抽象的原因之一,这些抽象更容易"推理"并说服自己的正确性.