Download pact-jvm-server JAR 4.0.4 with all dependencies
Pact server
===========
The pact server is a stand-alone interactions recorder and verifier, aimed at clients that are non-JVM or non-Ruby based.
The pact client for that platform will need to be implemented, but it only be responsible for generating the `JSON`
interactions, running the tests and communicating with the server.
The server implements a `JSON` `REST` Admin API with the following endpoints.
/ -> For diagnostics, currently returns a list of ports of the running mock servers.
/create -> For initialising a test server and submitting the JSON interactions. It returns a port
/complete -> For finalising and verifying the interactions with the server. It writes the `JSON` pact file to disk.
## Running the server
### Versions 2.2.6+
Pact server takes the following parameters:
```
Usage: pact-jvm-server [options] [port]
port
port to run on (defaults to 29999)
--help
prints this usage text
-h <value> | --host <value>
host to bind to (defaults to localhost)
-l <value> | --mock-port-lower <value>
lower bound to allocate mock ports (defaults to 20000)
-u <value> | --mock-port-upper <value>
upper bound to allocate mock ports (defaults to 40000)
-d | --daemon
run as a daemon process
-v <value> | --pact-version <value>
pact version to generate for (2 or 3)
-k <value> | --keystore-path <value>
Path to keystore
-p <value> | --keystore-password <value>
Keystore password
-s <value> | --ssl-port <value>
Ssl port the mock server should run on. lower and upper bounds are ignored
--debug
run with debug logging
```
### Using trust store 3.4.0+
Trust store can be used. However, it is limited to a single port for the time being.
### Prior to version 2.2.6
Pact server takes one optional parameter, the port number to listen on. If not provided, it will listen on 29999.
It requires an active console to run.
### Using a distribution archive
You can download a [distribution from maven central](http://search.maven.org/remotecontent?filepath=au/com/dius/pact-jvm-server_2.11/2.2.4/).
There is both a ZIP and TAR archive. Unpack it to a directory of choice and then run the script in the bin directory.
### Building a distribution bundle
You can build an application bundle with gradle by running (for 2.11 version):
$ ./gradlew :pact-jvm-server_2.11:installdist
This will create an app bundle in `build/2.11/install/pact-jvm-server_2.11`. You can then execute it with:
$ java -jar pact-jvm-server/build/2.10/install/pact-jvm-server_2.11/lib/pact-jvm-server_2.11-3.2.11.jar
or with the generated bundle script file:
$ pact-jvm-server/build/2.11/install/pact-jvm-server_2.11/bin/pact-jvm-server_2.11
By default will run on port `29999` but a port number can be optionally supplied.
### Running it with docker
You can use a docker image to execute the mock server as a docker container.
$ docker run -d -p 8080:8080 -p 20000-20010:20000-20010 uglyog/pact-jvm-server
This will run the main server on port 8080, and each created mock server on ports 20000-20010. You can map the ports to
any you require.
## Life cycle
The following actions are expected to occur
* The client calls `/create` to initialise a server with the expected `JSON` interactions and state
* The admin server will start a mock server on a random port and return the port number in the response
* The client will execute its interaction tests against the mock server with the supplied port
* Once finished, the client will call `/complete' on the Admin API, posting the port number
* The pact server will verify the interactions and write the `JSON` `pact` file to disk under `/target`
* The mock server running on the supplied port will be shutdown.
## Endpoints
### /create
The client will need `POST` to `/create` the generated `JSON` interactions, also providing a state as a query parameter
and a path.
For example:
POST http://localhost:29999/create?state=NoUsers&path=/sub/ref/path '{ "provider": { "name": "Animal_Service"}, ... }'
This will create a new running mock service provider on a randomly generated port. The port will be returned in the
`201` response:
{ "port" : 34423 }
But you can also reference the path from `/sub/ref/path` using the server port. The service will not strip
the prefix path, but instead will use it as a differentiator. If your services do not have differences
in the prefix of their path, then you will have to use the port method.
### /complete
Once the client has finished running its tests against the mock server on the supplied port (in this example port
`34423`) the client will need to `POST` to `/complete` the port number of the mock server that was used.
For example:
POST http://localhost:29999/complete '{ "port" : 34423 }'
This will cause the Pact server to verify the interactions, shutdown the mock server running on that port and writing
the pact `JSON` file to disk under the `target` directory.
### /
The `/` endpoint is for diagnostics and to check that the pact server is running. It will return all the currently
running mock servers port numbers.
For example:
GET http://localhost:29999/
'{ "ports": [23443,43232] }'
Files of the artifact pact-jvm-server version 4.0.4 from the group au.com.dius.
Artifact pact-jvm-server
Group au.com.dius
Version 4.0.4
Last update 17. December 2019
Tags: need limited filepath using maven store 40000 remotecontent time defaults 34423 search created bundle quot alone host once under image number calls optionally prefix each choice debug running differences life numbers write shutdown install trust endpoints allocate implemented supplied ports admin returned bound actions client both communicating download localhost takes 20000 optional finalising parameters execute text however submitting providing script posting bounds that generated against active require example diagnostics ignored generate ruby response following complete json servers name prints interactions differentiator 43232 provider finished 8080 reference main expected 20010 stand there service usage provided java server daemon bind uglyog lower 29999 test verify verifier help 23443 file only central platform services random interaction create distribution endpoint http start recorder container then will port query build version tests listen options aimed post responsible mock return nousers should process directory implements method archive based server_2 single cause being disk used password prior apos keystore value returns writes cycle initialise logging strip requires console docker pact default gradle rest this unpack call verifying have state writing currently from randomly upper initialising parameter installdist path gradlew with building application check your generating list versions target instead animal_service their also dius occur clients
Organization not specified
URL https://github.com/DiUS/pact-jvm
License Apache 2
Dependencies amount 0
Dependencies No dependencies
There are maybe transitive dependencies!
Group au.com.dius
Version 4.0.4
Last update 17. December 2019
Tags: need limited filepath using maven store 40000 remotecontent time defaults 34423 search created bundle quot alone host once under image number calls optionally prefix each choice debug running differences life numbers write shutdown install trust endpoints allocate implemented supplied ports admin returned bound actions client both communicating download localhost takes 20000 optional finalising parameters execute text however submitting providing script posting bounds that generated against active require example diagnostics ignored generate ruby response following complete json servers name prints interactions differentiator 43232 provider finished 8080 reference main expected 20010 stand there service usage provided java server daemon bind uglyog lower 29999 test verify verifier help 23443 file only central platform services random interaction create distribution endpoint http start recorder container then will port query build version tests listen options aimed post responsible mock return nousers should process directory implements method archive based server_2 single cause being disk used password prior apos keystore value returns writes cycle initialise logging strip requires console docker pact default gradle rest this unpack call verifying have state writing currently from randomly upper initialising parameter installdist path gradlew with building application check your generating list versions target instead animal_service their also dius occur clients
Organization not specified
URL https://github.com/DiUS/pact-jvm
License Apache 2
Dependencies amount 0
Dependencies No dependencies
There are maybe transitive dependencies!
There is a newer version: 4.0.10
Show newest versionShow all versions of pact-jvm-server Show documentation
Please rate this JAR file. Is it a good library?
0 downloads
Source code of pact-jvm-server version 4.0.4
META-INF
au.com.dius.pact.server
© 2015 - 2024 Weber Informatics LLC | Privacy Policy