use Test::More; use strict; use IO::String; use POSIX qw(locale_h); use locale; setlocale( LC_TIME, "C" ); BEGIN { eval { require 't/test-lib.pm'; require 't/smtp.pm'; }; } my $res; my $maintests = 20; SKIP: { eval 'require Email::Sender::Simple;'; if ($@) { skip 'Missing dependencies', $maintests; } my $client = LLNG::Manager::Test->new( { ini => { logLevel => 'error', useSafeJail => 1, authentication => 'Demo', userDB => 'Same', passwordDB => 'Demo', captcha_mail_enabled => 0, portalMainLogo => 'common/logos/logo_llng_old.png', newLocationWarning => 1, loginHistoryEnabled => 1 } } ); ## Simple access ok( $res = $client->_get( '/', accept => 'text/html' ), 'Get Portal', ); my ( $host, $url, $query ) = expectForm( $res, '#', undef, 'user', 'password' ); ## Authentication #1 with IP #1 clear_mail(); ok( $res = $client->_post( '/', IO::String->new('user=dwho&password=dwho'), length => 23, accept => 'text/html', ), 'First auth query' ); my $id = expectCookie($res); $client->logout($id); ok( !mail(), "First time seeing a new IP, no mail sent" ); ## Authentication #2 with IP #1 clear_mail(); ok( $res = $client->_post( '/', IO::String->new('user=dwho&password=dwho'), length => 23, accept => 'text/html', ), 'Second auth query' ); $id = expectCookie($res); expectRedirection( $res, 'http://auth.example.com/' ); $client->logout($id); ok( !mail(), "Second time seeing a new IP, no mail sent" ); ## Authentication #3 with IP #2 clear_mail(); ok( $res = $client->_post( '/', IO::String->new('user=dwho&password=dwho'), length => 23, accept => 'text/html', ip => '127.0.0.2', ), 'Third auth query' ); $id = expectCookie($res); expectRedirection( $res, 'http://auth.example.com/' ); $client->logout($id); like( mail(), qr#

Your account was signed in to from a new location\.


#, 'First login on a new IP, email sent' ); ## Authentication #1 with IP #3 wrong password clear_mail(); ok( $res = $client->_post( '/', IO::String->new('user=dwho&password=ohwd'), length => 23, accept => 'text/html', ip => "127.0.0.3", ), 'Fourth auth query' ); ok( $res->[2]->[0] =~ /<\/span>/, ' Bad credential' ) or print STDERR Dumper( $res->[2]->[0] ); ok( !mail(), "Failed login with a new IP, no email sent" ); ## Authentication #2 with IP #3 clear_mail(); ok( $res = $client->_post( '/', IO::String->new('user=dwho&password=dwho'), length => 23, accept => 'text/html', ip => '127.0.0.3', ), 'Fifth auth query' ); $id = expectCookie($res); expectRedirection( $res, 'http://auth.example.com/' ); like( subject(), qr#\[LemonLDAP::NG\] Sign-in from a new location#, ' Subject found' ); like( mail(), qr#

Your account was signed in to from a new location\.


#, ' Mail sent (Wrong password)' ); like( mail(), qr#Location 127.0.0.3#, ' Location found in mail body' ); like( mail(), qr#Date \d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}#, ' Date found in mail body' ); like( mail(), qr#UA Mozilla/5\.0 \(VAX-4000; rv:36\.0\) Gecko/20350101 Firefox
#, ' UserAgent found in mail body' ); ## Authentication #3 with IP #3 clear_mail(); ok( $res = $client->_post( '/', IO::String->new('user=dwho&password=dwho'), length => 23, accept => 'text/html', ip => '127.0.0.3', ), 'Fifth auth query' ); $id = expectCookie($res); expectRedirection( $res, 'http://auth.example.com/' ); ok( !mail(), "Login on newly learned address, no email" ); ## Authentication #3 with IP #1 clear_mail(); ok( $res = $client->_post( '/', IO::String->new('user=dwho&password=dwho'), length => 23, accept => 'text/html', ), 'Fifth auth query' ); $id = expectCookie($res); expectRedirection( $res, 'http://auth.example.com/' ); ok( !mail(), "Login on previously learned address, no email" ); } count($maintests); clean_sessions(); done_testing( count() );