Added high performance version of the Sessions code as a branch
[catagits/Catalyst-Plugin-Session.git] / t / basic.t
CommitLineData
95c6f6e8 1#!/usr/bin/perl
2
3use strict;
4use warnings;
5
6use Test::More tests => 6;
7use Test::MockObject;
8use Test::MockObject::Extends;
9
10my $m;
11BEGIN { use_ok( $m = "Catalyst::Plugin::SessionHP::State::Cookie" ) }
12
13my $cookie = Test::MockObject->new;
14$cookie->set_always( value => "the session id" );
15
16my $req = Test::MockObject->new;
17my %req_cookies;
18$req->set_always( cookies => \%req_cookies );
19
20my $res = Test::MockObject->new;
21my %res_cookies;
22$res->set_always( cookies => \%res_cookies );
23
24my $cxt =
25 Test::MockObject::Extends->new("Catalyst::Plugin::SessionHP::State::Cookie");
26
27$cxt->set_always( config => {} );
28$cxt->set_always( request => $req );
29$cxt->set_always( response => $res );
30$cxt->set_always( session => { } );
31$cxt->set_always( session_expires => 123 );
32$cxt->set_false("debug");
33my $session_id;
34$cxt->mock( session_id => sub { shift; $session_id = shift if @_; $session_id } );
35
36can_ok( $m, "setup_session" );
37
38$cxt->setup_session;
39
40like( $cxt->config->{session}{cookie_name},
41 qr/_session$/, "default cookie name is set" );
42
43$cxt->config->{session}{cookie_name} = "session";
44
45can_ok( $m, "get_sesson_id_from_state" );
46
47ok( !$cxt->get_sesson_id_from_state, "no session id yet");
48
49$cxt->clear;
50
51%req_cookies = ( session => $cookie );
52
53is( $cxt->get_sesson_id_from_state, "the session id", "session ID was restored from cookie" );
54
55$cxt->clear;
56$res->clear;
57
58
59# can_ok( $m, "cookie_is_rejecting" );
60# %req_cookies = ( path => '/foo' );
61# $req->set_always( path => '' );
62# ok( $cxt->cookie_is_rejecting(\%req_cookies), "cookie is rejecting" );
63# $req->set_always( path => 'foo/bar' );
64# ok( !$cxt->cookie_is_rejecting(\%req_cookies), "cookie is not rejecting" );