Change order in generate_rs so that stash->{class} always overrides ->class Add tests
[catagits/Catalyst-Controller-DBIC-API.git] / t / rest / stashedclass.t
index 84abd26..9a7dc2d 100644 (file)
@@ -53,4 +53,32 @@ my $base_url = "$base/api/rest/stashedclass";
     like($response->{messages}[0], qr/current_result_set.*does not pass the type constraint/, 'invalid class');
 }
 
+
+{
+    no warnings;
+    # stash->{class} should always win over $self->class
+    *Catalyst::Controller::DBIC::API::class = sub { 'RestTestDB::CD' };
+
+    my $class = 'RestTestDB::Artist';
+    my $req = GET( "$base_url/$class", {}, 'Accept' => 'text/x-json');
+    $mech->request($req);
+    cmp_ok( $mech->status, '==', '200', "status OK" );
+    my $response = $json->decode( $mech->content );
+    is($response->{success}, 'true', 'success');
+    is(scalar( @{$response->{list}} ), 3, 'three results - artist');
+}
+
+{
+    no warnings;
+    # stash->{class} not present, ->class should be returned
+    *Catalyst::Controller::DBIC::API::class = sub { 'RestTestDB::CD' };
+
+    my $req = GET( "$base_url/noclass", {}, 'Accept' => 'text/x-json');
+    $mech->request($req);
+    cmp_ok( $mech->status, '==', '200', "status OK" );
+    my $response = $json->decode( $mech->content );
+    is($response->{success}, 'true', 'success');
+    is(scalar( @{$response->{list}} ), 6, 'six results - cd');
+}
+
 done_testing();