Stop accidentally blowing up if we can't restore the user.. Add tests and docs for...
[catagits/Catalyst-Plugin-Authentication.git] / t / lib / AuthSessionTestApp.pm
1 package User::SessionRestoring;
2 use base qw/Catalyst::Authentication::User::Hash/;
3
4 sub for_session { $_[0]->id }
5 sub store { $_[0]->{store} }
6
7 package AuthSessionTestApp;
8 use Catalyst qw/
9         Session
10         Session::Store::Dummy
11         Session::State::Cookie
12
13         Authentication
14         Authentication::Store::Minimal
15         Authentication::Credential::Password
16 /;
17
18 use Test::More;
19 use Test::Exception;
20
21 use Digest::MD5 qw/md5/;
22
23 our $users;
24
25 sub moose : Local {
26         my ( $self, $c ) = @_;
27
28         ok(!$c->sessionid, "no session id yet");
29         ok(!$c->user_exists, "no user exists");
30         ok(!$c->user, "no user yet");
31         ok($c->login( "foo", "s3cr3t" ), "can login with clear");
32         is( $c->user, $users->{foo}, "user object is in proper place");
33 }
34
35 sub elk : Local {
36         my ( $self, $c ) = @_;
37
38         ok( $c->sessionid, "session ID was restored" );
39         ok( $c->user_exists, "user exists" );
40         ok( $c->user, "a user was also restored");
41         is_deeply( $c->user, $users->{foo}, "restored user is the right one (deep test - store might change identity)" );
42         
43         # Rename the user!
44         $users->{bar} = delete $users->{foo};
45 }
46
47 sub yak : Local {
48     my ( $self, $c ) = @_;
49     ok( $c->sessionid, "session ID was restored after user renamed" );
50     ok( $c->user_exists, "user appears to exist" );
51     ok( !$c->user, "try to restore - user was not restored");
52     ok( !$c->user_exists, "user no longer appears to exist" );
53 }
54
55 sub goat : Local {
56     my ( $self, $c ) = @_;
57     ok($c->login( "bar", "s3cr3t" ), "can login with clear (new username)");
58     is( $c->user, $users->{bar}, "user object is in proper place");
59     $c->logout;
60 }
61
62 sub fluffy_bunny : Local {
63     my ( $self, $c ) = @_;
64
65     ok( $c->session_is_valid, "session ID is restored after logout");
66     ok( !$c->user, "no user was restored after logout");
67         
68     $c->delete_session("bah");
69 }
70
71 sub possum : Local {
72     my ( $self, $c ) = @_;
73
74         ok( !$c->session_is_valid, "no session ID was restored");
75     $c->session->{definitely_not_a_user} = "moose";
76
77 }
78
79 sub butterfly : Local {
80     my ( $self, $c ) = @_;
81
82     ok( $c->session_is_valid, "valid session" );
83     ok( !$c->user_exists, "but no user exists" );
84     ok( !$c->user, "no user object either" );
85 }
86
87 __PACKAGE__->config->{'authentication'}{users} = $users = {
88         foo => User::SessionRestoring->new(
89                 id => 'foo',
90                 password => "s3cr3t",
91         ),
92 };
93
94 __PACKAGE__->setup;
95
96 $users->{foo}{store} = __PACKAGE__->default_auth_store;