VCR::Errors::UnhandledHTTPRequestError в тесте контроллера с использованием VCR

Я пытаюсь имитировать вызов API, в котором я загружаю файл, я использую API загрузки Wistia и поскольку я не хочу нагружать сервер каждым тестом, я пробую видеомагнитофон в первый раз.

У меня есть следующий тест в моей папке spec/controllers:

let(:file) { Rack::Test::UploadedFile.new("video_path", 'video/mp4') }

describe "GET #index" do
  it "assigns all videos as @videos" do
    VCR.use_cassette "wistia/upload" do 
      video = Video.create! valid_attributes

      get :index, {}
      expect(assigns(:videos)).to eq([video])
    end
  end
end

конец

Вызов API запускается внутри обратного вызова модели, который выглядит следующим образом:

class Video < ActiveRecord::Base
  after_save :move_video
  def move_video
    uri = URI('https://upload.wistia.com/')

    http = Net::HTTP.new(uri.host, uri.port)
    http.use_ssl = true

    # Construct the request.
    request = Net::HTTP::Post::Multipart.new uri.request_uri, {
    'api_password' => '',
    'project_id'   => ''
    'file' => my_video_file
    }
    # Make it so!
    response = http.request(request)
    return response
  end
end

Я отладил вызов этого метода, и он вызывается правильно, но когда я запускаю тест, я получаю следующую ошибку:

1) VideosController GET #index assigns all videos as @videos
     Failure/Error: video = Video.create! valid_attributes
     VCR::Errors::UnhandledHTTPRequestError:


       ================================================================================
       An HTTP request has been made that VCR does not know how to handle:
         POST https://upload.wistia.com/

       VCR is currently using the following cassette:
         - /Users/urielhernandez/Documents/pf/spec/vcr/wistia/upload.yml
         - :record => :once
         - :match_requests_on => [:method, :uri]

       Under the current configuration VCR can not find a suitable HTTP interaction
       to replay and is prevented from recording new requests. There are a few ways
       you can deal with this:

         * If you're surprised VCR is raising this error
           and want insight about how VCR attempted to handle the request,
           you can use the debug_logger configuration option to log more details [1].
         * You can use the :new_episodes record mode to allow VCR to
           record this new request to the existing cassette [2].
         * If you want VCR to ignore this request (and others like it), you can
           set an `ignore_request` callback [3].
         * The current record mode (:once) does not allow new requests to be recorded
           to a previously recorded cassette. You can delete the cassette file and re-run
           your tests to allow the cassette to be recorded with this request [4].
         * The cassette contains an HTTP interaction that matches this request,
           but it has already been played back. If you wish to allow a single HTTP
           interaction to be played back multiple times, set the `:allow_playback_repeats`
           cassette option [5].

       [1] https://www.relishapp.com/vcr/vcr/v/2-9-3/docs/configuration/debug-logging
       [2] https://www.relishapp.com/vcr/vcr/v/2-9-3/docs/record-modes/new-episodes
       [3] https://www.relishapp.com/vcr/vcr/v/2-9-3/docs/configuration/ignore-request
       [4] https://www.relishapp.com/vcr/vcr/v/2-9-3/docs/record-modes/once
       [5] https://www.relishapp.com/vcr/vcr/v/2-9-3/docs/request-matching/playback-repeats
       ================================================================================

Кассета была создана, но я получил указанную ошибку. После того, как я удалил кассету, чтобы проверить, генерировалась ли она, она не была сгенерирована повторно, и видеомагнитофон не обрабатывает запрос.


person Uriel Hernández    schedule 17.03.2015    source источник
comment
Блок VCR.use_cassette "wistia/upload" do не имеет блока end; поэтому я предполагаю, что это должно было вызвать синтаксическую ошибку. Попробуйте VCR.use_cassette "wistia_upload" do ... end ; / в названии кассеты также может выключать видеомагнитофон.   -  person Prakash Murthy    schedule 17.03.2015
comment
Извините, я редактирую свой вопрос, это была опечатка при копировании моего кода в вопрос. В моем коде есть конечный блок для метода VCR.use_cassete.   -  person Uriel Hernández    schedule 17.03.2015
comment
Замена wistia/upload на wistia_upload ничего не изменила.   -  person Uriel Hernández    schedule 17.03.2015
comment
/ в названии кассеты в порядке. Кассета создается в /Users/urielhernandez/Documents/pf/spec/vcr/wistia/upload.yml, как описано в сообщении об ошибке. Попробуйте VCR.use_cassette("wistia/upload", :record => :new_episodes) do ; который запишет это как новый запрос на той же кассете.   -  person Prakash Murthy    schedule 17.03.2015
comment
Теперь работает, единственное, что я добавил, это опция new_episode, которую вы сказали. Как я могу отметить ваш вопрос как правильный? Я пока не понимаю, в чем была проблема. И еще, моя кассета никогда не регенерировалась, я восстановил из хлама и все заработало.   -  person Uriel Hernández    schedule 17.03.2015
comment
Идеально. Я добавлю это в ответ с более подробной информацией.   -  person Prakash Murthy    schedule 17.03.2015
comment
Я перестал использовать видеомагнитофон и просто использовал моки rspec, чтобы издеваться над своими объектами. Это гораздо более гибко, чем использование видеомагнитофона.   -  person Fabrizio Bertoglio    schedule 06.08.2019


Ответы (1)


Кассета создается в /Users/urielhernandez/Documents/pf/spec/vcr/wistia/upload.yml, как описано в сообщении об ошибке.

Попробуйте VCR.use_cassette("wistia/upload", :record => :new_episodes) do ; который запишет это как новый запрос на той же кассете.

Дополнительные сведения о режимах записи vcr см. на странице https://www.relishapp.com/vcr/vcr/v/1-3-2/docs/record-modes

person Prakash Murthy    schedule 17.03.2015