Skip to content

Latest commit

 

History

History
72 lines (43 loc) · 3.27 KB

README.md

File metadata and controls

72 lines (43 loc) · 3.27 KB

Braintree Rails Example

Build Status

An example Braintree integration for Ruby on Rails.

Setup Instructions

  1. Install bundler:

    gem install bundler
  2. You may need to install postgresql (a production dependency) and mimemagic. On a mac using Homebrew, run these commands:

brew install shared-mime-info
brew install postgresql
  1. Bundle:

    bundle
  2. Copy the contents of example.env into a new file named .env and fill in your Braintree API credentials. Credentials can be found by navigating to Account > My User > View Authorizations in the Braintree Control Panel. Full instructions can be found on our support site.

  3. Start rails:

    rails server

Deploying to Heroku

You can deploy this app directly to Heroku to see the app live. Skip the setup instructions above and click the button below. This will walk you through getting this app up and running on Heroku in minutes.

Deploy

Running Tests

Running Unit Tests

Unit tests do not make API calls to Braintree and do not require Braintree credentials. You can run this project's unit tests by calling rake (or rails -R spec) on the command line.

Running Integration Tests

Integration tests make API calls to Braintree and require that you set up your Braintree credentials. You can run this project's integration tests by adding your sandbox API credentials to .env and calling rake spec:integration (or rails spec:integration) on the command line.

Running All Tests

You can run both unit and integrations tests by calling rake spec (or rails spec) on the command line.

Testing Transactions

Sandbox transactions must be made with sample credit card numbers, and the response of a Braintree::Transaction.sale() call is dependent on the amount of the transaction.

Pro Tips

  • Run rails s -b 0.0.0.0 when launching Rails server to listen on all interfaces.

Help

Disclaimer

This code is provided as is and is only intended to be used for illustration purposes. This code is not production-ready and is not meant to be used in a production environment. This repository is to be used as a tool to help merchants learn how to integrate with Braintree. Any use of this repository or any of its code in a production environment is highly discouraged.