- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下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/
过去 7-8 个月以来,我们一直在使用 Firebase。 这是一个非常棒的工具,感谢您的努力。 这里我有一个问题,是否有一种方法可以在不实际写入数据库的情况下修改数据。 因为大多数情况下,当我们调试
我正在尝试创建一个 W2V 模型,然后生成用于我的模型的训练和测试数据。我的问题是,在使用训练数据创建 W2V 模型后,如何生成测试数据。 最佳答案 Word2Vec 被认为是一种“无监督”算法,因此
from scipy.cluster.hierarchy import dendrogram, linkage,fcluster import numpy as np import matplotli
我有一个组件,我想在单元测试中检查选择器 @Component({ selector: 'my-component', )} 我想这样测试 describe('My Component',
想知道哪个好。 我必须将一些 JUnit 测试数据保存在不同的文件中。让我们将其称为 TestingData.java。我想到了两种方法。 第一种方式 TestingData.java public
这个问题在这里已经有了答案: 关闭 14 年前。 我想对我的一些 SQL 查询进行压力测试,找出糟糕的查询计划和瓶颈。我计划用随机测试数据填充一些表。 是否有工具或一组脚本可用于此目的,最好是用于
我正在尝试预测以下内容: list( [ 收盘价(当日) - 开盘价(当日) ] ) 使用以下内容作为输入: list( [ 开盘价(当天) - 收盘价(昨天) ] ) 但是,我的 test_pred
我已经编写了一个函数库,可以根据 ISO/IEC 7813 从卡片(信用卡、ID 等)上的磁条解析轨道 1 和轨道 2 数据。我希望针对一些有效的(但显然不是)严格测试这个库真正的信用卡')跟踪 2
我的问题如下。我有 6 个数据集(从不同的日子收集),我想为其构建决策树分类器。我需要找到最佳的树深度参数以避免过度拟合并对新数据进行良好的预测。 我的第一次尝试是将每个数据集按 50%/25%/25
我想在我的仪器测试中使用大文件(> 2 GB 的 zip 存档和视频文件)来测试从 SD 卡/内部存储加载文件。 如何编写这些仪器测试并为它们配备所需的文件?对于其他测试,我只需要非常小的文件,所以我
我在理解 MXNet ImageRecordIter 的工作原理时遇到了一些困难。 Here是我一直在使用的引用 首先,--test-ratio 标志实际上是做什么的?生成lst文件时,我无法分辨哪些
考虑具有成本函数的线性回归模型: 这里有 = 模型的权重 我们添加正则化参数以避免过度拟合数据。正则化项通过根据模型的权重对模型进行惩罚来阻止使用大的权重,转而使用较小的权重。问题是: 为什么保持模型
我们正在为基于 REST 的后端构建 Grails 前端。我们有很多值 (DTO) 编码到 JSON 或从 JSON 编码。 我正在寻找一种方便的方法来构建这些 DTO 的模拟以用于测试目的。我喜欢
我在家里的电脑和笔记本电脑上都在做一个 Python/MongoDB 项目。自然地,文档存储中的模式最好由数据本身表示 - 这就是为什么我想通过 Mercurial 分发我的测试数据以及代码本身。 最
Spring Test 有助于回滚测试方法中对数据库所做的任何更改。这意味着不必在每个测试方法之前花时间删除/重新加载测试数据。 但是,如果您使用 @BeforeClass Junit 注释,则会强制
我试图理解这行代码: msk = np.random.rand(len(df)) 小于 ( 大于或等于 (>=) 0.8。 ~msk 将 True 翻转为 False 并将 False 翻转为 Tr
我已按照说明使用 JMonkey 创建 Gradle 项目,但无法按照教程中所述加载任何 Assets : http://wiki.jmonkeyengine.org/doku.php/jme3:be
我试图理解这行代码: msk = np.random.rand(len(df)) 小于 ( 大于或等于 (>=) 0.8。 ~msk 将 True 翻转为 False 并将 False 翻转为 Tr
我正在尝试使用此处介绍的 Excel 数据阅读器 http://fabiouechi.blogspot.fi/2010/07/excel-data-driven-tests-with-nunit.ht
我想知道是否可以在根 html 元素级别向第 3 方包添加唯一标识符。例如,我通过 NPM 使用包 myDatePicker。 我可以将 ID 标记添加到实际的 html 元素,但嵌套在该元素内部的是
我是一名优秀的程序员,十分优秀!