Tests which I believe show that JSON encoding is handled correctly. I.E. You pass...
Tomas Doran [Mon, 26 Oct 2009 23:52:23 +0000 (23:52 +0000)]
t/json.t
t/lib/Test/Serialize/Controller/REST.pm

index b601c64..673c0a9 100644 (file)
--- a/t/json.t
+++ b/t/json.t
@@ -5,6 +5,7 @@ use FindBin;
 
 use lib ("$FindBin::Bin/lib", "$FindBin::Bin/../lib");
 use Test::Rest;
+use utf8;
 
 eval 'use JSON 2.12';
 plan skip_all => 'Install JSON 2.12 or later to run this test' if ($@);
@@ -13,7 +14,7 @@ plan tests => 9;
 
 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 +27,13 @@ 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");
 }
 
 1;
index 733508a..dad5483 100644 (file)
@@ -32,7 +32,9 @@ __PACKAGE__->config(
 sub monkey_put : Local : ActionClass('Deserialize') {
     my ( $self, $c ) = @_;
     if ( ref($c->req->data) eq "HASH" ) {
-        $c->res->output( $c->req->data->{'sushi'} );
+        my $out = $c->req->data->{'sushi'} . $c->req->data->{'chicken'}||'';
+        utf8::encode($out);
+        $c->res->output( $out );
     } else {
         $c->res->output(1);
     }