use JSON instead of JSON::Any to get rid of the CPAN Testers failures when only JSON...
[catagits/Catalyst-Controller-DBIC-API.git] / t / rpc / delete.t
CommitLineData
d2739840 1use 5.6.0;
2
3use strict;
4use warnings;
5
6use lib 't/lib';
7
8my $base = 'http://localhost';
9my $content_type = [ 'Content-Type', 'application/x-www-form-urlencoded' ];
10
11use RestTest;
12use DBICTest;
13use Test::More;
14use Test::WWW::Mechanize::Catalyst 'RestTest';
15use HTTP::Request::Common;
0b0bf911 16use JSON;
17
18my $json = JSON->new->utf8;
d2739840 19
20my $mech = Test::WWW::Mechanize::Catalyst->new;
0b0bf911 21ok( my $schema = DBICTest->init_schema(), 'got schema' );
d2739840 22
0b0bf911 23my $track = $schema->resultset('Track')->first;
d2739840 24my %original_cols = $track->get_columns;
25
0b0bf911 26my $track_delete_url = "$base/api/rpc/track/id/" . $track->id . "/delete";
a1f71064 27my $tracks_delete_url = "$base/api/rpc/track/delete";
d2739840 28
29{
0b0bf911 30 my $req = POST( $track_delete_url, {} );
31 $mech->request( $req, $content_type );
32 cmp_ok( $mech->status, '==', 200, 'Attempt to delete track ok' );
d2739840 33
0b0bf911 34 my $deleted_track = $schema->resultset('Track')->find( $track->id );
35 is( $deleted_track, undef, 'track deleted' );
d2739840 36}
37
38{
0b0bf911 39 my $req = POST(
40 $track_delete_url,
41 {
d2739840 42
0b0bf911 43 }
44 );
45 $mech->request( $req, $content_type );
46 cmp_ok( $mech->status, '==', 400, 'Attempt to delete again caught' );
d2739840 47}
48
a1f71064 49{
0b0bf911 50 my $track_cnt = $schema->resultset('Track')->count;
51 my $tracks_rs =
52 $schema->resultset('Track')
53 ->search( undef, { select => ['trackid'], as => ['id'], rows => 3 } );
54 $tracks_rs->result_class('DBIx::Class::ResultClass::HashRefInflator');
55 my $test_data = $json->encode( { list => [ $tracks_rs->all ] } );
56 my $req = POST( $tracks_delete_url, Content => $test_data );
57 $req->content_type('text/x-json');
58 $mech->request($req);
59 cmp_ok( $mech->status, '==', 200, 'Attempt to delete three tracks ok' );
60
61 is( $schema->resultset('Track')->count + 3,
62 $track_cnt, 'Three tracks deleted' );
a1f71064 63}
64
d2739840 65done_testing();