3 package Catalyst::Plugin::Session::Test::Store;
20 plan tests => 19 + ($args{extra_tests} || 0);
22 my $backend = $args{backend};
23 my $cfg = $args{config};
25 my $p = "Session::Store::$backend";
26 use_ok( my $m = "Catalyst::Plugin::$p" );
28 isa_ok( bless( {}, $m ), "Catalyst::Plugin::Session::Store" );
31 package # Hide from PAUSE
32 Catalyst::Plugin::SessionStateTest;
33 use base qw/Catalyst::Plugin::Session::State/;
39 ${ ref($c) . "::session_id" };
44 ${ ref($c) . "::session_id" } = $sid;
47 sub delete_session_id {
49 undef ${ ref($c) . "::session_id" };
55 package # Hide from PAUSE
57 use Catalyst qw/Session SessionStateTest/;
65 sub create_session : Global {
66 my ( $self, $c ) = @_;
67 ok( !$c->session_is_valid, "no session id yet" );
68 ok( $c->session, "session created" );
69 ok( $c->session_is_valid, "with a session id" );
71 $c->session->{magic} = "møøse";
74 sub recover_session : Global {
75 my ( $self, $c ) = @_;
76 ok( $c->session_is_valid, "session id exists" );
77 is( $c->sessionid, our $session_id,
78 "and is the one we saved in the last action" );
79 ok( $c->session, "a session exists" );
80 is( $c->session->{magic},
82 "and it contains what we put in on the last attempt" );
83 $c->delete_session("user logout");
86 sub after_session : Global {
87 my ( $self, $c ) = @_;
88 ok( !$c->session_is_valid, "no session id" );
89 ok( !$c->session->{magic}, "session data not restored" );
90 ok( !$c->session_delete_reason, "no reason for deletion" );
93 @{ __PACKAGE__->config->{'Plugin::Session'} }{ keys %$cfg } = values %$cfg;
95 { __PACKAGE__->setup; }; # Extra block here is an INSANE HACK to get inlined constructor
96 # (i.e. to make B::Hooks::EndOfScope fire)
101 package # Hide from PAUSE
103 use Catalyst qw/Session SessionStateTest/;
108 sub create_session : Global {
109 my ( $self, $c ) = @_;
111 $c->session->{magic} = "møøse";
114 sub recover_session : Global {
115 my ( $self, $c ) = @_;
117 ok( !$c->session_is_valid, "session is gone" );
120 $c->session_delete_reason,
122 "reason is that the session expired"
125 ok( !$c->session->{magic}, "no saved data" );
128 __PACKAGE__->config->{'Plugin::Session'}{expires} = 0;
130 @{ __PACKAGE__->config->{'Plugin::Session'} }{ keys %$cfg } = values %$cfg;
132 { __PACKAGE__->setup; }; # INSANE HACK (the block - as above)
137 can_ok( $m, "get_session_data" );
138 can_ok( $m, "store_session_data" );
139 can_ok( $m, "delete_session_data" );
140 can_ok( $m, "delete_expired_sessions" );
144 package # Hide from PAUSE
146 use Catalyst::Test "SessionStoreTest";
148 # idiotic void context warning workaround
150 my $x = get("/create_session");
151 $x = get("/recover_session");
152 $x = get("/after_session");
157 package # Hide fram PAUSE
159 use Catalyst::Test "SessionStoreTest2";
161 my $x = get("/create_session");
162 sleep 1; # let the session expire
163 $x = get("/recover_session");
175 Catalyst::Plugin::Session::Test::Store - Reusable sanity for session storage
182 use Catalyst::Plugin::Session::Test::Store (
183 backend => "FastMmap",
185 storage => "/tmp/foo",