Add tests which should fail, but don't.
[catagits/Catalyst-Action-REST.git] / t / catalyst-action-serialize.t
CommitLineData
e601adda 1use strict;
2use warnings;
7b8c5be2 3use Test::More tests => 9;
e601adda 4use Data::Serializer;
5use FindBin;
e601adda 6
7use lib ("$FindBin::Bin/lib", "$FindBin::Bin/../lib", "$FindBin::Bin/broken");
8use Test::Rest;
9
10# Should use Data::Dumper, via YAML
11my $t = Test::Rest->new('content_type' => 'text/x-data-dumper');
12
9d3bee45 13use_ok 'Catalyst::Test', 'Test::Catalyst::Action::REST';
e601adda 14
9d3bee45 15my $res = request($t->get(url => '/serialize/test'));
e601adda 16ok( $res->is_success, 'GET the serialized request succeeded' );
17is( $res->content, "{'lou' => 'is my cat'}", "Request returned proper data");
18
19my $nt = Test::Rest->new('content_type' => 'text/broken');
9d3bee45 20my $bres = request($nt->get(url => '/serialize/test'));
e601adda 21is( $bres->code, 415, 'GET on un-useable Serialize class returns 415');
22
23my $ut = Test::Rest->new('content_type' => 'text/not-happening');
9d3bee45 24my $ures = request($ut->get(url => '/serialize/test'));
e601adda 25is ($bres->code, 415, 'GET on unknown Content-Type returns 415');
26
27# This check is to make sure we can still serialize after the first
28# request.
9d3bee45 29my $res2 = request($t->get(url => '/serialize/test_second'));
e601adda 30ok( $res2->is_success, '2nd request succeeded' );
31is( $res2->content, "{'lou' => 'is my cat'}", "2nd request returned proper data");
32
7b8c5be2 33Test::Catalyst::Action::REST->controller('Serialize')->{serialize} = {};
34$res2 = request($t->get(url => '/serialize/test_second'));
35ok( $res2->is_success, 'request succeeded (deprecated config)' );
36is( $res2->content, "{'lou' => 'is my cat'}", "request returned proper data");
e601adda 37
381;