Fix DocumentParser being included for all objects

This commit is contained in:
Javi Martín
2024-04-10 16:12:40 +02:00
parent 09eddec663
commit 913b93aea7
4 changed files with 24 additions and 12 deletions

View File

@@ -1,5 +1,6 @@
include DocumentParser
class CensusApi class CensusApi
include DocumentParser
def call(document_type, document_number) def call(document_type, document_number)
response = nil response = nil
get_document_number_variants(document_type, document_number).each do |variant| get_document_number_variants(document_type, document_number).each do |variant|

View File

@@ -1,5 +1,6 @@
include DocumentParser
class LocalCensus class LocalCensus
include DocumentParser
def call(document_type, document_number) def call(document_type, document_number)
record = nil record = nil
get_document_number_variants(document_type, document_number).each do |variant| get_document_number_variants(document_type, document_number).each do |variant|

View File

@@ -1,5 +1,6 @@
include DocumentParser
class RemoteCensusApi class RemoteCensusApi
include DocumentParser
def call(document_type, document_number, date_of_birth, postal_code) def call(document_type, document_number, date_of_birth, postal_code)
response = nil response = nil
get_document_number_variants(document_type, document_number).each do |variant| get_document_number_variants(document_type, document_number).each do |variant|

View File

@@ -1,35 +1,44 @@
require "rails_helper" require "rails_helper"
include DocumentParser
describe DocumentParser do describe DocumentParser do
before do
dummy_class = Class.new do
include DocumentParser
end
stub_const("DummyClass", dummy_class)
end
let(:dummy) { DummyClass.new }
describe "#get_document_number_variants" do describe "#get_document_number_variants" do
it "returns no variants when document_number is not defined" do it "returns no variants when document_number is not defined" do
expect(DocumentParser.get_document_number_variants("1", "")).to be_empty expect(dummy.get_document_number_variants("1", "")).to be_empty
end end
it "trims and cleans up entry" do it "trims and cleans up entry" do
expect(DocumentParser.get_document_number_variants(2, " 1 2@ 34")).to eq(["1234"]) expect(dummy.get_document_number_variants(2, " 1 2@ 34")).to eq(["1234"])
end end
it "returns only one try for passports & residence cards" do it "returns only one try for passports & residence cards" do
expect(DocumentParser.get_document_number_variants(2, "1234")).to eq(["1234"]) expect(dummy.get_document_number_variants(2, "1234")).to eq(["1234"])
expect(DocumentParser.get_document_number_variants(3, "1234")).to eq(["1234"]) expect(dummy.get_document_number_variants(3, "1234")).to eq(["1234"])
end end
it "takes only the last 8 digits for dnis and resicence cards" do it "takes only the last 8 digits for dnis and resicence cards" do
expect(DocumentParser.get_document_number_variants(1, "543212345678")).to eq(["12345678"]) expect(dummy.get_document_number_variants(1, "543212345678")).to eq(["12345678"])
end end
it "tries all the dni variants padding with zeroes" do it "tries all the dni variants padding with zeroes" do
expect(DocumentParser.get_document_number_variants(1, "0123456")) expect(dummy.get_document_number_variants(1, "0123456"))
.to eq(["123456", "0123456", "00123456"]) .to eq(["123456", "0123456", "00123456"])
expect(DocumentParser.get_document_number_variants(1, "00123456")) expect(dummy.get_document_number_variants(1, "00123456"))
.to eq(["123456", "0123456", "00123456"]) .to eq(["123456", "0123456", "00123456"])
end end
it "adds upper and lowercase letter when the letter is present" do it "adds upper and lowercase letter when the letter is present" do
expect(DocumentParser.get_document_number_variants(1, "1234567A")) expect(dummy.get_document_number_variants(1, "1234567A"))
.to eq(%w[1234567 01234567 1234567a 1234567A 01234567a 01234567A]) .to eq(%w[1234567 01234567 1234567a 1234567A 01234567a 01234567A])
end end
end end