Fix DocumentParser being included for all objects
This commit is contained in:
@@ -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|
|
||||||
|
|||||||
@@ -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|
|
||||||
|
|||||||
@@ -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|
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
Reference in New Issue
Block a user