@DataProvider (name=getData)
public static Object[][] getData(){
Excelreader excel = new Excelreader("C:\\WorkspaceExcel\\Datasource.xlsx"); private static
String sheetName="SmokeTest"; // Test Data stored in a a table with
columns and rows. Ex. UserNmae and password are the columns and data
for them in rows private static String tableName="CreatePolicy";
// Some logic to read the data table store the data in a 2
dimentional array.
// Some logic by which I store the columns as Keys and data for them
as values in a HASHTABLE Return the hashtable
}
@Test (dataProvider="getData")
public void testData(Hashtable<String, String> data){
/* Logic to read an .xlsx file which has Snenario name, TestCase Name and its corespnding runflag. If the runflag is true i need to read the scenario name and testcase name from the .xlsx file. */
/* I need some logic to pass the ScenarioName (equivalent to Sheetname in DP) and TestCase Name (equivalent to datatable name in DP) which i am getting by reading the excelfile to DataProvider, so i can get the data which i need to execute the test case */
/*I am doing the above as part of Hybridframework, where i have Scenario, TC, Test step details in one excel sheet and data for each testcase in one more sheet */
}
Мой вопрос: мне нужна некоторая логика, поэтому, когда @Test выполняется, я должен динамически передавать данные File Path, SheetName, TableName, чтобы можно было использовать один и тот же поставщик данных, и это даст мне другой набор данных для работы.
Примечание. Поставщик данных вернет данные, указанные в Excel, в виде хэш-таблицы в табличном формате с именем таблицы. Поэтому, если путь к рабочему листу, имя листа и имя таблицы передаются поставщику данных, мой DP будет читать эту таблицу и возвращать всю таблицу данных в виде хэш-таблицы.