我正在尝试从au.com.dius:pact-jvm-consumer-junit_2.12:3.5.12
向au.com.dius:pact-jvm-consumer-junit_2.11:3.2.13
更新许多服务,但似乎新的消费者版本正在生成旧提供程序版本(au.com.dius:pact-jvm-provider-junit_2.11:3.2.13
)无法处理的协议。 / p>
旧协议有一个哈希映射,在根目录下添加匹配规则,如下所示
{
"consumer": {
"name": "consumer-amqp"
},
"provider": {
"name": "prodvider-amqp"
},
"messages": [
{
"description": "amqp contract",
"contents": {
"body": {
"guidProperty": "795ecfd5-a3a5-430f-a0cd-1569df61bff6"
}
},
"matchingRules": {
"$.body.body.guidProperty": {
"regex": "[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}"
}
}
}
],
"metadata": {
"pact-specification": {
"version": "3.0.0"
},
"pact-jvm": {
"version": "3.2.13"
}
}
}
新的消费者在匹配器周围添加和包装body
。以下是使用新消费者版本生成的相同协议的示例
{
"consumer": {
"name": "consumer-amqp"
},
"provider": {
"name": "prodiver-amqp"
},
"messages": [
{
"description": "contract",
"contents": {
"body": {
"guidProperty": "e2490de5-5bd3-43d5-b7c4-526e33f71304"
}
},
"matchingRules": {
"body": {
"$.guidProperty": {
"matchers": [
{
"match": "regex",
"regex": "[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}"
}
],
"combine": "AND"
}
}
}
}
],
"metadata": {
"pact-specification": {
"version": "3.0.0"
},
"pact-jvm": {
"version": "3.5.12"
}
}
}
由于该更改,提供程序无法使用以下错误解析匹配规则:
body
^
10:21:24.526 [main] DEBUG au.com.dius.pact.matchers.JsonBodyMatcher - compareValues: No matcher defined for path List($, body, body, guidProperty), using equality
10:21:24.527 [main] WARN au.com.dius.pact.matchers.Matchers$ - Path expression body is invalid, ignoring: [1.1] failure: `$' expected but `b' found
java.lang.AssertionError:
comparison
{$.body.body.guidProperty=Expected 'e2490de5-5bd3-43d5-b7c4-526e33f71304' but received 'aff876f5-5014-937c-6855-c099f9857437'
查看v3 spec新消息似乎有效,旧提供程序库(v3.2.13)是否不支持它?我查看了代码并找到了这个{ {3}}在我看来引入了变化。
从我的测试中,新的提供程序库(3.5.12)可以处理旧格式和新格式,但如果新的提供程序和旧的使用者库都存在于类路径中,则http合同测试会因运行时错误而失败。
问题:
1)有没有办法强迫新消费者以旧方式创建契约,并且符合规范吗?
2)有没有办法将提供程序更新到新版本,并且路径中仍然有旧的使用者库而不会出现故障?
答案 0 :(得分:0)
正如J_A_X所指出的,看起来你引用的提交修复了一个错误,即应该是版本3的协议不完全符合版本3(它们使用旧的匹配器格式)
1)有没有办法强迫新消费者以旧方式创建契约,并且符合规范吗?
是的,是的。您应该能够通过将系统属性pact.provider.version
设置为2
来解决此问题 - 然后旧版本和新版本都能够读取生成的协议。
2)有没有办法将提供程序更新到新版本,并且路径中仍然有旧的使用者库而不会出现故障?
是的,只要您要求旧的消费者版本生成版本2
契约(但理想情况下,为什么不将两者同时更新到同一版本?)