1.1.4 • Published 4 years ago

@nialloc9/pact-provider v1.1.4

Weekly downloads
-
License
ISC
Repository
github
Last release
4 years ago

pact-provider

An abstraction over pact.io's provider tests to hide away any complexities with integrating pact into your pipeline.

To help with the buy in from other teams and to get them to integrate contract testing it is important to make it as easy as possible. To do this pact-provider is a reusable abstraction over the provider tests to allow data sources to run just 1 function inside their pipeline to run against our consumer contracts in the broker.

This allows us to update the contract versions without having the data source update their code. Instead we can just ask them to update their version of the package (or have them always install latest).

Usage CLI

$ npm i -g @nialloc9/pact-provider

$ pact-provider --contractName=NameOfContract --pactBrokerUrl=https://MY_BROKER.pact.dius.com.au/ --pactBrokerToken=XXXX
ParameterRequiredTypeDescription
applicationUrlfalsestringRunning API provider host endpoint. e.g --applicationUrl=XXXX
contractNamefalsestringName of the provider contract. Overrides global variable PACT_BROKER_CONTRACT_NAME. e.g --contractName=XXXX
pactBrokerUrlfalsestringURL of the Pact Broker to retrieve pacts from. Required if not using pactUrls. e.g --pactBrokerUrl=XXXX
contractTagsfalsearray of stringsArray of tags, used to filter pacts from the Broker. e.g --contractTags={"dev", "prod"}
pactBrokerTokenfalsestringBearer token for Pact Broker authentication. If using Pactflow, you likely need this option. e.g --pactBrokerToken=XXXX
publishVerificationResultfalsebooleanPublish verification result to Broker --pactBrokerToken=trueboolean
contractVersionfalsestringProvider version, required to publish verification results to a broker --contractVersion=XXXX

Usage Progmatically

// my-pact-provider-tests.js
const { onRunPactTests } = require("@nialloc9/pact-provider");

onRunPactTests();


$ PACT_BROKER_CONTRACT_NAME=NameOfContract PACT_BROKER_TOKEN=XXXX PACT_BROKER_URL=https://MY_BROKER.pact.dius.com.au/ mocha -t 10000 my-pact-provider-tests.js

The global variables are required.

Config Progmatically

A config object can also be passed to the pact tests.

// my-pact-provider-tests.js
const { onRunPactTests } = require("@nialloc9/pact-provider");

const config = {};

onRunPactTests(config);
ParameterRequiredTypeDescription
applicationUrlfalsestringRunning API provider host endpoint.
contractNamefalsestringName of the provider contract. Overrides global variable PACT_BROKER_CONTRACT_NAME.
pactBrokerUrlfalsestringURL of the Pact Broker to retrieve pacts from. Required if not using pactUrls.
contractTagsfalsearray of stringsArray of tags, used to filter pacts from the Broker.
pactBrokerTokenfalsestringBearer token for Pact Broker authentication. If using Pactflow, you likely need this option.
publishVerificationResultfalsebooleanPublish verification result to Brokerboolean
contractVersionfalsestringProvider version, required to publish verification results to a broker
1.1.4

4 years ago

1.1.3

4 years ago

1.1.1

4 years ago

1.1.0

4 years ago

1.1.2

4 years ago

1.0.2

4 years ago

1.0.1

4 years ago

1.0.0

4 years ago