Appium 测试报告--步骤级报告
每执行一轮我们最后都需要看对应的测试结果,以此来判断应用是否存在问题,
因为没有采用TestNG 中的断言机制,所以报告没法套用TestNg 的方式展示,需要自定义方法来记录结果
第一步先要对测试用例的每一步记录测试结果
这里需要考虑新建的Sheet 没有任何标题时程序要先自行创建标题
当有数据时我们在后面一行追加记录
整个方法对应的完整代码是
public static void Record_TestResult() {
try {
//获取文件流
FileInputStream ExcelFile1 = new FileInputStream(constant.ReportPath);
System.out.println("报告文件"+constant.ReportPath);
//创建工作本
XSSFWorkbook ExcelWBook1 = new XSSFWorkbook(ExcelFile1);
//获取Sheet 名称
XSSFSheet ReportSheet=ExcelWBook1.getSheet("Report");
//获取测试报告的Sheet 页
XSSFRow Row;
//此处先判断下Report 的Sheet 是否有获取到
if (ReportSheet==null) {
//如果没有获取到时我们就新创建一个Sheet
ReportSheet=ExcelWBook1.createSheet("Report");
//Sheet 创那建之后再新建一个行号
XSSFRow Row2=ReportSheet.createRow(0);
//对第一行新加标题
Row2.createCell(0).setCellValue("测试用例ID");
Row2.createCell(1).setCellValue("用例描述");
Row2.createCell(2).setCellValue("测试步骤");
Row2.createCell(3).setCellValue("测试对象中文名称");
Row2.createCell(4).setCellValue("定位方式");
Row2.createCell(5).setCellValue("测试对象实体");
Row2.createCell(6).setCellValue("操作方法");
Row2.createCell(7).setCellValue("测试数据");
Row2.createCell(8).setCellValue("验证数据");
Row2.createCell(9).setCellValue("测试结际结果");
}
//获取最大行号
int LastNum2=ReportSheet.getLastRowNum();
//在最大行号后加一行用来写新的记录
Row=ReportSheet.createRow(LastNum2+1);
//获取行号信息之后将结果写入到对应的列
Row.createCell(constant.iCaseID).setCellValue(constant.sCaseID);
Row.createCell(constant.iReport_CaseDesc).setCellValue(constant.sCaseDesc);
Row.createCell(constant.iReport_CaseStep).setCellValue(constant.sCaseStep);
Row.createCell(constant.iReport_ObjectName).setCellValue(constant.sObjectName);
Row.createCell(constant.iReport_FindType).setCellValue(constant.sFindType);
Row.createCell(constant.iReport_Object).setCellValue(constant.sObject);
Row.createCell(constant.iReport_OptionMethod).setCellValue(constant.sOptionMethod);
Row.createCell(constant.iReport_TestData).setCellValue(constant.sTestData);
Row.createCell(constant.iReport_CheckVaue).setCellValue(constant.sCheckVaue);
Row.createCell(constant.iReport_TestResult).setCellValue(constant.sTestResult);
//创建文件输出流
FileOutputStream fileOut = new FileOutputStream(constant.ReportPath);
// 写入文件输出流到Excel
ExcelWBook1.write(fileOut);
//关闭文件流
fileOut.close();
//释放Excel
ExcelFile1.close();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
执行结果展示