gpt4 book ai didi

java - 具有并行 DataProvider 和随机顺序方法的 TestNG 套件 - 如何实现?

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:29:41 24 4
gpt4 key购买 nike

我有一个包含许多方法的测试类,其中每个方法都受够了并行数据提供程序。我想实现方法执行的混合顺序,但我无法控制数据提供程序线程池的大小——它与测试方法的数量成倍增加。请看例子:

我的测试套件定义:

<suite data-provider-thread-count="5" parallel="methods" preserve-order="false" name="Data provider problem">

我的测试类:

@Test(dataProvider = "dp1")
public void test1(TestData testData) { }

@Test(dataProvider = "dp2")
public void test2(TestData testData) { }

@DataProvider(name = "dp1", parallel = true)
public static Object[][] dp1() {
return createTestData1();
}

@DataProvider(name = "dp2", parallel = true)
public static Object[][] dp2() {
return createTestData2();
}

通过这样的测试套件配置,我实现了 test1()test2() 的混合执行,但数据提供程序线程池不是 5,而是 10!添加新的测试方法会使线程数成倍增加。正如 testNg 文档站点所说:“从 XML 文件运行的并行数据提供程序共享相同的线程池”让我感到惊讶。我只是错误地使用了套件的“并行”属性吗?如果是这样,是否可以通过其他方式实现我的目标(方法执行与数据提供者的混合顺序)?

我也尝试过使用一个数据提供者并在注入(inject)测试方法的基础上创建测试数据,但它也无济于事,见下文:

@Test(dataProvider = "dp")
public void test1(TestData testData) { }

@Test(dataProvider = "dp")
public void test2(TestData testData) { }

@DataProvider(name = "dp", parallel = true)
public static Object[][] dp(Method m) {
if (m.getName().equals("test1")) {
return createTestData1();
}
if (m.getName().equals("test2")) {
return createTestData2();
}
return null;
}

我仍然得到 10 个并行运行的测试执行。将数据提供程序方法移动到单独的类也无济于事。

最佳答案

您是否尝试调整@Test 的参数?

@Test(dataProvider = "dp", threadPoolSize=5)

关于java - 具有并行 DataProvider 和随机顺序方法的 TestNG 套件 - 如何实现?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15265771/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com