Skip to content

Commit

Permalink
LUPEYALPHA-955 - Add identity confirmation task to FE that auto passes
Browse files Browse the repository at this point in the history
* Show task outcome with OneLogin timestamp
* Tidy up status tags with tasks
  • Loading branch information
kenfodder committed Sep 9, 2024
1 parent b1571e5 commit 70130b0
Show file tree
Hide file tree
Showing 8 changed files with 115 additions and 14 deletions.
2 changes: 1 addition & 1 deletion app/helpers/admin/claims_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,7 @@ def matching_attributes(first_claim, second_claim)
def identity_confirmation_task_claim_verifier_match_status_tag(claim)
task = claim.tasks.detect { |t| t.name == "identity_confirmation" }

if task.nil? || task.claim_verifier_match.nil?
if task.nil?
status = "Unverified"
status_colour = "grey"
elsif task.passed?
Expand Down
8 changes: 5 additions & 3 deletions app/models/automated_checks/claim_verifiers/identity.rb
Original file line number Diff line number Diff line change
Expand Up @@ -18,16 +18,18 @@ def perform
return unless awaiting_task?(TASK_NAME)

# Order of matching matters so that subsequent conditions in methods fall through to execute the right thing
no_match ||
partial_match ||
complete_match
auto_pass || no_match || partial_match || complete_match
end

private

attr_accessor :admin_user, :claim
attr_reader :dqt_teacher_status

def auto_pass
create_task(match: nil, passed: true) if claim.policy.further_education_payments?
end

def dqt_teacher_status=(dqt_teacher_status)
@dqt_teacher_status = if dqt_teacher_status.instance_of?(Array)
dqt_teacher_status.first
Expand Down
1 change: 1 addition & 0 deletions app/models/policies/further_education_payments.rb
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ module FurtherEducationPayments
MIN_QA_THRESHOLD = 10

VERIFIERS = [
AutomatedChecks::ClaimVerifiers::Identity,
AutomatedChecks::ClaimVerifiers::ProviderVerification,
AutomatedChecks::ClaimVerifiers::Employment
]
Expand Down
2 changes: 2 additions & 0 deletions app/views/admin/tasks/_task_outcome.html.erb
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@
This task was performed by <%= user_details(task.created_by, include_line_break: false) %> on <%= l(task.updated_at) %>
<% elsif task.created_by %>
This task was performed by an automated check uploaded by <%= user_details(task.created_by, include_line_break: false) %> on <%= l(task.created_at) %>
<% elsif onelogin_auth_at = task.claim.onelogin_auth_at %>
This task was performed by GOV.UK One Login on <%= l(onelogin_auth_at) %>
<% else %>
This task was performed by an automated check on <%= l(task.created_at) %>
<% end %>
Expand Down
2 changes: 1 addition & 1 deletion app/views/admin/tasks/identity_confirmation.html.erb
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
<h2 class="govuk-heading-l"><%= @current_task_name.humanize %></h2>
</div>

<% unless @claim.identity_verified? %>
<% unless @claim.identity_verified? || @tasks_presenter.identity_confirmation.empty? %>
<div class="govuk-grid-column-two-thirds">
<%= render "admin/claims/answers", answers: @tasks_presenter.identity_confirmation %>
</div>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -332,10 +332,8 @@
)
end

it "creates the provider verification task" do
task = claim.reload.tasks.last

expect(task.name).to eq("provider_verification")
it "creates a provider verification task" do
task = claim.reload.tasks.find_by(name: "provider_verification")

expect(task.created_by.email).to eq(
"[email protected]"
Expand Down
60 changes: 57 additions & 3 deletions spec/helpers/admin/claims_helper_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -227,7 +227,61 @@
end
end

context "with task" do
context "with task passed nil" do
let(:claim_tasks) do
[
build(
:task,
claim_verifier_match: task_claim_verifier_match,
name: "identity_confirmation",
passed: nil
)
]
end

context "with task claim verifier match any" do
let(:task_claim_verifier_match) { :any }

it "returns partial match status tag" do
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("Partial match")
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("govuk-tag app-task-list__task-completed")
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("govuk-tag--yellow")
end
end

context "with task claim verifier match none" do
let(:task_claim_verifier_match) { :none }

it "returns no match status tag" do
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("No match")
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("govuk-tag app-task-list__task-completed")
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("govuk-tag--red")
end
end
end

# TODO: Don't think this condition is ever used as identity confirmation task is never failed
# However adding this purely for coverage of the condition that is available
context "with task passed false" do
let(:claim_tasks) do
[
build(
:task,
claim_verifier_match: nil,
name: "identity_confirmation",
passed: false
)
]
end

it "returns failed task status tag" do
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("Failed")
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("govuk-tag app-task-list__task-completed")
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("govuk-tag--red")
end
end

context "with task passed true" do
let(:claim_tasks) do
[
build(
Expand All @@ -243,9 +297,9 @@
let(:task_claim_verifier_match) { nil }

it "returns unverified task status tag" do
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("Unverified")
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("Passed")
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("govuk-tag app-task-list__task-completed")
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("govuk-tag--grey")
expect(identity_confirmation_task_claim_verifier_match_status_tag).to match("govuk-tag--green")
end
end

Expand Down
48 changes: 46 additions & 2 deletions spec/models/automated_checks/claim_verifiers/identity_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,50 @@ module ClaimVerifiers
}
end

describe "#perform with auto pass for FurtherEducationPayments" do
let(:policy) { Policies::FurtherEducationPayments }
let(:data) do
{
dob: claim_arg.date_of_birth,
name: claim_arg.full_name,
nino: claim_arg.national_insurance_number,
trn: claim_arg.eligibility.teacher_reference_number
}
end

subject(:perform) { identity.perform }

describe "identity confirmation task" do
subject(:identity_confirmation_task) { claim_arg.tasks.find_by(name: "identity_confirmation") }

before { perform }

describe "#claim_verifier_match" do
subject(:claim_verifier_match) { identity_confirmation_task.claim_verifier_match }

it { is_expected.to eq nil }
end

describe "#passed" do
subject(:passed) { identity_confirmation_task.passed }

it { is_expected.to eq true }
end

describe "#created_by" do
subject(:created_by) { identity_confirmation_task.created_by }

it { is_expected.to eq nil }
end

describe "#manual" do
subject(:manual) { identity_confirmation_task.manual }

it { is_expected.to eq false }
end
end
end

describe "#perform" do
subject(:perform) { identity.perform }

Expand Down Expand Up @@ -553,7 +597,7 @@ module ClaimVerifiers
national_insurance_number: "QQ100000C",
reference: "AB123456",
surname: "ELIGIBLE",
tasks: [build(:task, name: :identity_confirmation)],
tasks: [build(:task, name: :identity_confirmation, claim_verifier_match: :all)],
eligibility_attributes: {teacher_reference_number: "1234567"}
)
end
Expand All @@ -568,7 +612,7 @@ module ClaimVerifiers
describe "#claim_verifier_match" do
subject(:claim_verifier_match) { identity_confirmation_task.claim_verifier_match }

it { is_expected.to eq nil }
it { is_expected.to eq "all" }
end

describe "#created_by" do
Expand Down

0 comments on commit 70130b0

Please sign in to comment.