Generating Pact Consumer Tests with Grunt and Karma
Note that this is not an official Grunt plugin release! If you want to use this in a project, please be sure to follow the instructions for installing development versions, as outlined in the Installing Grunt guide.
This plugin requires Grunt ``
If you haven't used Grunt before, be sure to check out the Getting Started guide, as it explains how to create a Gruntfile as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:
npm install grunt-pact-js --save-dev
Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:
grunt.loadNpmTasks('grunt-pact-js');
Run this task with the grunt contracttest
command.
This plugin relies on the Ruby pact-mock_service. Please read the chapter Install the Mock Server
For your tests you need pact-consumer-js-dsl. Install the library with bower or nodejs and make it accessible over your karmer config
file.
bower install pact-consumer-js-dsl --save-dev
module.exports = function (config) {
config.set({
...
// list of files / patterns to load in the browser
files: [
// if you are using this example to setup your own project load pact from the node_modules directory
// i.e. node_modules/pact-consumer-js-dsl/dist/pact-consumer-js-dsl.js
'app/bower_components/pact-consumer-js-dsl/dist/pact-consumer-js-dsl.js',
],
...
}
}
This task requires you to have Ruby, Bundler and RubyGems installed. If you're on OS X or Linux you probably already have Ruby installed; test with ruby -v
in your terminal. When you've confirmed you have Ruby installed, run gem install bundler
.
If on Windows
, please refer to the Installing pact-mock-service on Windows
Windows users must run the install command after following Wiki instructions
(This Plugin is not tested with Windows)
Depending on your use case you can use different commands.
Run the grunt task grunt installMockService
.
Execute bundle install
inside the grunt pact js project folder to install pact-mock_service.
If you will change some option you can do this for example with:
grunt.initConfig({
contractTest: {
options: {
mockServicePort: 8181,
}
}
});
If you want change all configuration you can do this with:
grunt.initConfig({
contractTest: {
options: {
mockServicePort: 8181,
karmaConfigFile: 'test/karma.conf.js',
pactDir: 'tmp'
}
},
});
If you want add a custom Gem file for the mock service you can do this with:
grunt.initConfig({
installMockService: {
options: {
gemfile: 'your-custom-file-if-you-need'
}
},
});
The current Gem file contains the follow content:
source 'https://rubygems.org'
gem 'pact-mock_service', '~> 0.4.1'
It is located in node_modules/grunt-pact-js/Gemfile
.
To work on this plugin locally, use the npm link feature.
To recreate the README.MD just run grunt build-contrib
.
- Karma or any other task doesn't work!
>> rm -rf node_modules/grunt-pact-js/node_modules/*
>> npm install
-
Karma still doesn't work and there were errors while npm install
Make sure python27 is installed and selected:
>> sudo port select --set python python27
>> npm install
See also:
- https://github.com/DiUS/pact-consumer-js-dsl
- https://github.com/bethesque/pact-mock_service/wiki/Integrating-pact-mock-service-with-Grunt-and-Protractor
- https://github.com/bethesque/pact-mock_service/wiki/Installing-the-pact-mock_service-gem-on-Windows
- 2015-03-27 v0.3.0-SNAPSHOT fixed repo urls in package.json
- 2015-03-20 v0.2.3 Remove grunt as devDependencies
- 2015-03-20 v0.2.2 Fixed private flag and grunt-force-task dep
- 2015-03-20 v0.2.1 Fixed typos in documentation
- 2015-03-20 v0.2.0 Added config options
- 2015-03-20 v0.1.0 initial setup
Task submitted by devbliss GmbH
This file was generated on Fri Mar 27 2015 17:48:57.