Merge
[catagits/Catalyst-Action-REST.git] / t / catalyst-action-rest.t
index 535ac4e..124906c 100644 (file)
@@ -1,6 +1,6 @@
 use strict;
 use warnings;
-use Test::More tests => 18;
+use Test::More;
 use FindBin;
 
 use lib ( "$FindBin::Bin/lib", "$FindBin::Bin/../lib" );
@@ -33,6 +33,11 @@ foreach my $method (qw(GET DELETE POST PUT OPTIONS)) {
     );
 }
 
+my $head_res = request( $t->head(url => '/test') );
+ok($head_res->is_success, 'HEAD request succeeded')
+    or diag($head_res->code);
+ok(!$head_res->content, 'HEAD request had proper response');
+
 my $fail_res = request( $t->delete( url => '/notreally' ) );
 is( $fail_res->code, 405, "Request to bad method gets 405 Not Implemented" );
 is( $fail_res->header('allow'), "GET", "405 allow header properly set." );
@@ -42,6 +47,23 @@ is( $options_res->code, 200, "OPTIONS request handler succeeded" );
 is( $options_res->header('allow'),
     "GET", "OPTIONS request allow header properly set." );
 
+my $opts_res = request( $t->options( url => '/rest/opts' ) );
+is( $opts_res->code, 200, "OPTIONS request handler succeeded" );
+is( $opts_res->header('allow'),
+    "GET", "OPTIONS request allow header properly set." );
+is($opts_res->content, q{}, 'should have no body');
+
+$opts_res = request(
+  $t->options(
+    url => '/rest/opts',
+    headers => { Accept => 'application/json' },
+  )
+);
+is( $opts_res->code, 200, "OPTIONS request handler succeeded" );
+is( $opts_res->header('allow'),
+    "GET", "OPTIONS request allow header properly set." );
+is($opts_res->content, q{}, 'should have no body');
+
 my $modified_res = request( $t->get( url => '/not_modified' ) );
 is( $modified_res->code, 304, "Not Modified request handler succeeded" );
 
@@ -54,3 +76,5 @@ is(
 );
 
 1;
+
+done_testing;