Я не уверен, как подойти к тесту, когда он входит в часть исключения для следующего метода ".get":
/ api / reddit_client.rb :
module Api
class RedditClient
def self.get(path, access_token)
begin
response = RestClient.get(
path,
{ :Authorization => "Bearer #{access_token}" }
)
json_parse(response)
rescue RestClient::ExceptionWithResponse => e
logger.error "%%% Something went wrong in request post"
logger.error "%%% It fails with error: #{e.http_code}"
logger.error "%%% And with message: #{e.message}"
{ "message" => e.message, "error" => e.http_code }
end
end
...
...
...
private
def json_parse(response)
JSON.parse(response.body)
end
end
end
Я хочу, чтобы он проверил, вызывает ли он RestClient :: ExceptionWithResponse, для этого я сделал следующее:
/ api / reddit_client_spec.rb :
require 'rails_helper'
RSpec.describe Api::RedditClient do
let(:path) { 'https://www.somerandomapi.com' }
let(:access_token) { 'f00TOk3N' }
describe '.get' do
subject { described_class.get(path, access_token)}
context 'when not authorized' do
before do
allow(described_class)
.to receive(:get)
.and_raise(RestClient::ExceptionWithResponse)
end
it 'returns hash with error infos' do
expect{ subject }.to raise_error(RestClient::ExceptionWithResponse)
end
end
end
end
Что меня обманывает, так это то, что я также хочу проверить, был ли Rails.logger.error тоже вызываться 3 раза, и проверить мою ошибку хэша.Как проверить это случаи?