我有一个数组的 Gatling JSON 对象。该对象包含错误消息,例如
"error": [
{
"errorCode": "111",
"errorMessage": "very dynamic error :- at [Source: java.io.PushbackInputStream@5d0edb12; line: 6, column: 6]; nested exception is com.fasterxml.jackson.core.JsonParseException: "
},
{
"errorCode": null,
"errorMessage": "Fixed Error Message"
},
{
"errorCode": "112",
"errorMessage": "Again some error message"
}
]
我正在检查 jsonpath 作为
($.error[1].errorMessage).is("Fixed Error Message")
但是,不同的 API 有不同的错误对象,固定的 errorMessage 可以放在数组中的任何索引位置。
如何动态检查 jsonArray 中是否存在固定的 errorMessage 而不用担心 arrayIndex ?
我可以做一个独立匹配字符串与数组元素而不提及数组索引的查询,如下所示?
($.error[*].errorMessage).is("Fixed Error Message")
最佳答案
您可以使用以下内容过滤数组:
JsonPath.query("$.error[?(@.errorMessage=='Fixed Error Message')]", json)
编辑 1:
这将是检查是否确实找到消息的首选:
jsonPath("$.error[?(@.errorMessage=='Fixed Error Message')]").exists
如果您想做 .is() 检查,您可以尝试以下操作(不是很好):
jsonPath("$.error[?(@.errorMessage=='Fixed Error Message')].errorMessage").is("Fixed Error Message")
关于arrays - jsonpath 在与数组索引无关的 jsonarray 中查找字符串值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39584680/