VHS
a ruby gem for
stubbing every API call in tests
git: joaquin-rivera/vhs
Status quo
git: joaquin-rivera/vhs
XTM
Users API
many API calls
Profiles API
Events API
Problem
git: joaquin-rivera/vhs
- slow tests
- unreliable results due to network glitches, sandbox is down
- takes time to set up sandboxes + services
- hard to stub API calls in high level (feature) specs
Test suite also does many API calls
Enter VHS
git: joaquin-rivera/vhs
XTM
Users API
Profiles API
Events API
first-time call => records request
repeated calls => replays request
VCR
VCR
VCR
wraps around VCR at typhoeus level
VHS Advantages
git: joaquin-rivera/vhs
Test suite does less API calls
- faster tests
- reliable, deterministic results => NO intermittent red builds
- no need to change your specs
- no need to set up sandboxes + services
Usage
git: joaquin-rivera/vhs
gem 'vhs'
bundle
vhs-config-rspec.rb
rake spec # records the VCR cassettes
rake spec # replays existing VCR cassettes
cassettes are YAML files saved under
spec/fixtures/vcr as default
No stub collision
git: joaquin-rivera/vhs
Turn VHS off to stub yourself
# some spec file
describe YourClass, vhs: false do
context 'also can use rspec tag', vhs: false do
it 'needs VHS to be turned off', vhs: false do
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
end
Dynamic cassettes
git: joaquin-rivera/vhs
Before adding cassettes to git
---
- !ruby/struct:VCR::HTTPInteraction
request: !ruby/struct:VCR::Request
method: :post
uri: http://qi-joaquin-rivera.env.xing.com:3007/rest/search-proxy/templates/xtm/search?rid=internal&consumer=loggedin.web.xtm.search.center
$ vcr-dinamyze-cassettes.rb
dynamize your cassettes
---
- !ruby/struct:VCR::HTTPInteraction
request: !ruby/struct:VCR::Request
method: :post
uri: <%= api_host %>/search-proxy/templates/xtm/search?rid=internal&consumer=loggedin.web.xtm.search.center
now they use AppConfig.sandbox.rest_url
Learn by using
git: joaquin-rivera/vhs
- RESTApi.run_with_time_bandit breaks
- RESTApi::Request.check_response_token breaks
- Request with HTTP Status Code = 0, 4xx, 5xx
- Correct frequency to update cassettes
- Improve patterns when writing specs
- a.s.o...
check code, README and wiki for details
Benchmark
git: joaquin-rivera/vhs
without VHS
Finished in 12 minutes 1 second (files took 7.37 seconds to load)
1879 examples, 1 failure, 2 pending
VHS recording
Finished in 11 minutes 11 seconds (files took 8.02 seconds to load)
1884 examples, 79 failures, 2 pending
VHS replaying
Finished in 8 minutes 53 seconds (files took 7.97 seconds to load)
1884 examples, 69 failures, 2 pending
3 minutes gain as of today
but of course we are not green yet ;-)
Contact me
joaquin-rivera/vcr
Joaquin Rivera @ xing
- You need help to use VHS
- Ideas
- Opinions
- Questions
- Pull Requests
joaquin-rivera/vhs
git:
VHS a ruby gem for stubbing every API call in tests
By Joaquin Rivera Padron
VHS a ruby gem for stubbing every API call in tests
VHS is a ruby gem that records every API calls in your tests, then it replays them every time you run your tests.
- 1,995