VHS stubs all the API calls performed in your test suite, without you needing to change your tests.
VHS makes an intelligent handling of VCR cassettes to stub every API call that your test suite does. It does so by hooking into Typhoeus and determining the correct cassette for the request being performed.
On a first run if your API call has no cassette saved the real call is made. After that the real call will not be executed and the cassette will be used instead.
That means: faster and more reliable tests without worrying for stubbing what is not the scope of your test.
Add this line to your application's Gemfile:
gem 'vhs'And then execute:
$ bundle
Configure VHS:
$ vhs config cli
This copies a .vhs.yml file to your root with configuration options for VHS,
check it out to see the options. It is also gitignored so you can configure VHS
at will without affecting your teammates.
Now configure RSpec to use VHS:
$ vhs config rspec
This copies a spec/support/vhs.rb file, make sure you include in your spec_helper.
Now you are ready to run your specs using VHS.
After you run your spec suite, the cassettes used by your specs are saved under
the directory spec/fixtures/vhs.
To know whether all of the API calls succeeded you can list the error ones using:
$ vhs list error
And update them accordingly
$ vhs update error
Check the help of both commands to know the posibilities at your disposal.
TimeBandits break the usage of VHS, to make it work, you need to remove lines like
RESTApi.run_with_time_bandit(TimeBandits::CustomConsumers::Search)TODO add details here and in wiki pages about conflicts and ways of fixing them
If you have already stubbed calls to RESTApi in your specs, you
can turn VHS off using the provided rspec tag at the level of describe,
context, or it blocks like this:
# some spec file
describe XYZ, vhs: false do
context 'a spec context', vhs: false do
it 'is an spec example', vhs: false door leave VHS running for part of your spec, and just turn it off on the exact place you need to:
# some spec file
it 'is an spec stubbing RESTApi call' do
  # code goes here
  VHS.turn_off
  # stub as needed
  RESTApi.stub(:get, %r{/rest/users/users/})
  VHS.turn_on
  # from here on VHS takes over again
endIt makes sense to add the cassettes to your repo once the test suite is green.
But before you do so, check that your cassetttes have a fixed url value (i.e.
your test sandbox's rest url).
To ready them for anyone running the specs the cassettes need to be dynamized,
i.e. to replace that fixed sandbox rest url with the value in
AppConfig.sandbox.rest_url.
You can dymanize your cassettes running:
$ vhs dynamize
After that add the cassettes to your git repo and your team can enjoy your fast test suite.
After the cassettes are added to the repo, it can be the case that running your suite still generates new cassettes. To remove them easily use the command
$ vhs clean
It will remove every cassette not added or commited to git.
- Try in in jenkins
- Provide a wiki pages with specs
- Try it with test unit
- write specs!
- clean up code here and in VCR
- fix the CLI cassettes update command
- Fork it ( https://github.com/[my-github-username]/vhs/fork )
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request