The modern Ruby QuickBooks client: Part 3 - Gem Contributing
Record your own QBO sandbox transactions in a PR
You would like to enhance or fix something in the qbo_api
gem but aren't too sure about the "VCR-recorded-sandbox-transaction" part of the specs. Don't you worry a bit about that. Frankly, this "VCR-recorded-sandbox-transaction" thing will actually make it easier for you to contribute and not the other way around. Creating fictional API fixtures is the harder and more error-prone approach.
- Fork the
qbo_api
gem - Clone your fork, switch into the new directory, and
bundle
- Make a new branch for your PR e.g.
git checkout -b cust-ref-name
- Create a
.env
file and fill in all the values - Please see part 1, which will fully explain how to get all the values you need to properly fill in the
.env
file. - Next, run the specs
bundle exec rspec spec/
. - Open the spec
spec/create_update_delete_spec.rb
- Add a name attribute to the
CustomerRef
- Change the record setting to "all".
record: :all
and rerun - Run the
git status
to see which files have been modified. - Change the
record: :all
back torecord: :none
. - Commit the changes:
git commit -a -m "Add CustomerRef:name information when create a new invoice"
- Then push the branch and submit the pull request.
$ git clone git://github.com/[your fork]/qbo_api && cd qbo_api $ bundle
This section is at the 2:22 mark.
data:image/s3,"s3://crabby-images/a0c14/a0c140686f32d598bf4d058a006cb112f3d8f49e" alt=""
data:image/s3,"s3://crabby-images/a323c/a323c5d27583f73bb614b009e62c7bdf89b60b13" alt=""
data:image/s3,"s3://crabby-images/d82df/d82dfe0abeaba471532b1d232d11a57ba6a4fe6c" alt=""
record: :all
setting enabled the spec will test against your sandbox with VCR recording the transaction.data:image/s3,"s3://crabby-images/98357/983575dde7d9da1a9a4463802ea9631c77b39a34" alt=""
spec/vcr/qbo_api/create/invoice.yml
has been updated with the new recording.Conclusion
Contributing to the qbo_api
gem is a cinch. The fact that the gem
utilizes VCR-recorded transactions against real QuickBooks sandboxes makes it
a great choice. That said, don't be intimated at all by VCR; follow this
tutorial and you will easily be able to contribute in making the gem even better.
- Pushed on 03/01/2016 by Christian
- QuickBooks Integration Consulting