- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想了解为什么会发生以下情况?问题:如果我使用 Pact Junit 规则,Junit 测试会失败并出现 HttpConnect 异常。但是,如果我直接使用 Pact DSL,则会生成相同的测试通过并生成 pact 文件。有人可以告诉我为什么以及如何使用 Pact Junit 规则吗?
使用 Pact Junit 规则的代码:(失败并出现 HttpHostConnectException)
@Rule
public PactProviderRule rule = new PactProviderRule("DrivePOC", PactSpecVersion.V2, this);
/*Setting up what your expectations are*/
@Pact(provider = "P1",consumer = "C1")
public PactFragment createFragment(PactDslWithProvider builder)
{
PactFragment pactFragment = ConsumerPactBuilder
.consumer("C1")
.hasPactWith("P1")
.uponReceiving("load Files Data")
.path("/loadData")
.method("POST")
.body("{\"givefileId\": \"abc\"}")
.willRespondWith()
.status(200)
.body("{\"fileId\": \"abcfileId1234\"}")
.toFragment();
return pactFragment;
}
/*Test similar to Junit, verifies if the test are ok and the responses are as per expectations set in the createFragment*/
@Test
@PactVerification(value = "P1")
public void runTest() throws IOException
{
MockProviderConfig config = MockProviderConfig.createDefault();
Map expectedResponse = new HashMap();
expectedResponse.put("fileId", "abcfileId1234");
try {
Assert.assertEquals(new ProviderClient(config.url()).helloToDrive("{\"givefileId\": \"abc\"}"),
expectedResponse);
} catch (IOException e) {
throw new RuntimeException(e);
}
}
直接使用Pact DSL进行代码(此Junit通过并成功生成Pact文件)
@Test
public void testPact() {
PactFragment pactFragment = ConsumerPactBuilder
.consumer("C1")
.hasPactWith("P1")
.uponReceiving("load Files Data")
.path("/loadData")
.method("POST")
.body("{\"givefileId\": \"abc\"}")
.willRespondWith()
.status(200)
.body("{\"fileId\": \"abcfileId1234\"}")
.toFragment();
MockProviderConfig config = MockProviderConfig.createDefault();
VerificationResult result = pactFragment.runConsumer(config, new TestRun() {
public void run(MockProviderConfig config) throws Throwable {
Map expectedResponse = new HashMap();
expectedResponse.put("fileId", "abcfileId1234");
try {
Assert.assertEquals(new ProviderClient(config.url()).helloToHueDrive("{\"givefileId\": \"abc\"}"),
expectedResponse);
} catch (IOException e) {
throw new RuntimeException(e);
}
}
});
if (result instanceof PactError) {
throw new RuntimeException(((PactError)result).error());
}
Assert.assertEquals(ConsumerPactTest.PACT_VERIFIED, result);
}
最佳答案
将 Junit 版本从 4.8 更改为 4.9 后,我可以使注释正常工作。
关于java - 使用 Pact JUnit 规则还是直接使用 Pact DSL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44108752/
我看到 Pact 可以使用 Microsoft 的 Z3 定理证明器自动检查智能合约的某些属性。智能合约是否有相关属性无法自动验证?如果有,您是否希望逐案验证它们,或者是否正在开展工作以扩展自动检查器
我们正在尝试为 Scala 的 PACT-provider 实现一种混合方法。 我们正在寻找使用 PACT-JVM(Java 变体)的 Pact-JVM 提供方实现的简单示例 我们在 Scala 中有
我想了解为什么会发生以下情况?问题:如果我使用 Pact Junit 规则,Junit 测试会失败并出现 HttpConnect 异常。但是,如果我直接使用 Pact DSL,则会生成相同的测试通过并
我正在使用 JS pact 库 (github.com/pact-foundation/pact-js) 来测试聚合物应用程序。我需要在应用程序中测试ajax代码,我想在浏览器中测试它。 我现在在我的
我正在尝试使用 pact-JVM 在我们的 2 个服务之间生成协议(protocol)。但是当我尝试运行 Java 类时,出现了这个异常。 1) 我怀疑 Pact 本体有问题,对吗? PactDslW
下面的 Json 包含三个我不知道如何在基于 lambda 的 Pact DSL 中建模的东西(而且我无法通过阅读 https://github.com/DiUS/pact-jvm/tree/mast
下面的 Json 包含三个我不知道如何在基于 lambda 的 Pact DSL 中建模的东西(而且我无法通过阅读 https://github.com/DiUS/pact-jvm/tree/mast
我正在尝试使用 pact 来验证 spring boot 微服务。我已经从消费者生成了协议(protocol)文件,并使用协议(protocol)代理在提供者端对其进行了验证。 我有另一个用例,在根据
我正在尝试编写一个契约消费者测试来匹配以下响应。 [ { "accountId" : 1, "permissions" : [ {
我正在为上传文件的 put 请求设置测试。我的 pact 文件中的请求正文由单个字符串组成,其中包含每次测试运行都会更改的 mime 边界。我试图为请求正文字符串定义正则表达式匹配规则,但它不匹配。
我正在尝试在 Pact 中创建一个基本的 hello world 智能合约。在能够完成契约(Contract)的同时,我收到了警告。它并没有阻止我的契约(Contract)运行,但确实让我担心。 在未
我有一个服务将使用 json blob 响应请求,如下所示: { "field1": 1, "field2": "2", "array": [1,2,3] } 我知道我可以使用 EachL
我有一种情况,我用同一个端点编写了 2 个交互。即使我在 with_request 选项中传递了不同的查询,我也遇到了以下错误 - Error: Multiple interaction found
我正在使用 Pact 并创建消费者测试。我对特定请求的响应正文如下所示: PactDslJsonBody responseBody = new PactDslJsonBody()
我正在查看Python implementation协议(protocol)并试图建立提供国。似乎是说,做到这一点的方法是让提供者在服务中内置一个端点,调用该端点将提供者置于正确的状态。问题是我找不到
大约半年前,我的组织开始使用 Pact 在用 Java 编写的 REST 服务/微服务之间创建/验证契约(Contract)。 我们很难决定提供者测试的适当范围或掌握应该是什么,并且希望从其他契约用户
我对是否应该考虑某种类型的测试功能或契约(Contract)有疑问。 假设我有一个像/getToolType 这样的 API,它接受一个 {object""myObject"} 作为输入,并以 {ty
我不明白 @PactVerification 中 assert 的用法.对我来说,它更像是一种复杂的表达方式 1 == 1 .例如: import static org.assertj.core.ap
我是 PACT 的新手。我的应用程序是一个 Spring 启动应用程序。消费者在 PACT 代理中创建了协议(protocol)。现在我正在尝试从提供者端运行测试,并且我正在使用 gradle 插件来
我使用@pact-foundation/pact@latest (为了快速部署我的案例,有一个简单的 jest 示例) 使用此代码: 我已经生成了这个 PACT 文件: 它是根据规范3生成的(这些是设
我是一名优秀的程序员,十分优秀!