lemonldap-ng/lemonldap-ng-handler/t/69-Lemonldap-NG-Handler-PSG...

105 lines
3.1 KiB
Perl

use Test::More;
BEGIN {
require 't/test-psgi-lib.pm';
}
my $maintests = 12;
SKIP: {
eval { require Cache::Memcached; };
if ($@) {
skip 'Cache::Memcached not found', $maintests;
}
my $testmemd = new Cache::Memcached { 'servers' => ["127.0.0.1:11211"] };
unless ( $testmemd->stats->{hosts} ) {
skip 'Memcached not started', $maintests;
}
eval { require Apache::Session::Generate::MD5; };
if ($@) {
skip 'Apache::Session::Generate::MD5 not found', $maintests;
}
init(
'Lemonldap::NG::Handler::Server',
{
logLevel => 'error',
secureTokenUrls => [ '^/secured$', '/test$' ],
secureTokenHeader => 'AuthToken',
vhostOptions => {
'test1.example.com' => {
vhostHttps => 0,
vhostPort => 80,
vhostMaintenance => 0,
vhostServiceTokenTTL => -1,
},
},
exportedHeaders => {
'test1.example.com' => {
'Auth-User' => '$uid',
},
}
}
);
## Request secured URLs
# First URL
ok(
$res = $client->_get(
'/secured', undef,
'test1.example.com', "lemonldap=$sessionId",
VHOSTTYPE => 'SecureToken',
),
'Auth secured URL query 1'
);
ok( $res->[0] == 200, 'Code is 200' ) or explain( $res->[0], 200 );
# Check headers
%h = @{ $res->[1] };
ok( $h{'AuthToken'} =~ m%[0-9a-f]{32}%, 'Header "AuthToken" found' )
or explain( \%h, 'AuthToken => "md5 value"' );
ok( $h{'Auth-User'} eq 'dwho', 'Header Auth-User is set to "dwho"' )
or explain( \%h, 'Auth-User => "dwho"' );
# Second URL
ok(
$res = $client->_get(
'/try/test', undef,
'test1.example.com', "lemonldap=$sessionId",
VHOSTTYPE => 'SecureToken',
),
'Auth secured URL query 2'
);
ok( $res->[0] == 200, 'Code is 200' ) or explain( $res->[0], 200 );
# Check headers
%h = @{ $res->[1] };
ok( $h{'AuthToken'} =~ m%[0-9a-f]{32}%, 'Header "AuthToken" found' )
or explain( \%h, 'AuthToken => "md5 value"' );
ok( $h{'Auth-User'} eq 'dwho', 'Header Auth-User is set to "dwho"' )
or explain( \%h, 'Auth-User => "dwho"' );
## Request an unsecured URL
ok(
$res = $client->_get(
'/try', undef,
'test1.example.com', "lemonldap=$sessionId",
VHOSTTYPE => 'SecureToken',
),
'Auth unsecured URL query'
);
ok( $res->[0] == 200, 'Code is 200' ) or explain( $res->[0], 200 );
# Check headers
%h = @{ $res->[1] };
ok( !defined $h{'AuthToken'}, 'Header "AuthToken" not found' )
or explain( \%h, 'AuthToken => "md5 value"' );
ok( $h{'Auth-User'} eq 'dwho', 'Header Auth-User is set to "dwho"' )
or explain( \%h, 'Auth-User => "dwho"' );
}
count($maintests);
done_testing( count() );
clean();