VCR不会在成功请求时录制盒式磁带,只会在失败请求时录制



我有一个简单的测试来获取一个Facebook对象。我正在使用Curl来处理请求。

it "gets an object from Facebook" do
  VCR.use_cassette('facebook') do
    url = "https://graph.facebook.com/<ID>?access_token=#{@access_token}&#{query_string}"
    curl = Curl::Easy.perform(url)
    expect(curl.body_str).to eql('<my object>')
  end
end

我的VCR配置为:

VCR.configure do |c|
  c.cassette_library_dir = 'spec/fixtures/vcr_cassettes'
  c.hook_into :webmock
end

当我运行测试时,它通过了,并记录了以下内容:

[Cassette: 'facebook'] Initialized with options: {:record=>:once, :match_requests_on=>[:method, :uri], :allow_unused_http_interactions=>true, :serialize_with=>:yaml, :persist_with=>:file_system}
[webmock] Handling request: [get https://graph.facebook.com/<ID>?access_token=<TOKEN>&fields=%5B%22id%22,%22account_id%22,%22name%22,%22campaign_group_status%22,%22objective%22%5D] (disabled: false)
[Cassette: 'facebook'] Initialized HTTPInteractionList with request matchers [:method, :uri] and 0 interaction(s): {  }
[webmock] Identified request type (recordable) for [get https://graph.facebook.com/<ID>?access_token=<TOKEN>&fields=%5B%22id%22,%22account_id%22,%22name%22,%22campaign_group_status%22,%22objective%22%5D]

但是磁带没有被记录,目录是空的。我试过:record => :all也得到了同样的结果。

通常,人们在为他们正在使用的库使用不兼容的钩子时会遇到这个错误,但事实并非如此。我正在使用webmock和curp。

奇怪的是,当请求失败时,例如令牌过期时,会记录盒式磁带。当它被修复后,我删除了这个文件,它就不会再被录制了。

有人遇到过同样的问题吗?

事实证明,我的代码比上面的稍微复杂一点,并且在执行请求后执行回调。类似于:

success_handler = Proc.new { return c.body_str }
curl.on_success do |easy|
  success_handler.call(easy)
end

这会绕过VCR,并且不会写入文件。将代码重构为不使用回调是可行的。

最新更新