From 19067ebfee8fab39feed3960a8f84b496fdb0b3c Mon Sep 17 00:00:00 2001 From: Matthew Somerville Date: Tue, 26 Nov 2024 14:57:50 +0000 Subject: [PATCH] [Bromley] Cope with second Echo referral on same report. If a report was originally sent to Echo, then referred to Bromley more than once, we do not want to send the report to Bromley more than once. --- perllib/FixMyStreet/Cobrand/Bromley.pm | 10 ++++++++-- t/cobrand/bromley.t | 26 ++++++++++++++++++++------ 2 files changed, 28 insertions(+), 8 deletions(-) diff --git a/perllib/FixMyStreet/Cobrand/Bromley.pm b/perllib/FixMyStreet/Cobrand/Bromley.pm index 761f529a1c4..f105bb290ae 100644 --- a/perllib/FixMyStreet/Cobrand/Bromley.pm +++ b/perllib/FixMyStreet/Cobrand/Bromley.pm @@ -449,14 +449,20 @@ sub open311_get_update_munging { $notes = $_->{Value} if $_->{DatatypeName} eq 'Veolia Notes'; } $problem->set_extra_metadata(handover_notes => $notes); + if (my $original_external_id = $problem->get_extra_metadata('original_bromley_external_id')) { + # Originally sent to Bromley, don't need to resend report $problem->external_id($original_external_id); $comment->problem_state(REFERRED_TO_BROMLEY); $comment->send_state('unprocessed'); - } else { - # Resending report, don't need comment to be public + } elsif ($self->_has_report_been_sent_to_echo($problem)) { + # Resending report from Echo to Bromley, don't need comment to be public $comment->state('hidden'); $problem->resend; + } else { + # Assume has already been sent to Bromley, no need to resend report + $comment->problem_state(REFERRED_TO_BROMLEY); + $comment->send_state('unprocessed'); } } } diff --git a/t/cobrand/bromley.t b/t/cobrand/bromley.t index 7db428e58c5..7a0f2d33131 100644 --- a/t/cobrand/bromley.t +++ b/t/cobrand/bromley.t @@ -836,16 +836,19 @@ subtest 'redirecting of reports between backends' => sub { is_deeply [ map { $_->state } $report->comments->order_by('id')->all ], ['hidden', 'hidden']; }; + + my $event_guid = '05a10cb2-44c9-48d9-92a2-cc6788994bae'; + subtest 'A report sent to Echo, redirected to Confirm' => sub { $report->comments->delete; $report->unset_extra_metadata('original_bromley_external_id'); - $report->update({ external_id => 'original-guid' }); + $report->update({ external_id => $event_guid }); $mech->post('/waste/echo', Content_Type => 'text/xml', Content => $in); is $report->comments->count, 1, 'A new update'; is_deeply [ map { $_->state } $report->comments->all ], ['hidden']; $report->discard_changes; is $report->whensent, undef; - is $report->external_id, 'original-guid', 'ID not changed'; + is $report->external_id, $event_guid, 'ID not changed'; is $report->state, 'in progress', 'A state change'; is $report->category, 'Environmental Services'; FixMyStreet::Script::Reports::send(); @@ -856,8 +859,19 @@ subtest 'redirecting of reports between backends' => sub { is $c->param('description'), "$detail | Handover notes - Outgoing notes from Echo"; }; + subtest 'A second referral update comes in, should be a normal update' => sub { + $report->update({ external_id => 'bromley-id' }); + $mech->post('/waste/echo', Content_Type => 'text/xml', Content => $in); + is $report->comments->count, 2, 'A new update'; + my @updates = $report->comments->order_by('id')->all; + is_deeply [ map { $_->state } @updates ], ['hidden', 'confirmed']; + is_deeply [ map { $_->problem_state } @updates ], ['in progress', 'Environmental Services']; + $report->discard_changes; + isnt $report->whensent, undef; # Got sent in last subtest + is $report->external_id, 'bromley-id', 'ID not changed'; + }; + subtest "comment on a closed echo report result in a resend under 'Street Services'" => sub { - my $event_guid = '05a10cb2-44c9-48d9-92a2-cc6788994bae'; my $event_id = 123; my $echo = Test::MockModule->new('Integrations::Echo'); @@ -924,8 +938,8 @@ subtest 'redirecting of reports between backends' => sub { }; subtest "Another update from Echo on this new sent report closes it again" => sub { - $report->update({ external_id => 'guid' }); - my $in = $mech->echo_notify_xml('guid', 2104, 15004, 67); + $report->update({ external_id => $event_guid }); + my $in = $mech->echo_notify_xml('guid', 2104, 15004, 67, 'FMS-' . $report->id); $mech->post('/waste/echo', Content_Type => 'text/xml', Content => $in); is $report->comments->count, 3, 'A new update'; $report->discard_changes; @@ -936,7 +950,7 @@ subtest 'redirecting of reports between backends' => sub { }; subtest "Echo then redirect it back to Confirm" => sub { - my $in = $mech->echo_notify_xml('guid', 2104, 15004, 1252); + my $in = $mech->echo_notify_xml('guid', 2104, 15004, 1252, 'FMS-' . $report->id); $mech->post('/waste/echo', Content_Type => 'text/xml', Content => $in); is $report->comments->count, 4, 'A new update'; $report->discard_changes;