我正在尝试如何与maven surefire和testng并行运行测试。但是,配置似乎不是很简单,我无法使其工作。以下是我的虚拟测试。
@Log4j
public class DummyTest {
@Test
public void test_1() throws InterruptedException {
log.info("test 1 started");
Thread.sleep( 3000 );
assertTrue(true);
log.info("test 1 ended");
}
@Test
public void test_2() throws InterruptedException {
log.info("test 2 started");
Thread.sleep( 5000 );
assertTrue(true);
log.info("test 2 ended");
}
}
//------------------------------------
public class Dummy2Test {
@Test
public void test_1() throws InterruptedException {
log.info("test 1 started");
Thread.sleep( 3000 );
assertTrue(true);
log.info("test 1 ended");
}
@Test
public void test_2() throws InterruptedException {
log.info("test 2 started");
Thread.sleep( 5000 );
assertTrue(true);
log.info("test 2 ended");
}
}
这是我的万无一失的配置:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.17</version>
<configuration>
<parallel>all</parallel>
<threadCount>10</threadCount>
</configuration>
</plugin>
测试基本上是按顺序运行的。这是日志作为证据:
-------------------------------------------------------
T E S T S
-------------------------------------------------------
Running com.tns.ct.tests.Dummy2Test
Configuring TestNG with: TestNG652Configurator
2014-10-14 18:51:18 INFO com.tns.ct.tests.Dummy2Test.test_1():12 - test 1 started
2014-10-14 18:51:21 INFO com.tns.ct.tests.Dummy2Test.test_1():15 - test 1 ended
2014-10-14 18:51:21 INFO com.tns.ct.tests.Dummy2Test.test_2():20 - test 2 started
2014-10-14 18:51:26 INFO com.tns.ct.tests.Dummy2Test.test_2():23 - test 2 ended
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 8.316 sec - in com.tns.ct.tests.Dummy2Test
Running com.tns.ct.tests.DummyTest
Configuring TestNG with: TestNG652Configurator
2014-10-14 18:51:27 INFO com.tns.ct.tests.DummyTest.test_1():12 - test 1 started
2014-10-14 18:51:30 INFO com.tns.ct.tests.DummyTest.test_1():15 - test 1 ended
2014-10-14 18:51:30 INFO com.tns.ct.tests.DummyTest.test_2():20 - test 2 started
2014-10-14 18:51:35 INFO com.tns.ct.tests.DummyTest.test_2():23 - test 2 ended
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 8.318 sec - in com.tns.ct.tests.DummyTest
Results :
Tests run: 4, Failures: 0, Errors: 0, Skipped: 0
我的目的是并行运行所有测试(直到方法级别)。那么,我该如何实现呢?
答案 0 :(得分:0)
我不认为所有这些都是TestNG的选择。如果您希望所有测试用例并行执行,请尝试使用<parallel>methods<\paralell>
。