Commit | Line | Data |
a3bf437a |
1 | package User::SessionRestoring; |
2 | use base qw/Catalyst::Plugin::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->delete_session("bah"); |
44 | } |
45 | |
46 | sub fluffy_bunny : Local { |
47 | my ( $self, $c ) = @_; |
48 | |
f96a2155 |
49 | ok( !$c->session_is_valid, "no session ID was restored"); |
a3bf437a |
50 | ok( !$c->user, "no user was restored"); |
51 | } |
52 | |
53 | __PACKAGE__->config->{authentication}{users} = $users = { |
54 | foo => User::SessionRestoring->new( |
55 | id => 'foo', |
56 | password => "s3cr3t", |
57 | ), |
58 | }; |
59 | |
60 | __PACKAGE__->setup; |
61 | |
62 | $users->{foo}{store} = __PACKAGE__->default_auth_store; |