X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Controller-DBIC-API.git;a=blobdiff_plain;f=t%2Frpc%2Fdelete.t;fp=t%2Frpc%2Fdelete.t;h=ffd649a319bf10250f540186485a7ad4161d9036;hp=109d1b20d685753fa7debd0adc58463fd6d2db90;hb=0b0bf9111127c9fdad1e456169ec4cdd15b160f9;hpb=e17f1f8e991b57bf9f7f23547c0c9af8b3012569 diff --git a/t/rpc/delete.t b/t/rpc/delete.t index 109d1b2..ffd649a 100644 --- a/t/rpc/delete.t +++ b/t/rpc/delete.t @@ -13,46 +13,53 @@ use DBICTest; use Test::More; use Test::WWW::Mechanize::Catalyst 'RestTest'; use HTTP::Request::Common; +use JSON; + +my $json = JSON->new->utf8; my $mech = Test::WWW::Mechanize::Catalyst->new; -ok(my $schema = DBICTest->init_schema(), 'got schema'); +ok( my $schema = DBICTest->init_schema(), 'got schema' ); -my $track = $schema->resultset('Track')->first; +my $track = $schema->resultset('Track')->first; my %original_cols = $track->get_columns; -my $track_delete_url = "$base/api/rpc/track/id/" . $track->id . "/delete"; +my $track_delete_url = "$base/api/rpc/track/id/" . $track->id . "/delete"; my $tracks_delete_url = "$base/api/rpc/track/delete"; { - my $req = POST( $track_delete_url, { - - }); - $mech->request($req, $content_type); - cmp_ok( $mech->status, '==', 200, 'Attempt to delete track ok' ); + my $req = POST( $track_delete_url, {} ); + $mech->request( $req, $content_type ); + cmp_ok( $mech->status, '==', 200, 'Attempt to delete track ok' ); - my $deleted_track = $schema->resultset('Track')->find($track->id); - is($deleted_track, undef, 'track deleted'); + my $deleted_track = $schema->resultset('Track')->find( $track->id ); + is( $deleted_track, undef, 'track deleted' ); } { - my $req = POST( $track_delete_url, { + my $req = POST( + $track_delete_url, + { - }); - $mech->request($req, $content_type); - cmp_ok( $mech->status, '==', 400, 'Attempt to delete again caught' ); + } + ); + $mech->request( $req, $content_type ); + cmp_ok( $mech->status, '==', 400, 'Attempt to delete again caught' ); } { - my $track_cnt = $schema->resultset('Track')->count; - my $tracks_rs = $schema->resultset('Track')->search(undef, { select => ['trackid'], as => ['id'], rows => 3 }); - $tracks_rs->result_class('DBIx::Class::ResultClass::HashRefInflator'); - my $test_data = JSON::Any->Dump({ list => [$tracks_rs->all] }); - my $req = POST( $tracks_delete_url, Content => $test_data ); - $req->content_type('text/x-json'); - $mech->request($req); - cmp_ok( $mech->status, '==', 200, 'Attempt to delete three tracks ok' ); - - is($schema->resultset('Track')->count + 3, $track_cnt, 'Three tracks deleted'); + my $track_cnt = $schema->resultset('Track')->count; + my $tracks_rs = + $schema->resultset('Track') + ->search( undef, { select => ['trackid'], as => ['id'], rows => 3 } ); + $tracks_rs->result_class('DBIx::Class::ResultClass::HashRefInflator'); + my $test_data = $json->encode( { list => [ $tracks_rs->all ] } ); + my $req = POST( $tracks_delete_url, Content => $test_data ); + $req->content_type('text/x-json'); + $mech->request($req); + cmp_ok( $mech->status, '==', 200, 'Attempt to delete three tracks ok' ); + + is( $schema->resultset('Track')->count + 3, + $track_cnt, 'Three tracks deleted' ); } done_testing();