Skip to content

A library for mocking Braintree calls and responses in your tests

License

Notifications You must be signed in to change notification settings

buzzamus/mock-braintree

Repository files navigation

MockBraintree

A library for mocking Braintree responses in your tests

This Gem is a work in progress and currently offers only a small amount of functionality - currently only transaction.sale calls with limited responses returned.

Installation

Add this line to your application's Gemfile:

gem 'mock_braintree'

And then execute:

$ bundle

Or install it yourself as:

$ gem install mock_braintree

Usage

First, configure your mock Braintree integration by switching out your real Braintree configuration with MockBraintree::Gateway.new

example:

def gateway
  MockBraintree::Gateway.new
end

MockBraintree lets you test simple result handling just like Braintree responses:

result = gateway.transaction.sale(nonce: 'fake-valid-nonce', amount: '10.00', options: { submit_for_settlement: true })

puts result.success?
  #=> true
puts result.transaction.status
   #=> submitted_for_settlement
puts result.transaction.amount
  #=> '10.00'
puts result.transaction.id
  #=> 'ej6a32'

You can also adjust the amount of time it takes for you to receive a response by adjusting the value of WAIT_TIME within transaction_request.rb. The default is between 2-5 seconds (with 3 seconds weighted at a 57% chance). It is recommended to remove, or comment out this value when running specs (these values are commented out by default).

Development

After checking out the repo, run bin/setup to install dependencies. You can also run bin/console for an interactive prompt that will allow you to experiment.

To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.

Disclaimer

While I work at Braintree, this library was neither built by Braintree, nor is it maintained by Braintree. If there is a feature you are looking for PRs are always welcome, or feel free to fork your own branch and make it your own. If you find a bug please open an issue on this repo and do not contact Braintree directly.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/buzzamus/mock_braintree.

License

The gem is available as open source under the terms of the MIT License.

About

A library for mocking Braintree calls and responses in your tests

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published