The modern Ruby QuickBooks client Part 2
"Real world" fixtures
The qbo_api gem's specs were built against an official QuickBooks sandbox and then recorded using the VCR gem. Therefore, you have a fantastically quick way to get started with your integration project in that you can see "real world" QBO API transaction without your own sandbox or even a network connection. Allow me to demonstrate.
- Clone the
qbo_api
gem, switch into the new directory, andbundle
- Create a .env file If you are just running the specs then at minimum your .env needs to look like the following:
- Now you can run the specs by doing a
bundle exec rspec spec/
- Let's open up the
spec/create_update_delete_spec.rb
- Then go to the first spec where abouts the VCR cassette is being recorded.
- The
creds
method is defined in thespec/spec_helper.rb
- Before the initialize set
QboApi.log = true
and run the individual spec. - Now let's mess around with the response by outputing the invoice's customer name
- Next, open up the
spec/error_spec.rb
and goto the spec titled "handles a validation error".
$ git clone git://github.com/minimul/qbo_api && cd qbo_api $ bundle
export QBO_API_CONSUMER_KEY= export QBO_API_CONSUMER_SECRET= export QBO_API_ACCESS_TOKEN= export QBO_API_ACCESS_TOKEN_SECRET= export QBO_API_COMPANY_ID=12345
This section is at the 2:48 mark.
data:image/s3,"s3://crabby-images/4c57e/4c57e585120f93c52bd286b1a4a49a9766aa632b" alt=""
be
is a bash alias for bundle exec
.data:image/s3,"s3://crabby-images/8965a/8965a183aeb4f90a5888dde94a984d12f40e1d40" alt=""
data:image/s3,"s3://crabby-images/21981/2198139ece8a95faf87e3e369a7db39d7dec29e7" alt=""
.env
file is loaded by the
Dotenv
gem.
Minimul says —
If you want to see an example of an advanced VCR custom matcher keep
reading the spec/spec_helper.rb
file. The purpose of the
matcher is to make VCR more lenient so that any QuickBooks sandbox can be used.
This section is at the 5:29 mark.
data:image/s3,"s3://crabby-images/8415c/8415c761818dd99627b4f85da80b3761662fa579" alt=""
qbo_api
initialization and many other methods use keyword arguments, which is the primary reason for the Ruby 2.2.2
requirement.data:image/s3,"s3://crabby-images/f6b78/f6b783411c4f6c49c5b80239167efc9e1e5c37d9" alt=""
log
feature to view the HTTP transaction to QBO API.data:image/s3,"s3://crabby-images/2ed3b/2ed3b95cf39ad3efd69e3c6f1b77746df0b14eaa" alt=""
data:image/s3,"s3://crabby-images/c7f0a/c7f0abbb3b5fd684bcae86793b3d91b728be7c65" alt=""
p response['CustomerRef']['name']
and then comment out the QboApi.log = true
to isolate the output to only the customer name.
This section is at the 7:44 mark.
data:image/s3,"s3://crabby-images/6996c/6996ceeff5dd5bff3016e9d6950ff0bfb3dfb370" alt=""
Conclusion
When getting started with a QuickBooks integration project using the qbo_api
gem leverage the "real world" recorded specs to help you get started quickly.
- Pushed on 01/23/2016 by Christian
- QuickBooks Integration Consulting