From 51a83fee9ff77c9a0c9eea1ce10ac43793118d0e Mon Sep 17 00:00:00 2001 From: Matthew Somerville Date: Fri, 14 Oct 2016 14:01:42 +0100 Subject: Fix list of response templates for a problem. Instead of returning all templates for the problem's body, return those for the problem's category (or with no category). --- t/app/model/problem.t | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 't/app/model/problem.t') diff --git a/t/app/model/problem.t b/t/app/model/problem.t index 836e8a047..bd7d0e55c 100644 --- a/t/app/model/problem.t +++ b/t/app/model/problem.t @@ -749,6 +749,20 @@ subtest 'check reports from abuser not sent' => sub { ok $abuse->delete(), 'user removed from abuse table'; }; +subtest 'check response templates' => sub { + my $c1 = $mech->create_contact_ok(category => 'Potholes', body_id => $body_ids{2651}, email => 'p'); + my $c2 = $mech->create_contact_ok(category => 'Graffiti', body_id => $body_ids{2651}, email => 'g'); + my $t1 = FixMyStreet::DB->resultset('ResponseTemplate')->create({ body_id => $body_ids{2651}, title => "Title 1", text => "Text 1" }); + my $t2 = FixMyStreet::DB->resultset('ResponseTemplate')->create({ body_id => $body_ids{2651}, title => "Title 2", text => "Text 2" }); + my $t3 = FixMyStreet::DB->resultset('ResponseTemplate')->create({ body_id => $body_ids{2651}, title => "Title 3", text => "Text 3" }); + $t1->add_to_contacts($c1); + $t2->add_to_contacts($c2); + my ($problem) = $mech->create_problems_for_body(1, $body_ids{2651}, 'TITLE'); + is $problem->response_templates, 1, 'Only the global template returned'; + ($problem) = $mech->create_problems_for_body(1, $body_ids{2651}, 'TITLE', { category => 'Potholes' }); + is $problem->response_templates, 2, 'Global and pothole templates returned'; +}; + END { $problem->comments->delete if $problem; $problem->delete if $problem; -- cgit v1.2.3