aboutsummaryrefslogtreecommitdiffstats
path: root/t/app/controller
diff options
context:
space:
mode:
authorStruan Donald <struan@exo.org.uk>2017-10-26 10:26:36 +0100
committerStruan Donald <struan@exo.org.uk>2017-10-27 12:25:07 +0100
commit8eadf44dd462fd3016f9b70b79bfeacd6147ef12 (patch)
tree49cd729f08a95d9a65186f153d4b34f1358831bb /t/app/controller
parent27cab90573fb1c68076adf252a161687fa981b9c (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.t152
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();