use strict; use warnings; use Test::More; use FixMyStreet::TestMech; my $mech = FixMyStreet::TestMech->new; my $secret = FixMyStreet::App->model('DB::Secret')->search(); # don't explode if there's nothing in the secret table if ( $secret == 0 ) { diag "You need to put an entry in the secret table for the admin tests to run"; plan skip_all => 'No entry in secret table'; } my $user = FixMyStreet::App->model('DB::User') ->find_or_create( { email => 'test@example.com', name => 'Test User' } ); ok $user, "created test user"; my $user2 = FixMyStreet::App->model('DB::User') ->find_or_create( { email => 'test2@example.com', name => 'Test User 2' } ); ok $user2, "created second test user"; my $user3 = FixMyStreet::App->model('DB::User') ->find( { email => 'test3@example.com', name => 'Test User 2' } ); if ( $user3 ) { $mech->delete_user( $user3 ); } my $dt = DateTime->new( year => 2011, month => 04, day => 16, hour => 15, minute => 47, second => 23 ); my $report = FixMyStreet::App->model('DB::Problem')->find_or_create( { postcode => 'SW1A 1AA', bodies_str => '2504', areas => ',105255,11806,11828,2247,2504,', category => 'Other', title => 'Report to Edit', detail => 'Detail for Report to Edit', used_map => 't', name => 'Test User', anonymous => 'f', external_id => '13', state => 'confirmed', confirmed => $dt->ymd . ' ' . $dt->hms, lang => 'en-gb', service => '', cobrand => '', cobrand_data => '', send_questionnaire => 't', latitude => '51.5016605453401', longitude => '-0.142497580865087', user_id => $user->id, whensent => $dt->ymd . ' ' . $dt->hms, } ); my $alert = FixMyStreet::App->model('DB::Alert')->find_or_create( { alert_type => 'new_updates', parameter => $report->id, confirmed => 1, user => $user, }, ); subtest 'check summary counts' => sub { my $problems = FixMyStreet::App->model('DB::Problem')->search( { state => { -in => [qw/confirmed fixed closed investigating planned/, 'in progress', 'fixed - user', 'fixed - council'] } } ); ok $mech->host('www.fixmystreet.com'); my $problem_count = $problems->count; $problems->update( { cobrand => '' } ); FixMyStreet::App->model('DB::Problem')->search( { bodies_str => 2489 } )->update( { bodies_str => 1 } ); my $q = FixMyStreet::App->model('DB::Questionnaire')->find_or_new( { problem => $report, }); $q->whensent( \'current_timestamp' ); $q->in_storage ? $q->update : $q->insert; my $alerts = FixMyStreet::App->model('DB::Alert')->search( { confirmed => { '>' => 0 } } ); my $a_count = $alerts->count; FixMyStreet::override_config { ALLOWED_COBRANDS => [ 'fixmystreet' ], }, sub { $mech->get_ok('/admin'); }; $mech->title_like(qr/Summary/); $mech->content_contains( "$problem_count live problems" ); $mech->content_contains( "$a_count confirmed alerts" ); my $questionnaires = FixMyStreet::App->model('DB::Questionnaire')->search( { whensent => { -not => undef } } ); my $q_count = $questionnaires->count(); $mech->content_contains( "$q_count questionnaires sent" ); FixMyStreet::override_config { ALLOWED_COBRANDS => [ 'barnet' ], }, sub { ok $mech->host('barnet.fixmystreet.com'); $mech->get_ok('/admin'); $mech->title_like(qr/Summary/); my ($num_live) = $mech->content =~ /(\d+)<\/strong> live problems/; my ($num_alerts) = $mech->content =~ /(\d+) confirmed alerts/; my ($num_qs) = $mech->content =~ /(\d+) questionnaires sent/; $report->bodies_str(2489); $report->cobrand('barnet'); $report->update; $alert->cobrand('barnet'); $alert->update; $mech->get_ok('/admin'); $mech->content_contains( ($num_live+1) . " live problems" ); $mech->content_contains( ($num_alerts+1) . " confirmed alerts" ); $mech->content_contains( ($num_qs+1) . " questionnaires sent" ); $report->bodies_str(2504); $report->cobrand(''); $report->update; $alert->cobrand(''); $alert->update; }; FixMyStreet::App->model('DB::Problem')->search( { bodies_str => 1 } )->update( { bodies_str => 2489 } ); ok $mech->host('www.fixmystreet.com'); }; # This override is wrapped around ALL the /admin/body tests FixMyStreet::override_config { MAPIT_URL => 'http://mapit.mysociety.org/', MAPIT_TYPES => [ 'UTA' ], BASE_URL => 'http://www.example.org', }, sub { my $body = $mech->create_body_ok(2650, 'Aberdeen City Council'); $mech->get_ok('/admin/body/' . $body->id); $mech->content_contains('Aberdeen City Council'); $mech->content_like(qr{AB\d\d}); $mech->content_contains("http://www.example.org/around"); subtest 'check contact creation' => sub { my $contact = FixMyStreet::App->model('DB::Contact')->search( { body_id => $body->id, category => [ 'test category', 'test/category' ] } ); $contact->delete_all; my $history = FixMyStreet::App->model('DB::ContactsHistory')->search( { body_id => $body->id, category => [ 'test category', 'test/category' ] } ); $history->delete_all; $mech->get_ok('/admin/body/' . $body->id); $mech->submit_form_ok( { with_fields => { category => 'test category', email => 'test@example.com', note => 'test note', non_public => undef, } } ); $mech->content_contains( 'test category' ); $mech->content_contains( 'test@example.com' ); $mech->content_contains( 'test note' ); $mech->content_contains( 'Private: No' ); $mech->submit_form_ok( { with_fields => { category => 'private category', email => 'test@example.com', note => 'test note', non_public => 'on', } } ); $mech->content_contains( 'private category' ); $mech->content_contains( 'Private: Yes' ); $mech->submit_form_ok( { with_fields => { category => 'test/category', email => 'test@example.com', note => 'test/note', non_public => 'on', } } ); $mech->get_ok('/admin/body/' . $body->id . '/test/category'); }; subtest 'check contact editing' => sub { $mech->get_ok('/admin/body/' . $body->id .'/test%20category'); $mech->submit_form_ok( { with_fields => { email => 'test2@example.com', note => 'test2 note', non_public => undef, } } ); $mech->content_contains( 'test category' ); $mech->content_contains( 'test2@example.com' ); $mech->content_contains( 'test2 note' ); $mech->content_contains( 'Private: No' ); $mech->get_ok('/admin/body/' . $body->id . '/test%20category'); $mech->submit_form_ok( { with_fields => { email => 'test2@example.com', note => 'test2 note', non_public => 'on', } } ); $mech->content_contains( 'Private: Yes' ); $mech->get_ok('/admin/body/' . $body->id . '/test%20category'); $mech->content_contains( 'test2@example.com' ); }; subtest 'check contact updating' => sub { $mech->get_ok('/admin/body/' . $body->id . '/test%20category'); $mech->content_like(qr{test2\@example.com[^<]*[^<]*No}s); $mech->get_ok('/admin/body/' . $body->id); $mech->form_number( 1 ); $mech->tick( 'confirmed', 'test category' ); $mech->submit_form_ok({form_number => 1}); $mech->content_like(qr'test2@example.com[^<]*\s*Confirmed: Yes's); $mech->get_ok('/admin/body/' . $body->id . '/test%20category'); $mech->content_like(qr{test2\@example.com[^<]*[^<]*Yes}s); }; $body->update({ send_method => undef }); subtest 'check open311 configuring' => sub { $mech->get_ok('/admin/body/' . $body->id); $mech->content_lacks('Council contacts configured via Open311'); $mech->form_number(3); $mech->submit_form_ok( { with_fields => { api_key => 'api key', endpoint => 'http://example.com/open311', jurisdiction => 'mySociety', send_comments => 0, send_method => 'Open311', } } ); $mech->content_contains('Council contacts configured via Open311'); $mech->content_contains('Values updated'); my $conf = FixMyStreet::App->model('DB::Body')->find( $body->id ); is $conf->endpoint, 'http://example.com/open311', 'endpoint configured'; is $conf->api_key, 'api key', 'api key configured'; is $conf->jurisdiction, 'mySociety', 'jurisdiction configures'; $mech->form_number(3); $mech->submit_form_ok( { with_fields => { api_key => 'new api key', endpoint => 'http://example.org/open311', jurisdiction => 'open311', send_comments => 0, send_method => 'Open311', } } ); $mech->content_contains('Values updated'); $conf = FixMyStreet::App->model('DB::Body')->find( $body->id ); is $conf->endpoint, 'http://example.org/open311', 'endpoint updated'; is $conf->api_key, 'new api key', 'api key updated'; is $conf->jurisdiction, 'open311', 'jurisdiction configures'; }; subtest 'check text output' => sub { $mech->get_ok('/admin/body/' . $body->id . '?text=1'); is $mech->content_type, 'text/plain'; $mech->content_contains('test category'); }; }; # END of override wrap my $log_entries = FixMyStreet::App->model('DB::AdminLog')->search( { object_type => 'problem', object_id => $report->id }, { order_by => { -desc => 'id' }, } ); is $log_entries->count, 0, 'no admin log entries'; my $report_id = $report->id; ok $report, "created test report - $report_id"; foreach my $test ( { description => 'edit report title', fields => { title => 'Report to Edit', detail => 'Detail for Report to Edit', state => 'confirmed', name => 'Test User', email => $user->email, anonymous => 0, flagged => undef, non_public => undef, }, changes => { title => 'Edited Report', }, log_count => 1, log_entries => [qw/edit/], resend => 0, }, { description => 'edit report description', fields => { title => 'Edited Report', detail => 'Detail for Report to Edit', state => 'confirmed', name => 'Test User', email => $user->email, anonymous => 0, flagged => undef, non_public => undef, }, changes => { detail => 'Edited Detail', }, log_count => 2, log_entries => [qw/edit edit/], resend => 0, }, { description => 'edit report user name', fields => { title => 'Edited Report', detail => 'Edited Detail', state => 'confirmed', name => 'Test User', email => $user->email, anonymous => 0, flagged => undef, non_public => undef, }, changes => { name => 'Edited User', }, log_count => 3, log_entries => [qw/edit edit edit/], resend => 0, user => $user, }, { description => 'edit report set flagged true', fields => { title => 'Edited Report', detail => 'Edited Detail', state => 'confirmed', name => 'Edited User', email => $user->email, anonymous => 0, flagged => undef, non_public => undef, }, changes => { flagged => 'on', }, log_count => 4, log_entries => [qw/edit edit edit edit/], resend => 0, user => $user, }, { description => 'edit report user email', fields => { title => 'Edited Report', detail => 'Edited Detail', state => 'confirmed', name => 'Edited User', email => $user->email, anonymous => 0, flagged => 'on', non_public => undef, }, changes => { email => $user2->email, }, log_count => 5, log_entries => [qw/edit edit edit edit edit/], resend => 0, user => $user2, }, { description => 'change state to unconfirmed', fields => { title => 'Edited Report', detail => 'Edited Detail', state => 'confirmed', name => 'Edited User', email => $user2->email, anonymous => 0, flagged => 'on', non_public => undef, }, changes => { state => 'unconfirmed' }, log_count => 6, log_entries => [qw/state_change edit edit edit edit edit/], resend => 0, }, { description => 'change state to confirmed', fields => { title => 'Edited Report', detail => 'Edited Detail', state => 'unconfirmed', name => 'Edited User', email => $user2->email, anonymous => 0, flagged => 'on', non_public => undef, }, changes => { state => 'confirmed' }, log_count => 7, log_entries => [qw/state_change state_change edit edit edit edit edit/], resend => 0, }, { description => 'change state to fixed', fields => { title => 'Edited Report', detail => 'Edited Detail', state => 'confirmed', name => 'Edited User', email => $user2->email, anonymous => 0, flagged => 'on', non_public => undef, }, changes => { state => 'fixed' }, log_count => 8, log_entries => [qw/state_change state_change state_change edit edit edit edit edit/], resend => 0, }, { description => 'change state to hidden', fields => { title => 'Edited Report', detail => 'Edited Detail', state => 'fixed', name => 'Edited User', email => $user2->email, anonymous => 0, flagged => 'on', non_public => undef, }, changes => { state => 'hidden' }, log_count => 9, log_entries => [ qw/state_change state_change state_change state_change edit edit edit edit edit/ ], resend => 0, }, { description => 'edit and change state', fields => { title => 'Edited Report', detail => 'Edited Detail', state => 'hidden', name => 'Edited User', email => $user2->email, anonymous => 0, flagged => 'on', non_public => undef, }, changes => { state => 'confirmed', anonymous => 1, }, log_count => 11, log_entries => [ qw/edit state_change state_change state_change state_change state_change edit edit edit edit edit/ ], resend => 0, }, { description => 'resend', fields => { title => 'Edited Report', detail => 'Edited Detail', state => 'confirmed', name => 'Edited User', email => $user2->email, anonymous => 1, flagged => 'on', non_public => undef, }, changes => {}, log_count => 12, log_entries => [ qw/resend edit state_change state_change state_change state_change state_change edit edit edit edit edit/ ], resend => 1, }, { description => 'non public', fields => { title => 'Edited Report', detail => 'Edited Detail', state => '
= Spec::Rails

* http://rspec.info
* http://rubyforge.org/projects/rspec
* http://github.com/dchelimsky/rspec-rails
* http://wiki.github.com/dchelimsky/rspec/rails
* mailto:rspec-devel@rubyforge.org

== DESCRIPTION:

Behaviour Driven Development for Ruby on Rails.

rspec-rails is an RSpec extension that allows you to drive the development of
Ruby on Rails applications with RSpec.

This is the repository for rspec-rails-1.x. If you're looking
for rspec-rails-2 for rails-3, see http://github.com/rspec/rspec-rails.

== FEATURES:

* Use RSpec to independently specify Rails Models, Views, Controllers and Helpers
* Integrated fixture loading
* Special generators for Resources, Models, Views and Controllers that generate RSpec code examples.

== VISION:

For people for whom TDD is a brand new concept, the testing support built into
Ruby on Rails is a huge leap forward. The fact that it is built right in is
fantastic, and Ruby on Rails apps are generally much easier to maintain than
they might have been without such support.

For those of us coming from a history with TDD, and now BDD, the existing
support presents some problems related to dependencies across examples. To
that end, RSpec on Rails supports 4 types of examples. We’ve also built in
first class mocking and stubbing support in order to break dependencies across
these different concerns.

== MORE INFORMATION:

See Spec::Rails::Example for information about the different kinds of example
groups you can use to spec the different Rails components

See Spec::Rails::Matchers for information about Rails-specific
expectations you can set on responses and models, etc.

== INSTALL

* Visit http://wiki.github.com/dchelimsky/rspec/rails for installation instructions.
qw/edit edit edit edit/], user => $user2, }, { desc => 'edit update state', fields => { text => 'this is a changed update', state => 'confirmed', name => 'A User', anonymous => 0, email => 'test2@example.com', }, changes => { state => 'unconfirmed', }, log_count => 5, log_entries => [qw/state_change edit edit edit edit/], }, { desc => 'edit update state and text', fields => { text => 'this is a changed update', state => 'unconfirmed', name => 'A User', anonymous => 0, email => 'test2@example.com', }, changes => { text => 'this is a twice changed update', state => 'confirmed', }, log_count => 7, log_entries => [qw/edit state_change state_change edit edit edit edit/], }, ) { subtest $test->{desc} => sub { $log_entries->reset; $mech->get_ok('/admin/update_edit/' . $update->id ); is_deeply $mech->visible_form_values, $test->{fields}, 'initial form values'; my $to_submit = { %{ $test->{fields} }, %{ $test->{changes} } }; $mech->submit_form_ok( { with_fields => $to_submit } ); is_deeply $mech->visible_form_values, $to_submit, 'submitted form values'; is $log_entries->count, $test->{log_count}, 'number of log entries'; is $log_entries->next->action, $_, 'log action' for @{ $test->{log_entries} }; $update->discard_changes; is $update->$_, $test->{changes}->{$_} for grep { $_ ne 'email' } keys %{ $test->{changes} }; if ( $test->{changes}{state} && $test->{changes}{state} eq 'confirmed' ) { isnt $update->confirmed, undef; } if ( $test->{user} ) { is $update->user->id, $test->{user}->id, 'update user'; } }; } my $westminster = $mech->create_body_ok(2504, 'Westminster City Council'); $report->bodies_str($westminster->id); $report->update; for my $test ( { desc => 'user is problem owner', problem_user => $user, update_user => $user, update_fixed => 0, update_reopen => 0, update_state => undef, user_body => undef, content => 'user is problem owner', }, { desc => 'user is body user', problem_user => $user, update_user => $user2, update_fixed => 0, update_reopen => 0, update_state => undef, user_body => $westminster->id, content => 'user is from same council as problem - ' . $westminster->id, }, { desc => 'update changed problem state', problem_user => $user, update_user => $user2, update_fixed => 0, update_reopen => 0, update_state => 'planned', user_body => $westminster->id, content => 'Update changed problem state to planned', }, { desc => 'update marked problem as fixed', problem_user => $user, update_user => $user3, update_fixed => 1, update_reopen => 0, update_state => undef, user_body => undef, content => 'Update marked problem as fixed', }, { desc => 'update reopened problem', problem_user => $user, update_user => $user, update_fixed => 0, update_reopen => 1, update_state => undef, user_body => undef, content => 'Update reopened problem', }, ) { subtest $test->{desc} => sub { $report->user( $test->{problem_user} ); $report->update; $update->user( $test->{update_user} ); $update->problem_state( $test->{update_state} ); $update->mark_fixed( $test->{update_fixed} ); $update->mark_open( $test->{update_reopen} ); $update->update; $test->{update_user}->from_body( $test->{user_body} ); $test->{update_user}->update; $mech->get_ok('/admin/update_edit/' . $update->id ); $mech->content_contains( $test->{content} ); }; } subtest 'editing update email creates new user if required' => sub { my $user = FixMyStreet::App->model('DB::User')->find( { email => 'test4@example.com' } ); $user->delete if $user; my $fields = { text => 'this is a changed update', state => 'hidden', name => 'A User', anonymous => 0, email => 'test4@example.com', }; $mech->submit_form_ok( { with_fields => $fields } ); $user = FixMyStreet::App->model('DB::User')->find( { email => 'test4@example.com' } ); is_deeply $mech->visible_form_values, $fields, 'submitted form values'; ok $user, 'new user created'; $update->discard_changes; is $update->user->id, $user->id, 'update set to new user'; }; subtest 'adding email to abuse list from update page' => sub { my $email = $update->user->email; my $abuse = FixMyStreet::App->model('DB::Abuse')->find( { email => $email } ); $abuse->delete if $abuse; $mech->get_ok( '/admin/update_edit/' . $update->id ); $mech->content_contains('Ban email address'); $mech->click_ok('banuser'); $mech->content_contains('Email added to abuse list'); $mech->content_contains('(Email in abuse table)'); $abuse = FixMyStreet::App->model('DB::Abuse')->find( { email => $email } ); ok $abuse, 'entry created in abuse table'; $mech->get_ok( '/admin/update_edit/' . $update->id ); $mech->content_contains('(Email in abuse table)'); }; subtest 'flagging user from update page' => sub { $update->user->flagged(0); $update->user->update; $mech->get_ok( '/admin/update_edit/' . $update->id ); $mech->content_contains('Flag user'); $mech->click_ok('flaguser'); $mech->content_contains('User flagged'); $mech->content_contains('Remove flag'); $update->discard_changes; ok $update->user->flagged, 'user flagged'; $mech->get_ok( '/admin/update_edit/' . $update->id ); $mech->content_contains('Remove flag'); }; subtest 'unflagging user from update page' => sub { $update->user->flagged(1); $update->user->update; $mech->get_ok( '/admin/update_edit/' . $update->id ); $mech->content_contains('Remove flag'); $mech->click_ok('removeuserflag'); $mech->content_contains('User flag removed'); $mech->content_contains('Flag user'); $update->discard_changes; ok !$update->user->flagged, 'user not flagged'; $mech->get_ok( '/admin/update_edit/' . $update->id ); $mech->content_contains('Flag user'); }; subtest 'hiding comment marked as fixed reopens report' => sub { $update->mark_fixed( 1 ); $update->update; $report->state('fixed - user'); $report->update; my $fields = { text => 'this is a changed update', state => 'hidden', name => 'A User', anonymous => 0, email => 'test2@example.com', }; $mech->submit_form_ok( { with_fields => $fields } ); $report->discard_changes; is $report->state, 'confirmed', 'report reopened'; $mech->content_contains('Problem marked as open'); }; $log_entries->delete; subtest 'report search' => sub { $update->state('confirmed'); $update->user($report->user); $update->update; $mech->get_ok('/admin/reports'); $mech->get_ok('/admin/reports?search=' . $report->id ); $mech->content_contains( $report->title ); my $r_id = $report->id; $mech->content_like( qr{href="http://[^/]*[^.]/report/$r_id"[^>]*>$r_id} ); $mech->get_ok('/admin/reports?search=' . $report->external_id); $mech->content_like( qr{href="http://[^/]*[^.]/report/$r_id"[^>]*>$r_id} ); $mech->get_ok('/admin/reports?search=ref:' . $report->external_id); $mech->content_like( qr{href="http://[^/]*[^.]/report/$r_id"[^>]*>$r_id} ); $mech->get_ok('/admin/reports?search=' . $report->user->email); my $u_id = $update->id; $mech->content_like( qr{href="http://[^/]*[^.]/report/$r_id"[^>]*>$r_id} ); $mech->content_like( qr{href="http://[^/]*[^.]/report/$r_id#update_$u_id"[^>]*>$u_id} ); $update->state('hidden'); $update->update; $mech->get_ok('/admin/reports?search=' . $report->user->email); $mech->content_like( qr{]*hidden[^>]*> \s* \s* $u_id \s* }xs ); $report->state('hidden'); $report->update; $mech->get_ok('/admin/reports?search=' . $report->user->email); $mech->content_like( qr{]*hidden[^>]*> \s* ]*> \s* $r_id \s* }xs ); $report->state('fixed - user'); $report->update; $mech->get_ok('/admin/reports?search=' . $report->user->email); $mech->content_like( qr{href="http://[^/]*[^.]/report/$r_id"[^>]*>$r_id} ); }; subtest 'search abuse' => sub { $mech->get_ok( '/admin/users?search=example' ); $mech->content_like(qr{test4\@example.com.*\s*.*?\s*\(Email in abuse table}s); }; subtest 'show flagged entries' => sub { $report->flagged( 1 ); $report->update; $user->flagged( 1 ); $user->update; $mech->get_ok('/admin/flagged'); $mech->content_contains( $report->title ); $mech->content_contains( $user->email ); }; my $haringey = $mech->create_body_ok(2509, 'Haringey Borough Council'); subtest 'user search' => sub { $mech->get_ok('/admin/users'); $mech->get_ok('/admin/users?search=' . $user->name); $mech->content_contains( $user->name); my $u_id = $user->id; $mech->content_like( qr{user_edit/$u_id">Edit} ); $mech->get_ok('/admin/users?search=' . $user->email); $mech->content_like( qr{user_edit/$u_id">Edit} ); $user->from_body($haringey->id); $user->update; $mech->get_ok('/admin/users?search=' . $haringey->id ); $mech->content_contains('Haringey'); }; $log_entries = FixMyStreet::App->model('DB::AdminLog')->search( { object_type => 'user', object_id => $user->id }, { order_by => { -desc => 'id' }, } ); is $log_entries->count, 0, 'no admin log entries'; $user->flagged( 0 ); $user->update; my $southend = $mech->create_body_ok(2607, 'Southend-on-Sea Borough Council'); for my $test ( { desc => 'edit user name', fields => { name => 'Test User', email => 'test@example.com', body => $haringey->id, flagged => undef, }, changes => { name => 'Changed User', }, log_count => 1, log_entries => [qw/edit/], }, { desc => 'edit user email', fields => { name => 'Changed User', email => 'test@example.com', body => $haringey->id, flagged => undef, }, changes => { email => 'changed@example.com', }, log_count => 2, log_entries => [qw/edit edit/], }, { desc => 'edit user body', fields => { name => 'Changed User', email => 'changed@example.com', body => $haringey->id, flagged => undef, }, changes => { body => $southend->id, }, log_count => 3, log_entries => [qw/edit edit edit/], }, { desc => 'edit user flagged', fields => { name => 'Changed User', email => 'changed@example.com', body => $southend->id, flagged => undef, }, changes => { flagged => 'on', }, log_count => 4, log_entries => [qw/edit edit edit edit/], }, { desc => 'edit user remove flagged', fields => { name => 'Changed User', email => 'changed@example.com', body => $southend->id, flagged => 'on', }, changes => { flagged => undef, }, log_count => 4, log_entries => [qw/edit edit edit edit/], }, ) { subtest $test->{desc} => sub { $mech->get_ok( '/admin/user_edit/' . $user->id ); my $visible = $mech->visible_form_values; is_deeply $visible, $test->{fields}, 'expected user'; my $expected = { %{ $test->{fields} }, %{ $test->{changes} } }; $mech->submit_form_ok( { with_fields => $expected } ); $visible = $mech->visible_form_values; is_deeply $visible, $expected, 'user updated'; $mech->content_contains( 'Updated!' ); }; } subtest "Test setting a report from unconfirmed to something else doesn't cause a front end error" => sub { $report->update( { confirmed => undef, state => 'unconfirmed', non_public => 0 } ); $mech->get_ok("/admin/report_edit/$report_id"); $mech->submit_form_ok( { with_fields => { state => 'investigating' } } ); $report->discard_changes; ok( $report->confirmed, 'report has a confirmed timestamp' ); $mech->get_ok("/report/$report_id"); }; subtest "Check admin_base_url" => sub { my $rs = FixMyStreet::App->model('DB::Problem'); my $cobrand = FixMyStreet::Cobrand->get_class_for_moniker($report->cobrand)->new(); is (FixMyStreet::App->model('DB::Problem')->get_admin_url( $cobrand, $report), (sprintf 'https://secure.mysociety.org/admin/bci/report_edit/%d', $report_id), 'get_admin_url OK'); }; $mech->delete_user( $user ); $mech->delete_user( $user2 ); $mech->delete_user( $user3 ); $mech->delete_user( 'test4@example.com' ); done_testing();