1

我有以下回应:

[
    {
        "id": 53,
        "fileUri": "abc",
        "filename": "abc.jpg",
        "fileSizeBytes": 578466,
        "createdDate": "2018-10-15",
        "updatedDate": "2018-10-15"
    },
    {
        "id": 54,
        "fileUri": "xyz",
        "filename": "xyz.pdf",
        "fileSizeBytes": 88170994,
        "createdDate": "2018-10-15",
        "updatedDate": "2018-10-15"
    }
]

我正在尝试将id值与 JUnit 中的对象匹配,如下所示:

RestAssured.given() //
                .expect() //
                .statusCode(HttpStatus.SC_OK) //
                .when() //
                .get(String.format("%s/%s/file", URL_BASE, id)) //
                .then() //
                .log().all() //
                .body("", hasSize(2)) //
                .body("id", hasItems(file1.getId(), file2.getId()));

但是当匹配发生时,它会尝试将 a 匹配int到 a long。相反,我得到了这个输出:

java.lang.AssertionError: 1 expectation failed.
JSON path id doesn't match.
Expected: (a collection containing <53L> and a collection containing <54L>)
  Actual: [53, 54]

如何告诉 Rest Assured 该值确实很长,即使它可能短到足以放入 int 中?我可以将文件id转换为一个int并且它可以工作,但这似乎很草率。

4

1 回答 1

0

问题是当从 json 转换为 java 类型时,选择 int 类型,一种解决方案是比较 int 值。代替

.body("id", hasItems(file1.getId(), file2.getId()));

利用

.body("id", hasItems(new Long(file1.getId()).intValue(), new Long(file2.getId()).intValue()));
于 2019-04-26T08:43:46.463 回答