Skip to content

Commit

Permalink
[LUPEYALPHA-1061] Practitioner invalid reference screen (#3279)
Browse files Browse the repository at this point in the history
  • Loading branch information
vacabor authored Oct 7, 2024
1 parent dc656f2 commit 94d94a1
Show file tree
Hide file tree
Showing 9 changed files with 106 additions and 50 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,14 @@ class FindReferenceForm < Form
attribute :email, :string

validates :reference_number, presence: {message: i18n_error_message(:presence)}
validate :validate_permissible_reference_number

def save
return false if invalid?

journey_session.answers.assign_attributes(
reference_number:,
start_email: email
start_email: email,
reference_number_found: claim_exists?
)
journey_session.save!
end
Expand All @@ -27,16 +27,6 @@ def claim_exists?
.where(practitioner_email_address: email)
.exists?
end

def validate_permissible_reference_number
unless claim_exists?
errors.add(
:reference_number,
:impermissible,
message: self.class.i18n_error_message(:impermissible)
)
end
end
end
end
end
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ module EarlyYearsPayment
module Practitioner
class SessionAnswers < Journeys::SessionAnswers
attribute :reference_number, :string
attribute :reference_number_found, :boolean, default: nil
attribute :start_email, :string

def policy
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ module Journeys
module EarlyYearsPayment
module Practitioner
class SlugSequence
SLUGS = %w[
CLAIM_SLUGS = %w[
find-reference
sign-in
how-we-use-your-information
Expand All @@ -14,6 +14,12 @@ class SlugSequence
check-your-answers
].freeze

RESULTS_SLUGS = %w[
ineligible
].freeze

SLUGS = (CLAIM_SLUGS + RESULTS_SLUGS).freeze

def self.start_page_url
Rails.application.routes.url_helpers.landing_page_path("early-years-payment-practitioner")
end
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ def ineligible?
end

def ineligibility_reason
start_ineligibility_reason || authenticated_ineligibility_reason
start_ineligibility_reason || provider_ineligibility_reason || practitioner_ineligibility_reason
end

def start_ineligibility_reason
Expand All @@ -31,7 +31,7 @@ def start_ineligibility_reason
end
end

def authenticated_ineligibility_reason
def provider_ineligibility_reason
return nil unless answers.is_a?(Journeys::EarlyYearsPayment::Provider::Authenticated::SessionAnswers)

if answers.nursery_urn.to_s == "none_of_the_above"
Expand All @@ -43,6 +43,14 @@ def authenticated_ineligibility_reason
end
end

def practitioner_ineligibility_reason
return nil unless answers.is_a?(Journeys::EarlyYearsPayment::Practitioner::SessionAnswers)

if answers.reference_number_found == false
:reference_number_not_found
end
end

private

def ineligible_returner?
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
<% content_for(:page_title, page_title("There is a problem", journey: current_journey_routing_name)) %>
<% @backlink_path = claim_path(current_journey_routing_name, "find-reference", request.query_parameters) %>

<div class="govuk-grid-row">
<div class="govuk-grid-column-two-thirds">
<h1 class="govuk-heading-l">
There is a problem
</h1>
<p class="govuk-body">
This claim reference isn’t correct. Check your invite email.
</p>

<p class="govuk-body">
Your employer will also have the claim reference in their claim confirmation email.
</p>

<p class="govuk-body">
Contact us at
<%= govuk_link_to t("early_years_payment_practitioner.feedback_email"), "mailto:#{t("early_years_payment_practitioner.feedback_email")}", no_visited_state: true %>.
if you need further assistance to sign into the early years financial incentive payments service.
</p>

<%= govuk_button_link_to "Try again", claim_path(current_journey_routing_name, "find-reference", request.query_parameters) %>
</div>
</div>
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
<% ineligibility_reason = Journeys::EarlyYearsPayment::Practitioner::EligibilityChecker.new(journey_session:).ineligibility_reason %>
<%= render "ineligibility_#{ineligibility_reason}" %>
5 changes: 2 additions & 3 deletions config/locales/en.yml
Original file line number Diff line number Diff line change
Expand Up @@ -1392,15 +1392,14 @@ en:
claim_subject: "Early Years Payment"
early_years_payment_practitioner:
journey_name: Claim an early years financial incentive payment - practitioner
feedback_email: implementme@example.com
support_email: "help@opsteam.com"
feedback_email: "help@opsteam.education.gov.uk"
support_email: "help@opsteam.education.gov.uk"
claim_description: for early years financial incentive payment
forms:
find_reference:
question: Enter your claim reference
errors:
presence: Enter your claim reference number
impermissible: Enter a valid claim reference number
email_address:
label: Your email address
hint1: We’ll use this to update you with progress on your claim.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,17 +18,13 @@
fill_in "Claim reference number", with: claim.reference
click_button "Submit"

expect(page).to have_content "Enter your claim reference"
expect(page).to have_content "This claim reference isn’t correct."
end

scenario "after multiple attempts should work" do
when_early_years_payment_practitioner_journey_configuration_exists

visit "/early-years-payment-practitioner/find-reference?skip_landing_page=true&email=user@example.com"
expect(page).to have_content "Enter your claim reference"
fill_in "Claim reference number", with: "foo"
click_button "Submit"

expect(page).to have_content "Enter your claim reference"
fill_in "Claim reference number", with: claim.reference
click_button "Submit"
Expand All @@ -41,4 +37,25 @@
click_button "Submit"
expect(page).to have_content "Sign in with GOV.UK One Login"
end

scenario "should show ineligibility page when an invalid reference is given" do
when_early_years_payment_practitioner_journey_configuration_exists

visit "/early-years-payment-practitioner/find-reference?skip_landing_page=true&email=user@example.com"
expect(page).to have_content "Enter your claim reference"
fill_in "Claim reference number", with: "invalid"
click_button "Submit"

expect(page).to have_content "This claim reference isn’t correct."
click_link "Try again"

expect(page).to have_content "Enter your claim reference"
fill_in "Claim reference number", with: "also invalid"
click_button "Submit"

expect(page).to have_content "This claim reference isn’t correct."
click_link "Back"

expect(page).to have_content "Enter your claim reference"
end
end
Original file line number Diff line number Diff line change
Expand Up @@ -21,33 +21,6 @@
end
end

context "when random string" do
let(:reference_number) { "foo" }

it "is not valid" do
expect(subject).to be_invalid
expect(subject.errors[:reference_number]).to be_present
end
end

context "when non EY claim" do
let(:reference_number) { claim.reference }
let(:email) { claim.practitioner_email_address }

let(:claim) do
create(
:claim,
reference: "foo",
practitioner_email_address: "user@example.com"
)
end

it "is not valid" do
expect(subject).to be_invalid
expect(subject.errors[:reference_number]).to be_present
end
end

context "when EY claim" do
let(:reference_number) { claim.reference }
let(:email) { claim.practitioner_email_address }
Expand Down Expand Up @@ -84,5 +57,40 @@
subject.save
}.to change { journey_session.reload.answers.reference_number }.from(nil).to(reference_number)
end

it "updates reference_number_found in session" do
expect {
subject.save
}.to change { journey_session.reload.answers.reference_number_found }.from(nil).to(true)
end

context "when reference is a random string" do
let(:reference_number) { "foo" }

it "updates reference_number_found in session" do
expect {
subject.save
}.to change { journey_session.reload.answers.reference_number_found }.from(nil).to(false)
end
end

context "when reference is a non EY claim" do
let(:reference_number) { claim.reference }
let(:email) { claim.practitioner_email_address }

let(:claim) do
create(
:claim,
reference: "foo",
practitioner_email_address: "user@example.com"
)
end

it "updates reference_number_found in session" do
expect {
subject.save
}.to change { journey_session.reload.answers.reference_number_found }.from(nil).to(false)
end
end
end
end

0 comments on commit 94d94a1

Please sign in to comment.