Changes to allow for dropping of the 'realms' config hash and instead
[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     $c->logout;
44 }
45
46 sub fluffy_bunny : Local {
47         my ( $self, $c ) = @_;
48
49         ok( $c->session_is_valid, "no session ID was restored");
50         ok( !$c->user, "no user was restored");
51         
52     $c->delete_session("bah");
53 }
54
55 sub possum : Local {
56     my ( $self, $c ) = @_;
57
58         ok( !$c->session_is_valid, "no session ID was restored");
59     $c->session->{definitely_not_a_user} = "moose";
60
61 }
62
63 sub butterfly : Local {
64     my ( $self, $c ) = @_;
65
66     ok( $c->session_is_valid, "valid session" );
67     ok( !$c->user_exists, "but no user exists" );
68     ok( !$c->user, "no user object either" );
69 }
70
71 __PACKAGE__->config->{'authentication'}{users} = $users = {
72         foo => User::SessionRestoring->new(
73                 id => 'foo',
74                 password => "s3cr3t",
75         ),
76 };
77
78 __PACKAGE__->setup;
79
80 $users->{foo}{store} = __PACKAGE__->default_auth_store;