diff options
author | Struan Donald <struan@exo.org.uk> | 2017-10-26 10:26:36 +0100 |
---|---|---|
committer | Struan Donald <struan@exo.org.uk> | 2017-10-27 12:25:07 +0100 |
commit | 8eadf44dd462fd3016f9b70b79bfeacd6147ef12 (patch) | |
tree | 49cd729f08a95d9a65186f153d4b34f1358831bb /t/app/controller | |
parent | 27cab90573fb1c68076adf252a161687fa981b9c (diff) |
always allow problems to be removed from shortlist
If a user is trying to remove a problem from their shortlist we should
always allow it regardless of the state of the problem. Previously if a
problem wasn't displayed on the site then it could not be removed from
the shortlist which was an issue with council cobrands and reports that
had changed body.
Fixes mysociety/fixmystreetforcouncils#243
Diffstat (limited to 't/app/controller')
-rw-r--r-- | t/app/controller/my_planned.t | 152 |
1 files changed, 152 insertions, 0 deletions
diff --git a/t/app/controller/my_planned.t b/t/app/controller/my_planned.t index 51ea0297e..67d59e148 100644 --- a/t/app/controller/my_planned.t +++ b/t/app/controller/my_planned.t @@ -5,6 +5,7 @@ $mech->get_ok('/my/planned'); is $mech->uri->path, '/auth', "got sent to the sign in page"; my $body = $mech->create_body_ok(2237, 'Oxfordshire County Council'); +my $body2 = $mech->create_body_ok(2421, 'Oxford City Council'); my ($problem) = $mech->create_problems_for_body(1, $body->id, 'Test Title'); $mech->get_ok($problem->url); @@ -77,4 +78,155 @@ subtest "POSTing multiple problems to my/planned/change adds all to shortlist" = $mech->text_contains('Shortlisted'); }; +subtest "re-ordering shortlist on non shortlist page redirect to shortlist" => sub { + $user->user_planned_reports->remove(); + my ($problem1) = $mech->create_problems_for_body(1, $body->id, 'New Problem'); + + $mech->get_ok($problem1->url); + my ($csrf) = $mech->content =~ /meta content="([^"]*)" name="csrf-token"/; + + $mech->post_ok( '/my/planned/change', { + id => $problem1->id, + 'shortlist-up' => 1, + token => $csrf, + }, + ); + + $mech->content_contains('Your shortlist'); +}; + +subtest "shortlist with no action is forbidden" => sub { + $user->user_planned_reports->remove(); + my ($problem1) = $mech->create_problems_for_body(1, $body->id, 'New Problem'); + + $mech->get_ok($problem1->url); + my ($csrf) = $mech->content =~ /meta content="([^"]*)" name="csrf-token"/; + + my $result = $mech->post( '/my/planned/change', { + id => $problem1->id, + token => $csrf, + }, + ); + + is $result->code, 403, '403 response if no action'; +}; + +subtest "cannot remove non-existant problems from shortlist" => sub { + $user->user_planned_reports->remove(); + my ($problem1) = $mech->create_problems_for_body(1, $body->id, 'New Problem'); + + $mech->get_ok($problem1->url); + my ($csrf) = $mech->content =~ /meta content="([^"]*)" name="csrf-token"/; + + my $result = $mech->post( '/my/planned/change', { + id => 999, + 'shortlist-remove' => 1, + token => $csrf, + }, + ); + + is $result->code, 404, 'removing missing report returns 404'; +}; + +subtest "can remove problems from shortlist" => sub { + $user->user_planned_reports->remove(); + my ($problem1, $problem2) = $mech->create_problems_for_body(2, $body->id, 'New Problem'); + + $mech->get_ok($problem1->url); + my ($csrf) = $mech->content =~ /meta content="([^"]*)" name="csrf-token"/; + + $mech->post_ok( '/my/planned/change_multiple', { + 'ids[]' => [ + $problem1->id, + $problem2->id, + ], + token => $csrf, + } + ); + + $mech->get_ok($problem1->url); + $mech->text_contains('Shortlisted'); + + ($csrf) = $mech->content =~ /meta content="([^"]*)" name="csrf-token"/; + + $mech->post_ok( '/my/planned/change', { + id => $problem1->id, + 'shortlist-remove' => 1, + token => $csrf, + }, + 'Removed problem from shortlist'); + + $mech->get_ok($problem1->url); + $mech->text_lacks('Shortlisted'); + $mech->text_contains('Shortlist'); + + # check cases where problem has changed body due + # to e.g. change of category + $problem2->update({ + bodies_str => $body2->id, + title => 'Other body problem', + }); + + $mech->get_ok('/my/planned'); + $mech->text_contains('Other body problem'); + + ($csrf) = $mech->content =~ /meta content="([^"]*)" name="csrf-token"/; + + $mech->post_ok( '/my/planned/change', { + id => $problem2->id, + 'shortlist-remove' => 1, + token => $csrf, + }, + 'Removed problem for other body from shortlist'); + + $mech->get_ok('/my/planned'); + $mech->text_lacks('Other body problem'); +}; + +FixMyStreet::override_config { + ALLOWED_COBRANDS => [ 'oxfordshire' ], + BASE_URL => 'http://oxfordshire.fixmystreet.site', +}, sub { + subtest "can remove problems not displayed in cobrand from shortlist" => sub { + $user->user_planned_reports->remove(); + my ($problem1) = $mech->create_problems_for_body(2, $body->id, 'New Problem'); + + $mech->get_ok($problem1->url); + my ($csrf) = $mech->content =~ /meta content="([^"]*)" name="csrf-token"/; + + $mech->post_ok( '/my/planned/change_multiple', { + 'ids[]' => [ + $problem1->id, + ], + token => $csrf, + } + ); + + $mech->get_ok('/my/planned'); + $mech->text_contains('New Problem'); + $mech->content_contains('Remove from shortlist'); + + $problem1->update({ + bodies_str => $body2->id, + }); + + $mech->get_ok('/my/planned'); + $mech->text_contains('New Problem'); + $mech->content_contains('Remove from shortlist'); + + ($csrf) = $mech->content =~ /meta content="([^"]*)" name="csrf-token"/; + + $mech->post_ok( '/my/planned/change', { + id => $problem1->id, + 'shortlist-remove' => 1, + token => $csrf, + ajax => 1, + }, + 'Removed problem not displayed in this cobrand'); + + $mech->get_ok('/my/planned'); + $mech->text_lacks('New Problem', 'Problem no longer in shortlist'); + }; +}; + done_testing(); |