use Test::More;
use Test::WWW::Mechanize::Catalyst 'RestTest';
use HTTP::Request::Common;
-use JSON;
+use JSON::MaybeXS;
-my $json = JSON->new->utf8;
+my $json = JSON::MaybeXS->new(utf8 => 1);
my $mech = Test::WWW::Mechanize::Catalyst->new;
ok( my $schema = DBICTest->init_schema(), 'got schema' );
{
my $id = 1;
my $req =
- GET( $artist_view_url . $id, undef, 'Accept' => 'application/json' );
+ GET( $artist_view_url . $id, 'Accept' => 'application/json' );
$mech->request($req);
cmp_ok( $mech->status, '==', 200, 'open attempt okay' );
my %expected_response =
$schema->resultset('Artist')->find($id)->get_columns;
my $response = $json->decode( $mech->content );
+ #artist does not have use_json_boolean => 1, so true values are stringified to 'true'
is_deeply(
$response,
+
+ # artist doesn't set use_json_boolean
{ data => \%expected_response, success => 'true' },
'correct data returned'
);
{
my $id = 5;
my $req =
- GET( $artist_view_url . $id, undef, 'Accept' => 'application/json' );
+ GET( $artist_view_url . $id, 'Accept' => 'application/json' );
$mech->request($req);
cmp_ok( $mech->status, '==', 400, 'open attempt not ok' );
my $response = $json->decode( $mech->content );
{
my $id = 9;
my $req =
- GET( $track_view_url . $id, undef, 'Accept' => 'application/json' );
+ GET( $track_view_url . $id, 'Accept' => 'application/json' );
$mech->request($req);
cmp_ok( $mech->status, '==', 200, 'got track with datetime object okay' );
my %expected_response =
my $response = $json->decode( $mech->content );
is_deeply(
$response,
- { data => \%expected_response, success => 'true' },
+
+ # track does set use_json_boolean
+ { data => \%expected_response, success => JSON::MaybeXS::true },
'correct data returned for track with datetime'
);
}
+{
+ my $req =
+ GET( $artist_view_url . 'action_with_error', 'Accept' => 'application/json' );
+ $mech->request($req);
+ cmp_ok( $mech->status, '==', 404, 'action returned error 404' );
+ my $response = $json->decode( $mech->content );
+ is_deeply(
+ $response,
+
+ # artist doesn't set use_json_boolean
+ { success => 'false' },
+ 'correct data returned'
+ );
+}
+
done_testing();