diff --git a/app/helpers/admin/claims_helper.rb b/app/helpers/admin/claims_helper.rb index 3a014d5828..2a80382a26 100644 --- a/app/helpers/admin/claims_helper.rb +++ b/app/helpers/admin/claims_helper.rb @@ -155,8 +155,11 @@ def task_status_tag(claim, task_name) status_colour = "red" end - tag_classes = "govuk-tag app-task-list__task-completed govuk-tag--#{status_colour}" + task_status_content_tag(status_colour:, status:) + end + def task_status_content_tag(status_colour:, status:) + tag_classes = "govuk-tag app-task-list__task-completed govuk-tag--#{status_colour}" content_tag("strong", status, class: tag_classes) end diff --git a/app/views/admin/tasks/student_loan_plan.html.erb b/app/views/admin/tasks/student_loan_plan.html.erb index 5b659ff4a9..1f1dda4440 100644 --- a/app/views/admin/tasks/student_loan_plan.html.erb +++ b/app/views/admin/tasks/student_loan_plan.html.erb @@ -15,10 +15,17 @@
- <% if !@task.passed.nil? %> + <% if @task.persisted? %> <%= render "task_outcome", task: @task %> <% else %> - <%= render "form", task_name: "student_loan_plan", claim: @claim %> +
+

+ <%= task_status_content_tag(status_colour: "grey", status: "Incomplete") %> +

+

+ This task has not been checked against Student Loan Company data yet. +

+
<% end %> <%= render partial: "admin/task_pagination" %> diff --git a/config/locales/en.yml b/config/locales/en.yml index 653bf0bb5e..9138a7d87f 100644 --- a/config/locales/en.yml +++ b/config/locales/en.yml @@ -933,8 +933,6 @@ en: claimant_answers: true: "Yes" false: "No" - student_loan_plan: - title: "Does the claimant’s student loan plan match the information we hold about their loan?" forms: ineligible: courses: diff --git a/spec/factories/policies/further_education_payments/eligibilities.rb b/spec/factories/policies/further_education_payments/eligibilities.rb index 2775a82d95..868766b622 100644 --- a/spec/factories/policies/further_education_payments/eligibilities.rb +++ b/spec/factories/policies/further_education_payments/eligibilities.rb @@ -6,6 +6,12 @@ trait :eligible do eligible_school contract_type { "permanent" } + verified + end + + trait :not_verified do + eligible_school + contract_type { "permanent" } end trait :eligible_school do diff --git a/spec/features/admin/admin_checks_further_education_payments_claim_spec.rb b/spec/features/admin/admin_checks_further_education_payments_claim_spec.rb new file mode 100644 index 0000000000..5a5f01983a --- /dev/null +++ b/spec/features/admin/admin_checks_further_education_payments_claim_spec.rb @@ -0,0 +1,5 @@ +require "rails_helper" + +RSpec.feature "Admin checks an Further Education Payments claim" do + it_behaves_like "Admin Checks", Policies::FurtherEducationPayments +end diff --git a/spec/features/admin/admin_claims_filtering_spec.rb b/spec/features/admin/admin_claims_filtering_spec.rb index 1efc8f778b..d6018c972d 100644 --- a/spec/features/admin/admin_claims_filtering_spec.rb +++ b/spec/features/admin/admin_claims_filtering_spec.rb @@ -22,7 +22,7 @@ let(:approved_awaiting_qa_claims) { create_list(:claim, 2, :approved, :flagged_for_qa, policy: Policies::LevellingUpPremiumPayments) } let(:auto_approved_awaiting_payroll_claims) { create_list(:claim, 2, :auto_approved, policy: Policies::LevellingUpPremiumPayments) } let(:approved_claim) { create(:claim, :approved, policy: Policies::LevellingUpPremiumPayments, assigned_to: mette, decision_creator: mary) } - let(:further_education_claims_awaiting_provider_verification) { create_list(:claim, 2, :submitted, policy: Policies::FurtherEducationPayments, eligibility_trait: :eligible, assigned_to: valentino) } + let(:further_education_claims_awaiting_provider_verification) { create_list(:claim, 2, :submitted, policy: Policies::FurtherEducationPayments, eligibility_trait: :not_verified, assigned_to: valentino) } let(:rejected_claim) { create(:claim, :rejected, policy: Policies::LevellingUpPremiumPayments, assigned_to: valentino) } let!(:claims) do @@ -74,8 +74,8 @@ scenario "the service operator can filter by themselves or other team members" do click_on "View claims" - expect(page.find("table")).to have_content("TSLR").exactly(5).times - expect(page.find("table")).to have_content("ECP").exactly(10).times + expect(page).to have_selector("td[text()='TSLR']", count: 5) + expect(page).to have_selector("td[text()='ECP']", count: 10) # Excludes payroll users and deleted users expect(page).to have_select("team_member", options: ["All", "Unassigned", "#{user.given_name} #{user.family_name}", "Mary Wasu Wabi", "Valentino Ricci", "Mette Jørgensen"]) @@ -109,7 +109,7 @@ select "Unassigned", from: "team_member" click_on "Apply filters" - expect(page.find("table")).to have_content("STRI").exactly(2).times + expect(page).to have_selector("td[text()='STRI']", count: 2) expect_page_to_show_claims(lup_claims_unassigned) end diff --git a/spec/jobs/further_education_payments/provider_verification_chase_email_spec.rb b/spec/jobs/further_education_payments/provider_verification_chase_email_spec.rb index 1e6d580952..d0726c1fc2 100644 --- a/spec/jobs/further_education_payments/provider_verification_chase_email_spec.rb +++ b/spec/jobs/further_education_payments/provider_verification_chase_email_spec.rb @@ -14,7 +14,7 @@ policy: Policies::FurtherEducationPayments, eligibility: build( :further_education_payments_eligibility, - :eligible + :not_verified )) } @@ -24,7 +24,7 @@ policy: Policies::FurtherEducationPayments, eligibility: build( :further_education_payments_eligibility, - :eligible, + :not_verified, provider_verification_email_last_sent_at: DateTime.new(2024, 10, 1, 7, 0, 0) )) } @@ -35,7 +35,7 @@ policy: Policies::FurtherEducationPayments, eligibility: build( :further_education_payments_eligibility, - :eligible, + :not_verified, provider_verification_email_last_sent_at: DateTime.new(2024, 10, 15, 7, 0, 0) )) } diff --git a/spec/models/automated_checks/claim_verifiers/student_loan_plan_spec.rb b/spec/models/automated_checks/claim_verifiers/student_loan_plan_spec.rb index 94188cb9e8..1849073be0 100644 --- a/spec/models/automated_checks/claim_verifiers/student_loan_plan_spec.rb +++ b/spec/models/automated_checks/claim_verifiers/student_loan_plan_spec.rb @@ -10,7 +10,7 @@ module ClaimVerifiers let(:claim_arg) { claim } let(:claim) { create(:claim, :submitted, policy:) } - shared_examples :execution_with_an_outcome do + shared_examples :creating_a_task_and_note do let(:saved_task) { claim_arg.tasks.find_by(name: "student_loan_plan") } let(:saved_note) { claim_arg.notes.last } @@ -49,7 +49,7 @@ module ClaimVerifiers end end - shared_examples :execution_without_an_outcome do + shared_examples :not_creating_a_task_or_note do it "does not save anything and returns immediately", :aggregate_failures do is_expected.to be_nil @@ -64,7 +64,7 @@ module ClaimVerifiers context "when the claim policy is TSLR" do let(:policy) { Policies::StudentLoans } - it_behaves_like :execution_without_an_outcome + it_behaves_like :not_creating_a_task_or_note end context "when the claim policy is ECP/LUP/FE" do @@ -79,14 +79,14 @@ module ClaimVerifiers let(:submitted_using_slc_data) { false } - it_behaves_like :execution_without_an_outcome + it_behaves_like :not_creating_a_task_or_note end context "when the claim was submitted using SLC data" do let(:submitted_using_slc_data) { true } let(:claim_student_loan_plan) { StudentLoan::PLAN_1 } - it_behaves_like :execution_without_an_outcome + it_behaves_like :not_creating_a_task_or_note end context "when the claim was not submitted using SLC data" do @@ -97,7 +97,7 @@ module ClaimVerifiers let(:expected_match_value) { nil } let(:expected_note) { "[SLC Student loan plan] - No data" } - it_behaves_like :execution_with_an_outcome + it_behaves_like :creating_a_task_and_note end context "when there is student loan data - with a plan" do @@ -109,7 +109,7 @@ module ClaimVerifiers let(:expected_match_value) { "all" } let(:expected_note) { "[SLC Student loan plan] - Matched - has a student loan" } - it_behaves_like :execution_with_an_outcome + it_behaves_like :creating_a_task_and_note end context "when there is student loan data - without a plan" do @@ -121,7 +121,7 @@ module ClaimVerifiers let(:expected_match_value) { "all" } let(:expected_note) { "[SLC Student loan plan] - Matched - does not have a student loan" } - it_behaves_like :execution_with_an_outcome + it_behaves_like :creating_a_task_and_note end end end diff --git a/spec/models/claim_spec.rb b/spec/models/claim_spec.rb index 5c56c2a7dc..b028feb62c 100644 --- a/spec/models/claim_spec.rb +++ b/spec/models/claim_spec.rb @@ -910,7 +910,7 @@ subject { described_class.awaiting_further_education_provider_verification } let!(:claim_with_fe_provider_verification) { create(:claim, policy: Policies::FurtherEducationPayments, eligibility_trait: :verified) } - let!(:claim_awaiting_fe_provider_verification) { create(:claim, policy: Policies::FurtherEducationPayments, eligibility_trait: :eligible) } + let!(:claim_awaiting_fe_provider_verification) { create(:claim, policy: Policies::FurtherEducationPayments, eligibility_trait: :not_verified) } let!(:non_fe_claim) { create(:claim, policy: Policies::StudentLoans) } it "returns claims that are awaiting FE provider verification" do diff --git a/spec/support/admin_checks_feature_shared_examples.rb b/spec/support/admin_checks_feature_shared_examples.rb index 38a3aaa522..4fd75536a5 100644 --- a/spec/support/admin_checks_feature_shared_examples.rb +++ b/spec/support/admin_checks_feature_shared_examples.rb @@ -15,6 +15,7 @@ before do @signed_in_user = sign_in_as_service_operator + create(:task, :automated, :passed, name: "student_loan_plan", claim:) end def lup_claim_checking_steps @@ -66,15 +67,13 @@ def lup_claim_checking_steps expect(claim.tasks.find_by!(name: "employment").passed?).to eq(true) - expect(page).to have_content(I18n.t("#{claim.policy.to_s.underscore}.admin.task_questions.student_loan_plan.title")) expect(page).to have_content("Student loan plan") expect(page).to have_link("Next: Decision") expect(page).to have_link("Previous: Employment") + expect(page).to have_content("Passed") + expect(page).not_to have_button("Save and continue") - choose "Yes" - click_on "Save and continue" - - expect(claim.tasks.find_by!(name: "student_loan_plan").passed?).to eq(true) + click_link "Next: Decision" expect(page).to have_content("Claim decision") expect(page).not_to have_link("Next") @@ -149,15 +148,13 @@ def ecp_claim_checking_steps expect(claim.tasks.find_by!(name: "employment").passed?).to eq(true) - expect(page).to have_content(I18n.t("#{claim.policy.to_s.underscore}.admin.task_questions.student_loan_plan.title")) expect(page).to have_content("Student loan plan") expect(page).to have_link("Next: Decision") expect(page).to have_link("Previous: Employment") + expect(page).to have_content("Passed") + expect(page).not_to have_button("Save and continue") - choose "Yes" - click_on "Save and continue" - - expect(claim.tasks.find_by!(name: "student_loan_plan").passed?).to eq(true) + click_link "Next: Decision" expect(page).to have_content("Claim decision") expect(page).not_to have_link("Next") @@ -243,6 +240,51 @@ def tslr_claim_checking_steps expect(claim.latest_decision.created_by).to eq(@signed_in_user) end + def fe_claim_checking_steps + visit admin_claims_path + find("a[href='#{admin_claim_tasks_path(claim)}']").click + + click_on I18n.t("admin.tasks.identity_confirmation.title") + + expect(page).to have_content(I18n.t("#{claim.policy.to_s.underscore}.admin.task_questions.identity_confirmation.title")) + expect(page).to have_link("Next: Provider verification") + expect(page).not_to have_link("Previous") + + choose "Yes" + click_on "Save and continue" + + expect(claim.tasks.find_by!(name: "identity_confirmation").passed?).to eq(true) + + expect(page).to have_content(I18n.t("#{claim.policy.to_s.underscore}.admin.task_questions.provider_verification.title")) + expect(page).to have_link("Next: Student loan plan") + expect(page).to have_link("Previous: Identity confirmation") + + choose "Yes" + click_on "Save and continue" + + expect(claim.tasks.find_by!(name: "provider_verification").passed?).to eq(true) + + expect(page).to have_content("Student loan plan") + expect(page).to have_content("Passed") + expect(page).not_to have_button("Save and continue") + expect(page).to have_link("Next: Decision") + expect(page).to have_link("Previous: Provider verification") + + click_link "Next: Decision" + + expect(page).to have_content("Claim decision") + expect(page).not_to have_link("Next") + expect(page).to have_link("Previous: Student loan plan") + + choose "Approve" + fill_in "Decision notes", with: "All checks passed!" + click_on "Confirm decision" + + expect(page).to have_content("Claim has been approved successfully") + expect(claim.latest_decision).to be_approved + expect(claim.latest_decision.created_by).to eq(@signed_in_user) + end + def qa_approval_steps expect(page).to have_content("This claim has been marked for a quality assurance review") expect(page).to have_content("Quality assurance decision") @@ -269,6 +311,8 @@ def claim_checking_steps(policy) ecp_claim_checking_steps elsif policy == Policies::StudentLoans tslr_claim_checking_steps + elsif policy == Policies::FurtherEducationPayments + fe_claim_checking_steps else raise "Unimplemented policy: #{policy}" end @@ -281,7 +325,7 @@ def claim_checking_steps(policy) claim_checking_steps(policy) end - scenario "service operator QAs a #{policy_name} claim" do + scenario "service operator QAs a #{policy_name} claim", if: policy::MIN_QA_THRESHOLD.positive? do claim_checking_steps(policy) qa_approval_steps end