2ba6ff8a99b02f70dee2e22f5094965452df5c15
[catagits/Catalyst-Authentication-Credential-HTTP.git] / t / basic.t
1 #!/usr/bin/perl
2
3 use strict;
4 use warnings;
5
6 use Test::More tests => 12;
7 use Test::MockObject::Extends;
8 use Test::MockObject;
9 use Test::Exception;
10 use HTTP::Headers;
11
12
13 my $m; BEGIN { use_ok($m = "Catalyst::Plugin::Authentication::Credential::HTTP") }
14
15 can_ok( $m, "authenticate_http" );
16 can_ok( $m, "authorization_required" );
17 can_ok( $m, "authorization_required_response" );
18
19 my $req = Test::MockObject->new;
20 my $req_headers = HTTP::Headers->new;
21
22 $req->set_always( headers => $req_headers );
23
24 my $res = Test::MockObject->new;
25
26 my $status;
27 $res->mock(status => sub { $status = $_[1] });
28
29 my $res_headers = HTTP::Headers->new;
30 $res->set_always( headers => $res_headers );
31
32 my $c = Test::MockObject::Extends->new( $m );
33
34 my $cache = Test::MockObject->new;
35 $cache->mock(set => sub { shift->{$_[0]} = $_[1] });
36 $cache->mock(get => sub { return shift->{$_[0]} });
37 $c->mock(cache => sub { $cache });
38
39 my @login_info;
40 $c->mock( login => sub { shift; @login_info = @_; 1 } );
41 $c->set_always( config => {} );
42 $c->set_always( req => $req );
43 $c->set_always( res => $res );
44
45
46 ok( !$c->authenticate_http, "http auth fails without header");
47
48 $req_headers->authorization_basic( qw/foo bar/ );
49
50 ok( $c->authenticate_http, "auth successful with header");
51 is_deeply( \@login_info, [qw/foo bar/], "login info delegated");
52
53 lives_ok {
54     $c->authorization_required
55 } "no detach on authorization required with successful authentication";
56
57 $req_headers->clear;
58 $c->clear;
59
60 throws_ok {
61     $c->authorization_required;
62 } qr/^ $Catalyst::DETACH $/x, "detached on no authorization required with bad auth";
63
64 is( $status, 401, "401 status code" );
65 like( ($res_headers->header('WWW-Authenticate'))[0], qr/^Digest/, "WWW-Authenticate header set: digest");
66 like( ($res_headers->header('WWW-Authenticate'))[1], qr/^Basic/, "WWW-Authenticate header set: basic");