Commit | Line | Data |
e601adda |
1 | use strict; |
2 | use warnings; |
10018fb4 |
3 | use Test::More; |
e601adda |
4 | use YAML::Syck; |
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 Data::Serializer |
11 | my $t = Test::Rest->new('content_type' => 'text/x-yaml'); |
12 | |
c5c27d42 |
13 | use_ok 'Catalyst::Test', 'Test::Catalyst::Action::REST'; |
14 | my $url = '/deserialize/test'; |
e601adda |
15 | |
588cbecc |
16 | my $req = $t->put( url => $url, data => Dump({ kitty => "LouLou" })); |
17 | my $res = request($req); |
e601adda |
18 | ok( $res->is_success, 'PUT Deserialize request succeeded' ); |
19 | is( $res->content, "LouLou", "Request returned deserialized data"); |
20 | |
588cbecc |
21 | $req->method('GET'); |
22 | isnt( request($req)->content, 'LouLou', 'GET request with body does not work by default' ); |
23 | |
24 | $req->url('/deserialize/test_action_args'); |
25 | is( request($req)->content, 'LouLou', 'GET request via action_args'); |
26 | |
e601adda |
27 | my $nt = Test::Rest->new('content_type' => 'text/broken'); |
c5c27d42 |
28 | my $bres = request($nt->put( url => $url, data => Dump({ kitty => "LouLou" }))); |
e601adda |
29 | is( $bres->code, 415, 'PUT on un-useable Deserialize class returns 415'); |
30 | |
31 | my $ut = Test::Rest->new('content_type' => 'text/not-happening'); |
c5c27d42 |
32 | my $ures = request($ut->put( url => $url, data => Dump({ kitty => "LouLou" }))); |
e601adda |
33 | is ($bres->code, 415, 'GET on unknown Content-Type returns 415'); |
34 | |
35 | 1; |
10018fb4 |
36 | |
37 | done_testing; |