8 my $base = 'http://localhost';
9 my $content_type = [ 'Content-Type', 'application/x-www-form-urlencoded' ];
14 use Test::WWW::Mechanize::Catalyst 'RestTest';
15 use HTTP::Request::Common qw/ DELETE /;
18 my $mech = Test::WWW::Mechanize::Catalyst->new;
19 ok(my $schema = DBICTest->init_schema(), 'got schema');
21 my $track = $schema->resultset('Track')->first;
22 my %original_cols = $track->get_columns;
24 my $track_url = "$base/api/rest/track/";
25 my $track_delete_url = $track_url . $track->id;
28 my $req = HTTP::Request->new( DELETE => $track_delete_url );
29 $req->content_type('text/x-json');
31 cmp_ok( $mech->status, '==', 200, 'Attempt to delete track ok' );
33 my $deleted_track = $schema->resultset('Track')->find($track->id);
34 is($deleted_track, undef, 'track deleted');
38 my $req = HTTP::Request->new( DELETE => $track_delete_url );
39 $req->content_type('text/x-json');
41 cmp_ok( $mech->status, '==', 400, 'Attempt to delete again caught' );
45 my $track_cnt = $schema->resultset('Track')->count;
46 my $tracks_rs = $schema->resultset('Track')->search(undef, { select => ['trackid'], as => ['id'], rows=> 3 });
47 $tracks_rs->result_class('DBIx::Class::ResultClass::HashRefInflator');
48 my $test_data = JSON::Any->Dump({ list => [$tracks_rs->all] });
49 my $req = DELETE( $track_url, Content => $test_data );
50 $req->content_type('text/x-json');
52 cmp_ok( $mech->status, '==', 200, 'Attempt to delete three tracks ok' );
54 is($schema->resultset('Track')->count + 3, $track_cnt, 'Three tracks deleted');