gpt4 book ai didi

java - 如何使用来自 excel 文件的不同测试数据集在 testng 中运行多个测试用例?

转载 作者:行者123 更新时间:2023-11-30 10:27:38 29 4
gpt4 key购买 nike

我有以下testng.xml,我的项目包含多个类,每个类都有一个@Test testNG方法及其相关的数据提供者(意味着类I1_DoLoginTest包含一个方法及其数据提供者,类I2_CreateScenarioTest包含一个方法及其数据提供者和类I3_RunSimulationTest包含一种方法及其数据提供者)

请参阅这 3 个类中的每一个的结构与此非常相似:

public class I1 {

@Test(priority = 1,dataProvider="dp_i1_Login")
public void I1_LoginTestCase(){
//Processing data from dataprovider given below
}
@DataProvider(name="dp_i1_Login")
public Object[][] dp_i1_Login() throws Exception{
//return fetching single row data in the form object array from excelsheet
//to be processed by test case
}
}

所以基本上我有一个带有dataprovider的类,它一次提供一行数据,每个单元格将作为参数传递给同一类的@Test方法,然后控制移动到下一个类,即I2_CreateScenarioTest,然后是I3_RunSimulationTest(两者I2_CreateScenarioTest 和 I3_RunSimulationTest 与 I1_LoginTestCase 结构相同)
testng.xml结构如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite guice-stage="DEVELOPMENT" name="Default suite">
<test verbose="2" name="Default test">
<classes>
<class name="com.als.I1"/>
<class name="com.als.I2"/>
<class name="com.als.I3"/>
</classes>
</test> <!-- Default test -->
</suite> <!-- Default suite -->

我的问题是所有这 3 个类的执行顺序,我从不同的 Excel 工作表中选择了 1 行(请在此处引用 Excel 工作表的结构 Excel Sheet)

例如,如果每张表中有 2 行提供数据,则当前执行 testng suit(testng.xml) 就像执行 I1-I1-I2-I2-I3-I3 类,但我想执行类像 I1-I2-I3-I1-I2-I3。

单个方法在其各自的工作表中将其数据提供者的数据执行两次作为 2 行,但我需要将执行控制移动到第二类,即 I2,一旦 I1 类从 Excel 工作表读取和处理第一行,对于 I2 类也是如此, I2 也处理一行并移动到 I3 并且整个执行顺序 (I1-I2-I3) 应该重复它们各自工作表的第二行,每个单独的 excel 工作表中的每一行共同代表一个测试服数据,第二行在每个单独的 excel 表中,共同代表第二个测试服数据。我想将 testng 类执行为 I1-I2-I3-(对于所有行 1)-I1-I2-I3-(对于所有行 2)而不是 I1-I1-I2-I2-I3-I3(行 1-行2,第1行-第2行,第1行-第2行)

最佳答案

您目前无法在 TestNG 中执行此操作。 TestNG 基本上会运行一个具有 @Test 的类测试由数据提供者提供支持并迭代所有数据提供者提供的数据集,然后在你的 <test> 中选择下一个类标签。如果您启用了并行性,这将并行发生,但不是您期望的方式。

但是,您可以尝试执行以下操作:

构建一个由 @Factory 驱动的测试类带注释的构造函数并绑定(bind)此构造函数的 @Factory@DataProvider 的注释带注释的数据提供者。

在你的测试类中,你所有的@Test目前分散在多个类中的方法。

这种安排会导致 TestNG 从您的数据提供者中选择一行数据,将其提供给构造函数以实例化您的测试类,然后,您的 @Test方法基本上可以处理通过构造函数注入(inject)其中的数据。因此,对于数据提供者提供的每一行数据,都会创建一个测试类实例。这是您实现目标的唯一途径。

这是一个示例:

import static org.testng.Assert.assertTrue;

import org.testng.annotations.DataProvider;
import org.testng.annotations.Factory;
import org.testng.annotations.Test;

import java.util.HashMap;
import java.util.Map;

public class SampleTestClass {
private String name;
private int age;
private Map<String, Integer> marks;

@Factory(dataProvider = "getData")
public SampleTestClass(String name, int age, Map<String, Integer> marks) {
this.name = name;
this.age = age;
this.marks = marks;
}

@DataProvider(name = "getData")
public static Object[][] testData() {
return new Object[][]{
{"Amar", 16, marksInSubjects(45, 55, 65)},
{"Akbar", 16, marksInSubjects(55, 65, 75)},
{"Antony", 16, marksInSubjects(35, 45, 55)},
};
}

@Test
public void testName() {
assertTrue(name != null && !name.trim().isEmpty(), "Should have received a valid name");
}

@Test
public void testAge() {
assertTrue(age > 0 && age < 30, "Should have received a valid age.");
}

@Test(dataProvider = "marks")
public void testMarks(String subject, int marks) {
boolean validSubject = subject != null && !"sports".equalsIgnoreCase(subject.trim());
assertTrue(validSubject, "Should have received a valid subject");
assertTrue(marks >= 40, this.name + " didn't pass in " + subject);
}

@DataProvider(name = "marks")
public Object[][] getMarks() {
Object[][] marks = new Object[this.marks.size()][1];
int index = 0;
for (Map.Entry<String, Integer> mark : this.marks.entrySet()) {
marks[index++] = new Object[]{mark.getKey(), mark.getValue()};
}
return marks;
}

private static Map<String, Integer> marksInSubjects(int m1, int m2, int m3) {
Map<String, Integer> marks = new HashMap<>();
marks.put("english", m1);
marks.put("science", m2);
marks.put("mathematics", m3);
return marks;
}
}

关于java - 如何使用来自 excel 文件的不同测试数据集在 testng 中运行多个测试用例?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45239116/

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