-
-
Notifications
You must be signed in to change notification settings - Fork 178
Set up checklist
This is a high level check list of things that need to be done when setting up an integration to be tested with Pact using the Pact Broker. As there are many Pact implementations in different languages, you will need to consult the documentation for your language to find out how to implement each step. See The steps to reaching Pact Nirvana for an in depth explanation of the purpose of each step.
This will get you to the stage where your consumer and provider have a pact that is generated and verified automatically, with a set up that allows you to introduce changes without breaking the provider build.
- Write tests for the consumer that use the Pact mock provider (these generate the pact)
- Add a task that only runs on the CI to publish the pacts to the Pact Broker (the Pact implementation for you language will provide this)
- Configure the pacts to be published with a tag that is the name of the git/svn branch (eg.
master
,feat-foo
)
- Add a pact verification test to the provider build
- Configure the verification test to verify the pacts with the tag
master
(or whatever the "main line" of development is called) - Configure the verification test to publish verification results only when run on the CI
- Create a webhook that triggers the provider verification step of your CI pipeline when a pact changes
This set up will ensure that you can only deploy compatible versions of your consumer and provider to a given environment.
- Ensure the Pact Broker knows which application versions are in each environment by adding a step to the deployment process to tag the relevant consumer version with the name of the environment (eg.
test
,prod
) - Check that you are safe to deploy to a given environment by adding a call to
can-i-deploy
before deploying.
- To ensure backwards compatibility between the production consumer and the latest provider, add the name of the tag for the production environment (eg.
prod
) to the list of tags that the provider verifies. - Add a step to the deployment process to tag the relevant provider version with the name of the environment (eg.
test
,prod
) - Check that you are safe to deploy to a given environment by adding a call to
can-i-deploy
before deploying.
This step should not be necessary if you deploy both consumer and provider at similar and regular intervals, but you may get in to a situation where you're trying to deploy a new version of the consumer to production, but can-i-deploy
fails because you have never verified the production version of the provider against the latest version of the consumer. To get around this you can either 1. deploy the latest version of the provider (recommended if possible) or 2. check out the production version of the provider codebase, and run the pact verification task against the pact for the consumer version you're trying to deploy.