【问题标题】:How to get the downloaded xlsx file from the api endpoint in karate?如何从空手道的 api 端点获取下载的 xlsx 文件?
【发布时间】:2023-03-11 05:15:01
【问题描述】:

我有一个下载 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 中测试同一端点时,我得到了一个有效的 excelsheet。

【问题讨论】:

    标签: download xlsx karate


    【解决方案1】:

    从空手道 0.9.X 开始,您有一个 responseBytes 变量,它将是原始字节,这可能是您需要的。

    * def value = FileChecker.createExcelFile(responseBytes)
    

    您可以将方法签名更改为:

    public static String createExcelFile(byte[] excel) {}
    

    您应该能够轻松地将字节数组转换为 InputStream 并从那里获取。

    附:只是说它“在邮递员中工作”没有帮助:P

    【讨论】:

    • 工作,谢谢!我提到 Postman 只是为了避免诸如文件可能不是有效的 xlsx 之类的问题
    【解决方案2】:

    从空手道测试中下载 zip 文件作为二进制咬合数组

    场景:验证并从部署中获取 ADCI Uri 给定 url basicURL + DeployUri +ArtifactUri 和标题{authorization:'#(authToken)',accept:'application/json',tenant:'#(tenantUUId)',Content-Type:'application/zip'} 当方法得到 然后状态 200 而def responsebytes = responseBytes

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2021-09-22
      • 2021-08-19
      • 2021-05-16
      • 2015-08-02
      • 2017-11-10
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多