faraday/examples/client_spec.rb
2019-07-19 14:11:30 +02:00

66 lines
1.4 KiB
Ruby

# frozen_string_literal: true
# Requires Ruby with rspec and faraday gems.
# rspec client_spec.rb
require 'faraday'
require 'json'
# Example API client
class Client
def initialize(conn)
@conn = conn
end
def sushi(jname)
res = @conn.get("/#{jname}")
data = JSON.parse(res.body)
data['name']
end
end
Rspec.describe Client do
let(:stubs) { Faraday::Adapter::Test::Stubs.new }
let(:conn) { Faraday.new { |b| b.adapter(:test, stubs) } }
let(:client) { Client.new(conn) }
it 'parses name' do
stubs.get('/ebi') do |env|
# optional: you can inspect the Faraday::Env
expect(env.url.path).to eq('/ebi')
[
200,
{ 'Content-Type': 'application/javascript' },
'{"name": "shrimp"}'
]
end
# uncomment to trigger stubs.verify_stubbed_calls failure
# stubs.get('/unused') { [404, {}, ''] }
expect(client.sushi('ebi')).to eq('shrimp')
stubs.verify_stubbed_calls
end
it 'handles 404' do
stubs.get('/ebi') do
[
404,
{ 'Content-Type': 'application/javascript' },
'{}'
]
end
expect(client.sushi('ebi')).to be_nil
stubs.verify_stubbed_calls
end
it 'handles exception' do
stubs.get('/ebi') do
raise Faraday::ConnectionFailed, nil
end
expect { client.sushi('ebi') }.to raise_error(Faraday::ConnectionFailed)
stubs.verify_stubbed_calls
end
end