我有一个下载 xlsx 文件的端点。在我的测试中,我需要检查文件的内容(不是将文件与另一个文件进行比较,而是读取内容并检查)。我正在使用空手道框架进行测试,并尝试使用 apache POI 来处理 Excel 工作表。但是,调用下载端点时我从空手道得到的响应是一个字符串。为了使用 POI 创建 Excel 文件,我需要一个 InputStream 或实际文件的路径。我已经尝试过转换,但不起作用。
我想我在这里缺少一些联系,或者转换可能很糟糕,我对空手道和整个事情都是新手。
我感谢任何帮助,谢谢!
Given url baseUrl
Given path downloadURI
When method GET
Then status 200
And match header Content-disposition contains 'attachment'
And match header Content-disposition contains 'example.xlsx'
And match header Content-Type == 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
* def value= FileChecker.createExcelFile(response)
* print value
以及Java代码:
public static String createExcelFile(String excel) throws IOException, InvalidFormatException {
InputStream stream = IOUtils.toInputStream(excel, Charset.forName("UTF-8"));
Workbook workbook = WorkbookFactory.create(stream);
return ("Workbook has " + workbook.getNumberOfSheets() + " Sheets : ");
}
运行场景时,我收到以下错误:javascript evaluation failed: FileChecker.createExcelFile(response), java.io.IOException: Failed to read zip entry source
在 Postman 中测试相同的端点时,我得到了一个有效的 Excel 工作表。
在空手道 0.9.X 中,您有responseBytes https://github.com/intuit/karate#responsebytes变量将是原始字节,这可能是您所需要的。
* def value = FileChecker.createExcelFile(responseBytes)
您可以将方法签名更改为:
public static String createExcelFile(byte[] excel) {}
您应该能够轻松地将字节数组转换为InputStream
并从那里拿走它。
附:只是说它“在 Postman 中工作”是没有帮助的:P
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)