VCR
1.0.0
1.0.0
  • Initial page
  • record_modes
    • :none
    • :new_episodes
    • :all
    • :once
  • test_frameworks
    • Usage with Test::Unit
    • Usage with Cucumber
    • Usage with RSpec metadata
  • request_matching
    • Matching on Headers
    • Matching on Body
    • Matching on Method
    • URI without param(s)
    • Identical requests are replayed in sequence
    • Matching on Body
    • Playback repeats
    • Matching on URI
    • Matching on Host
    • Matching on Path
    • Matching on Query string
    • Register and use a custom matcher
  • cassettes
    • exclusive cassette
    • Update content_length header
    • Error for HTTP request made when no cassette is in use
    • Naming
    • Allow Unused HTTP Interactions
    • Freezing Time
    • Decode compressed response
    • Dynamic ERB cassettes
    • Automatic Re-recording
    • Cassette format
  • configuration
    • hook_into
    • cassette_library_dir
    • Filter sensitive data
    • Ignore Request
    • Debug Logging
    • default_cassette_options
    • query_parser
    • uri_parser
    • Allow HTTP connections when no cassette
    • Preserve Exact Body Bytes
  • http_libraries
    • EM HTTP Request
    • Net::HTTP
  • hooks
    • before_playback hook
    • after_http_request hook
    • before_http_request hook
    • before_record hook
    • around_http_request hook
  • middleware
    • Faraday middleware
    • Rack
Powered by GitBook
On this page
  • Background ()
  • Unused HTTP interactions are allowed by default
  • Error raised if option is false and there are unused interactions
  • No error raised if option is false and all interactions are used
  • Does not silence other errors raised in use_cassette block

Was this helpful?

  1. cassettes

Allow Unused HTTP Interactions

If set to false, this cassette option will cause VCR to raise an error when a cassette is ejected and there are unused HTTP interactions remaining, unless there is already an exception unwinding the callstack.

It verifies that all requests included in the cassette were made, and allows VCR to function a bit like a mock object at the HTTP layer.

The option defaults to true (mostly for backwards compatibility).

Background ()

Given a file named "vcr_config.rb" with:

require 'vcr'

VCR.configure do |c|
  c.hook_into :webmock
  c.cassette_library_dir = 'cassettes'
end

And a previously recorded cassette file "cassettes/example.yml" with:

--- 
http_interactions: 
- request: 
    method: get
    uri: http://example.com/foo
    body: 
      encoding: UTF-8
      string: ""
    headers: {}
  response: 
    status: 
      code: 200
      message: OK
    headers: 
      Content-Length: 
      - "5"
    body: 
      encoding: UTF-8
      string: Hello
    http_version: "1.1"
  recorded_at: Tue, 01 Nov 2011 04:58:44 GMT
recorded_with: VCR 2.0.0

Unused HTTP interactions are allowed by default

Given a file named "allowed_by_default.rb" with:

require 'vcr_config'

VCR.use_cassette("example") do
  # no requests
end

When I run ruby allowed_by_default.rb

Then it should pass.

Error raised if option is false and there are unused interactions

Given a file named "disallowed_with_no_requests.rb" with:

require 'vcr_config'

VCR.use_cassette("example", :allow_unused_http_interactions => false) do
  # no requests
end

When I run ruby disallowed_with_no_requests.rb

Then it should fail with an error like:

There are unused HTTP interactions left in the cassette:
  - [get http://example.com/foo] => [200 "Hello"]

No error raised if option is false and all interactions are used

Given a file named "disallowed_with_all_requests.rb" with:

require 'vcr_config'

VCR.use_cassette("example", :allow_unused_http_interactions => false) do
  Net::HTTP.get_response(URI("http://example.com/foo"))
end

When I run ruby disallowed_with_all_requests.rb

Then it should pass.

Does not silence other errors raised in use_cassette block

Given a file named "does_not_silence_other_errors.rb" with:

require 'vcr_config'

VCR.use_cassette("example", :allow_unused_http_interactions => false) do
  raise "boom"
end

When I run ruby does_not_silence_other_errors.rb

Then it should fail with "boom"

And the output should not contain "There are unused HTTP interactions".

PreviousNamingNextFreezing Time

Last updated 5 years ago

Was this helpful?