We were very inconsistent regarding these rules. Personally I prefer no empty lines around blocks, clases, etc... as recommended by the Ruby style guide [1], and they're the default values in rubocop, so those are the settings I'm applying. The exception is the `private` access modifier, since we were leaving empty lines around it most of the time. That's the default rubocop rule as well. Personally I don't have a strong preference about this one. [1] https://rubystyle.guide/#empty-lines-around-bodies
31 lines
1.0 KiB
Ruby
31 lines
1.0 KiB
Ruby
require "rails_helper"
|
|
|
|
describe LocalCensus do
|
|
let(:api) { LocalCensus.new }
|
|
|
|
describe "#call" do
|
|
let(:invalid_body) { nil }
|
|
let(:valid_body) { create(:local_census_record) }
|
|
|
|
it "returns the response for the first valid variant" do
|
|
allow(api).to receive(:get_record).with(1, "00123456").and_return(invalid_body)
|
|
allow(api).to receive(:get_record).with(1, "123456").and_return(invalid_body)
|
|
allow(api).to receive(:get_record).with(1, "0123456").and_return(valid_body)
|
|
|
|
response = api.call(1, "123456")
|
|
|
|
expect(response).to be_valid
|
|
expect(response.date_of_birth).to eq(Date.new(1970, 1, 31))
|
|
end
|
|
|
|
it "returns the last failed response" do
|
|
allow(api).to receive(:get_record).with(1, "00123456").and_return(invalid_body)
|
|
allow(api).to receive(:get_record).with(1, "123456").and_return(invalid_body)
|
|
allow(api).to receive(:get_record).with(1, "0123456").and_return(invalid_body)
|
|
response = api.call(1, "123456")
|
|
|
|
expect(response).not_to be_valid
|
|
end
|
|
end
|
|
end
|