我正在使用wiremock进行REST API测试,我遇到了以下问题。 我创建了以下2个json请求。
请求1:
{
"request": {
"method": "GET",
"urlPattern": "/api/v1/user/2158634832/ishop.*",
"headers": {
"Accept": {
"contains": "application/json"
},
"X-RequestId": {
"matches": ".*"
},
"X-SecurityToken": {
"matches": "valid_secure_token"
}
}
},
"response": {
"status": 200,
"jsonBody": {
"user": {
"ID": "5cc1b131-8858-4870-a7ce-fd37aa805ebf",
"info": [
{
"kid": "2f0ad36a-9f23-427c-9a15-16d240385b87",
"cid": 10962435,
"pid": "V",
"contactid": 11812026,
"created": "2017-04-26T00:08:25.926",
"lastModified": "2017-04-27T00:01:45.047",
}
]
}
},
"headers": {
"Content-Type": "application/json"
}
}
}
我对上述电线摇滚的请求看起来像这样
**/api/v1/user/2158634832/ishop?ID=9879cfde-e353-4722-a91e-f22d29d8195c**
请求2:
{
"request": {
"method": "GET",
"urlPattern": "/api/v1/user/2158634832/ishop/status.*",
"headers": {
"Accept": {
"contains": "application/json"
},
"X-RequestId": {
"matches": ".*"
},
"X-SecurityToken": {
"matches": "valid_secure_token"
}
}
},
"response": {
"status": 200,
"jsonBody": {
"userstatus": {
"id": "5cc1b131-8858-4870-a7ce-fd37aa805ebf",
"type": "ishop",
"status" : "active",
"lastModifiedTime": "2017-04-27T00:01:45.047",
"allowedChange": "true"
}
},
"headers": {
"Content-Type": "application/json"
}
}
}
我对上述内容的请求看起来像这样
/api/v1/user/2158634832/ishop/status?ID=9879cfde-e353-4722-a91e-f22d29d8195c
这里的问题是,有时由于请求1和请求2的类似URL模式,有时会发生什么
当我提交请求1的请求时,我收到了请求2的响应。
任何人都可以建议我一个解决方法,我该如何解决这个问题?我希望与match和urlPattern有关,不知何故,我可以在第一个请求中发出状态调用,但我不知道如何。
有什么建议吗?
答案 0 :(得分:3)
由于您的一个请求网址包含另一个,因此匹配较短网址的正则表达式也会匹配较长的一个。我怀疑这就是为什么当你喜欢较长的一个时,较短的一个匹配。
我建议您更详细地说明您的网址匹配,例如
第一个存根中的 "urlPath": "/api/v1/user/2158634832/ishop"
和
"urlPath": "/api/v1/user/2158634832/ishop/status"
在第二个
尽管您没有指定ID查询参数,但仍会匹配。 WireMock将没有匹配参数的额外标题或查询参数视为“不关心,无论如何匹配”。
答案 1 :(得分:1)
更好的解决方案是使用存根优先级:
http://wiremock.org/docs/stubbing/#stub-priority
这样,您仍然可以使用urlPatten
{
"priority" : 2,
"request": {
"method": "GET",
"urlPattern": "/api/v1/user/2158634832/ishop.*",
"headers": {
...
和:
{
"priority" : 1,
"request": {
"method": "GET",
"urlPattern": "/api/v1/user/2158634832/ishop/status.*",
"headers": {
...
答案 2 :(得分:0)
我用以下方式修复它
请求1已从
更改"urlPattern": "/api/v1/user/2158634832/ishop.*",
到
"urlPath": "/api/v1/user/2158634832/ishop",
请求2已从
更改"urlPattern": "/api/v1/user/2158634832/ishop/status.*",
到
"urlPath": "/api/v1/user/2158634832/ishop/status",