From 1491dc9a1619947bea7592729f040f85e014b930 Mon Sep 17 00:00:00 2001 From: Phil Lee Date: Wed, 4 Dec 2024 10:43:37 +0000 Subject: [PATCH] add EY serializer for admin data report --- app/models/claim/data_report_request.rb | 18 ++++++++++ spec/models/claim/data_report_request_spec.rb | 36 +++++++++++++++++-- 2 files changed, 51 insertions(+), 3 deletions(-) diff --git a/app/models/claim/data_report_request.rb b/app/models/claim/data_report_request.rb index 0022e621d0..71c597def7 100644 --- a/app/models/claim/data_report_request.rb +++ b/app/models/claim/data_report_request.rb @@ -83,6 +83,24 @@ def to_csv_row end end + class EarlyYearsPayments < Base + def to_csv_row + [ + ExcelUtils.escape_formulas(claim.reference), + nil, + ExcelUtils.escape_formulas(claim.national_insurance_number), + ExcelUtils.escape_formulas(claim.full_name), + ExcelUtils.escape_formulas(claim.email_address), + ExcelUtils.escape_formulas(claim.date_of_birth), + nil, + ExcelUtils.escape_formulas(claim.policy), + ExcelUtils.escape_formulas(claim.eligibility.eligible_ey_provider.nursery_name), + ExcelUtils.escape_formulas(claim.eligibility.eligible_ey_provider.urn), + ExcelUtils.escape_formulas(claim.payroll_gender) + ] + end + end + class InternationalRelocationPayments < Base def to_csv_row [ diff --git a/spec/models/claim/data_report_request_spec.rb b/spec/models/claim/data_report_request_spec.rb index d726199b2a..928ec4148f 100644 --- a/spec/models/claim/data_report_request_spec.rb +++ b/spec/models/claim/data_report_request_spec.rb @@ -7,7 +7,7 @@ let(:csv) { CSV.parse(subject.to_csv, headers: true) } describe "#to_csv" do - context "early policies" do + context "original policies" do let(:claims) do [ create(:claim, :submitted, policy: Policies::StudentLoans), @@ -36,7 +36,7 @@ end end - context "FE policy" do + context "FE policy claims" do let(:claims) do [ create(:claim, :submitted, policy: Policies::FurtherEducationPayments) @@ -63,7 +63,7 @@ end end - context "IRP claims" do + context "IRP policy claims" do let(:claims) do [ create(:claim, :submitted, policy: Policies::InternationalRelocationPayments) @@ -92,6 +92,36 @@ end end + context "EY policy claims" do + let(:claims) do + [ + create(:claim, :submitted, policy: Policies::EarlyYearsPayments) + ] + end + + it "contains the correct headers" do + expect(csv.headers).to eql(Claim::DataReportRequest::HEADERS) + end + + it "contains the correct values" do + claims.each_with_index do |claim, index| + expect(csv[index]["Claim reference"]).to eql(claim.reference) + expect(csv[index]["Teacher reference number"]).to be_nil + expect(csv[index]["NINO"]).to eql(claim.national_insurance_number) + expect(csv[index]["Full name"]).to eql(claim.full_name) + expect(csv[index]["Email"]).to eql(claim.email_address) + expect(csv[index]["Date of birth"]).to eql(claim.date_of_birth.to_s) + expect(csv[index]["ITT subject"]).to be_nil + expect(csv[index]["Policy name"]).to eql(claim.policy.to_s) + expect(csv[index]["School name"]).to eql(claim.eligibility.eligible_ey_provider.nursery_name) + expect(csv[index]["School unique reference number"]).to eql(claim.eligibility.eligible_ey_provider.urn) + expect(csv[index]["Payroll gender"]).to eql(claim.payroll_gender) + expect(csv[index]["Nationality"]).to be_nil + expect(csv[index]["Passport number"]).to be_nil + end + end + end + context "when there is a single quotation sign in name field" do let(:claims) do [