Switch from JSON to JSON::MaybeXS to get a better choice of JSON parsers.
[catagits/Catalyst-Action-REST.git] / t / json.t
index e3a13da..7c8cc03 100644 (file)
--- a/t/json.t
+++ b/t/json.t
@@ -2,18 +2,15 @@ use strict;
 use warnings;
 use Test::More;
 use FindBin;
+use Test::Requires qw(JSON::MaybeXS);
 
 use lib ("$FindBin::Bin/lib", "$FindBin::Bin/../lib");
 use Test::Rest;
-
-eval 'require JSON';
-plan skip_all => 'Install JSON to run this test' if ($@);
-
-plan tests => 9;
+use utf8;
 
 use_ok 'Catalyst::Test', 'Test::Serialize';
 
-my $json = JSON->new;
+my $json = JSON->new->utf8;
 # The text/x-json should throw a warning
 for ('text/x-json', 'application/json') {
     my $t = Test::Rest->new('content_type' => $_);
@@ -26,10 +23,25 @@ for ('text/x-json', 'application/json') {
 
     my $post_data = {
         'sushi' => 'is good for monkey',
+        'chicken' => ' 佐藤 純',
     };
     my $mres_post = request($t->post(url => '/monkey_put', data => $json->encode($post_data)));
     ok( $mres_post->is_success, "POST to the monkey succeeded");
-    is_deeply($mres_post->content, "is good for monkey", "POST data matches");
+    my $exp = "is good for monkey 佐藤 純";
+    utf8::encode($exp);
+    is_deeply($mres_post->content, $exp, "POST data matches");
+}
+
+{
+    my $t = Test::Rest->new('content_type' => 'application/json');
+    my $json_data = '{ "sushi":"is good for monkey", }';
+    my $mres_post = request($t->post(url => '/monkey_put', data => $json_data));
+    ok( ! $mres_post->is_success, "Got expected failed status due to invalid JSON" );
+
+    my $relaxed_post = request( $t->post(url => "/monkey_json_put", data => $json_data));
+    ok( $relaxed_post->is_success, "Got success due to setting relaxed JSON input" );
 }
 
 1;
+
+done_testing;