Commit | Line | Data |
e601adda |
1 | use strict; |
2 | use warnings; |
7b8c5be2 |
3 | use Test::More tests => 9; |
e601adda |
4 | use Data::Serializer; |
5 | use FindBin; |
e601adda |
6 | |
7 | use lib ("$FindBin::Bin/lib", "$FindBin::Bin/../lib", "$FindBin::Bin/broken"); |
8 | use Test::Rest; |
9 | |
10 | # Should use Data::Dumper, via YAML |
11 | my $t = Test::Rest->new('content_type' => 'text/x-data-dumper'); |
12 | |
9d3bee45 |
13 | use_ok 'Catalyst::Test', 'Test::Catalyst::Action::REST'; |
e601adda |
14 | |
9d3bee45 |
15 | my $res = request($t->get(url => '/serialize/test')); |
e601adda |
16 | ok( $res->is_success, 'GET the serialized request succeeded' ); |
17 | is( $res->content, "{'lou' => 'is my cat'}", "Request returned proper data"); |
18 | |
19 | my $nt = Test::Rest->new('content_type' => 'text/broken'); |
9d3bee45 |
20 | my $bres = request($nt->get(url => '/serialize/test')); |
e601adda |
21 | is( $bres->code, 415, 'GET on un-useable Serialize class returns 415'); |
22 | |
23 | my $ut = Test::Rest->new('content_type' => 'text/not-happening'); |
9d3bee45 |
24 | my $ures = request($ut->get(url => '/serialize/test')); |
e601adda |
25 | is ($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 |
29 | my $res2 = request($t->get(url => '/serialize/test_second')); |
e601adda |
30 | ok( $res2->is_success, '2nd request succeeded' ); |
31 | is( $res2->content, "{'lou' => 'is my cat'}", "2nd request returned proper data"); |
32 | |
7b8c5be2 |
33 | Test::Catalyst::Action::REST->controller('Serialize')->{serialize} = {}; |
34 | $res2 = request($t->get(url => '/serialize/test_second')); |
35 | ok( $res2->is_success, 'request succeeded (deprecated config)' ); |
36 | is( $res2->content, "{'lou' => 'is my cat'}", "request returned proper data"); |
e601adda |
37 | |
38 | 1; |