MVN

au.com.dius : pact-jvm-provider-junit5

Maven & Gradle

Apr 18, 2020
1 usages
1k stars

pact-jvm-provider-junit5 · # Pact Junit 5 Extension ## Overview For writing Pact verification tests with JUnit 5, there is an JUnit 5 Invocation Context Provider that you can use with the `@TestTemplate` annotation. This will generate a test for each interaction found for the pact files for the provider. To use it, add the `@Provider` and one of the pact source annotations to your test class (as per a JUnit 4 test), then add a method annotated with `@TestTemplate` and `@ExtendWith(PactVerificationInvocationContextProvider.class)` that takes a `PactVerificationContext` parameter. You will need to call `verifyInteraction()` on the context parameter in your test template method. For example: ```java @Provider("myAwesomeService") @PactFolder("pacts") public class ContractVerificationTest { @TestTemplate @ExtendWith(PactVerificationInvocationContextProvider.class) void pactVerificationTestTemplate(PactVerificationContext context) { context.verifyInteraction(); } } ``` For details on the provider and pact source annotations, refer to the [Pact junit runner](../pact-jvm-provider-junit/README.md) docs. ## Test target You can set the test target (the object that defines the target of the test, which should point to your provider) on the `PactVerificationContext`, but you need to do this in a before test method (annotated with `@BeforeEach`). There are three different test targets you can use: `HttpTestTarget`, `HttpsTestTarget` and `AmpqTestTarget`. For example: ```java @BeforeEach void before(PactVerificationContext context) { context.setTarget(HttpTestTarget.fromUrl(new URL(myProviderUrl))); // or something like // context.setTarget(new HttpTestTarget("localhost", myProviderPort, "/")); } ``` **Note for Maven users:** If you use Maven to run your tests, you will have to make sure that the Maven Surefire plugin is at least version 2.22.1 uses an isolated classpath. For example, configure it by adding the following to your POM: ```xml <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-surefire-plugin</artifactId> <version>2.22.1</version> <configuration> <useSystemClassLoader>false</useSystemClassLoader> </configuration> </plugin> ``` ## Provider State Methods Provider State Methods work in the same way as with JUnit 4 tests, refer to the [Pact junit runner](../pact-jvm-provider-junit/README.md) docs. ### Using multiple classes for the state change methods If you have a large number of state change methods, you can split things up by moving them to other classes. You will need to specify the additional classes on the test context in a `Before` method. Do this with the `withStateHandler` or `setStateHandlers` methods. See [StateAnnotationsOnAdditionalClassTest](src/test/java/au/com/dius/pact/provider/junit5/StateAnnotationsOnAdditionalClassTest.java) for an example. ## Modifying the requests before they are sent **Important Note:** You should only use this feature for things that can not be persisted in the pact file. By modifying the request, you are potentially modifying the contract from the consumer tests! Sometimes you may need to add things to the requests that can't be persisted in a pact file. Examples of these would be authentication tokens, which have a small life span. The Http and Https test targets support injecting the request that will executed into the test template method. You can then add things to the request before calling the `verifyInteraction()` method. For example to add a header: ```java @TestTemplate @ExtendWith(PactVerificationInvocationContextProvider.class) void testTemplate(PactVerificationContext context, HttpRequest request) { // This will add a header to the request request.addHeader("X-Auth-Token", "1234"); context.verifyInteraction(); } ``` ## Objects that can be injected into the test methods You can inject the following objects into your test methods (just like the `PactVerificationContext`). They will be null if injected before the supported phase. | Object | Can be injected from phase | Description | | ------ | --------------- | ----------- | | PactVerificationContext | @BeforeEach | The context to use to execute the interaction test | | Pact | any | The Pact model for the test | | Interaction | any | The Interaction model for the test | | HttpRequest | @TestTemplate | The request that is going to be executed (only for HTTP and HTTPS targets) | | ProviderVerifier | @TestTemplate | The verifier instance that is used to verify the interaction | ## Allowing the test to pass when no pacts are found to verify (version 4.0.7+) By default, the test will fail with an exception if no pacts were found to verify. This can be overridden by adding the `@IgnoreNoPactsToVerify` annotation to the test class. For this to work, you test class will need to be able to receive null values for any of the injected parameters.

<dependency>
    <groupId>au.com.dius</groupId>
    <artifactId>pact-jvm-provider-junit5</artifactId>
    <version>4.0.10</version>
</dependency>
Copy
pom.xml
Table Of Contents

Latest Version

Choose a version of au.com.dius : pact-jvm-provider-junit5 to add to Maven or Gradle - Latest Versions:

  • Latest Stable: 4.0.10
  • Latest Beta: 4.0.0-beta.6

All Versions

Choose a version of au.com.dius : pact-jvm-provider-junit5 to add to Maven or Gradle - All Versions:

Version Vulnerabilities Updated
4.0.x
pact-jvm-provider-junit5-4.0.10
pact-jvm-provider-junit5-4.0.9
pact-jvm-provider-junit5-4.0.8
pact-jvm-provider-junit5-4.0.7
pact-jvm-provider-junit5-4.0.6
pact-jvm-provider-junit5-4.0.5
pact-jvm-provider-junit5-4.0.4
pact-jvm-provider-junit5-4.0.3
pact-jvm-provider-junit5-4.0.2
pact-jvm-provider-junit5-4.0.1
pact-jvm-provider-junit5-4.0.0
pact-jvm-provider-junit5-4.0.0-beta.6
pact-jvm-provider-junit5-4.0.0-beta.5
pact-jvm-provider-junit5-4.0.0-beta.4
pact-jvm-provider-junit5-4.0.0-beta.3
pact-jvm-provider-junit5-4.0.0-beta.2
pact-jvm-provider-junit5-4.0.0-beta.1

How to add a dependency to Maven

Add the following au.com.dius : pact-jvm-provider-junit5 maven dependency to the pom.xml file with your favorite IDE (IntelliJ / Eclipse / Netbeans):

<dependency>
    <groupId>au.com.dius</groupId>
    <artifactId>pact-jvm-provider-junit5</artifactId>
    <version>4.0.10</version>
</dependency>

How to add a dependency to Gradle

Gradle Groovy DSL: Add the following au.com.dius : pact-jvm-provider-junit5 gradle dependency to your build.gradle file:

implementation 'au.com.dius:pact-jvm-provider-junit5:4.0.10'

Gradle Kotlin DSL: Add the following au.com.dius : pact-jvm-provider-junit5 gradle kotlin dependency to your build.gradle.kts file:

implementation("au.com.dius:pact-jvm-provider-junit5:4.0.10")

How to add a dependency to SBT Scala

SBT Scala: Add the following au.com.dius : pact-jvm-provider-junit5 sbt scala dependency to your build.sbt file:

libraryDependencies += "au.com.dius" % "pact-jvm-provider-junit5" % "4.0.10"

Advertisement

Dependencies from Group

Apr 29, 2020
31 usages
1k stars
Nov 04, 2018
27 usages
1k stars
Nov 04, 2018
18 usages
1k stars
Apr 29, 2020
13 usages
1k stars
Apr 29, 2020
12 usages
1k stars

Discover Dependencies

Apr 18, 2020
1k stars
Apr 18, 2020
1k stars
Apr 18, 2020
1k stars
Apr 18, 2020
1k stars
Apr 01, 2019
2 usages
98 stars
Apr 06, 2019
0 stars
Jun 19, 2023
1 usages
11.1k stars
Apr 06, 2019
3 usages
1 stars
Apr 06, 2019
2 usages
0 stars