Selenium: datos basados en Excel
Al diseñar una prueba, la parametrización de las pruebas es inevitable. Usaremos Apache POI - Excel JAR's para lograr lo mismo. Nos ayuda a leer y escribir en Excel.
Descarga JAR
Step 1 - Navega a la URL - https://poi.apache.org/download.html y descargue el formato ZIP.
data:image/s3,"s3://crabby-images/1c551/1c551346bdc1c160990332c396a8c462f25d5aea" alt=""
Step 2 - Haga clic en Mirror Link para descargar los JAR.
data:image/s3,"s3://crabby-images/fd36d/fd36d5f69a1009fbc91acf07205897f3686d2bcf" alt=""
Step 3 - Descomprime el contenido en una carpeta.
data:image/s3,"s3://crabby-images/56ee8/56ee8b2788047bf9b47513556eed2615101b9837" alt=""
Step 4 - Los contenidos descomprimidos se mostrarán como se muestra a continuación.
data:image/s3,"s3://crabby-images/a5fbd/a5fbd430e086f3ddeb4971e36372096664f4a812" alt=""
Step 5 - Ahora cree un nuevo proyecto y agregue todos los 'JAR externos' en la carpeta 'poi-3.10.FINAL'.
data:image/s3,"s3://crabby-images/88699/886994332101ec51d28806a974d25f04fea84d08" alt=""
Step 6 - Ahora agregue todos los 'JAR externos' en la carpeta 'ooxml-lib'.
data:image/s3,"s3://crabby-images/a066c/a066ce453d21feb14b0dcfeedea9d51b47b3c683" alt=""
Step 7 - Ahora agregue todos los 'JAR externos' en la carpeta 'lib'.
data:image/s3,"s3://crabby-images/1a04d/1a04d9a90000f056e68c735a1e41771ba45c046c" alt=""
Step 8 - El JAR agregado se muestra como se muestra a continuación.
data:image/s3,"s3://crabby-images/c4e0e/c4e0eef91235b36c528b7be220fe53c4fdcc5ad3" alt=""
Step 9- El Explorador de paquetes se muestra como se muestra a continuación. Aparte de eso, agregue los JAR relacionados con 'WebDriver'
data:image/s3,"s3://crabby-images/61f34/61f34bb4c76485f4cff18bbf03381250250d9978" alt=""
Parametrización
Para demostración, parametrizaremos la prueba de la calculadora de porcentaje.
Step 1- Parametrizaremos todas las entradas requeridas para la calculadora de porcentaje usando Excel. El Excel diseñado se muestra a continuación.
data:image/s3,"s3://crabby-images/fe09e/fe09e2ecea48a0548963c60abc8ea563272999fa" alt=""
Step 2 - Ejecute todas las funciones de la calculadora de porcentaje para todos los parámetros especificados.
Step 3- Creemos métodos genéricos para acceder al archivo de Excel utilizando los JAR importados. Estos métodos nos ayudan a obtener datos de una celda en particular o establecer datos de una celda en particular, etc.
import java.io.*;
import org.apache.poi.xssf.usermodel.*;
public class ExcelUtils {
private XSSFSheet ExcelWSheet;
private XSSFWorkbook ExcelWBook;
//Constructor to connect to the Excel with sheetname and Path
public Excelutils(String Path, String SheetName) throws Exception {
try {
// Open the Excel file
FileInputStream ExcelFile = new FileInputStream(Path);
// Access the required test data sheet
ExcelWBook = new XSSFWorkbook(ExcelFile);
ExcelWSheet = ExcelWBook.getSheet(SheetName);
} catch (Exception e) {
throw (e);
}
}
//This method is to set the rowcount of the excel.
public int excel_get_rows() throws Exception {
try {
return ExcelWSheet.getPhysicalNumberOfRows();
} catch (Exception e) {
throw (e);
}
}
//This method to get the data and get the value as strings.
public String getCellDataasstring(int RowNum, int ColNum) throws Exception {
try {
String CellData =
ExcelWSheet.getRow(RowNum).getCell(ColNum).getStringCellValue();
System.out.println("The value of CellData " + CellData);
return CellData;
} catch (Exception e) {
return "Errors in Getting Cell Data";
}
}
//This method to get the data and get the value as number.
public double getCellDataasnumber(int RowNum, int ColNum) throws Exception {
try {
double CellData =
ExcelWSheet.getRow(RowNum).getCell(ColNum).getNumericCellValue();
System.out.println("The value of CellData " + CellData);
return CellData;
} catch (Exception e) {
return 000.00;
}
}
}
Step 4 - Ahora agregue un método principal que accederá a los métodos de Excel que hemos desarrollado.
public class xldemo {
public static void main(String[] args) throws Exception {
ExcelUtils dd = new ExcelUtils ("C:\\Book1.xlsx","Sheet1");
System.out.println("The Row count is " + dd.excel_get_rows());
dd.getCellDataasnumber(1, 1);
dd.getCellDataasnumber(1, 2);
dd.getCellDataasnumber(1, 3);
dd.getCellDataasnumber(2, 1);
dd.getCellDataasnumber(2, 2);
dd.getCellDataasnumber(2, 3);
dd.getCellDataasnumber(3, 1);
dd.getCellDataasnumber(3, 2);
dd.getCellDataasnumber(3, 3);
}
}
Salida
Al ejecutar el script, la salida se muestra en la consola como se muestra a continuación.
data:image/s3,"s3://crabby-images/a8c2c/a8c2c9a92846fc3ee9178a0870d5e633a8d68e6c" alt=""