lemonldap-ng/lemonldap-ng-portal/t/43-MailPasswordReset-DBI.t

207 lines
6.3 KiB
Perl
Raw Normal View History

2018-01-24 22:32:08 +01:00
use Test::More;
use strict;
use IO::String;
2019-08-29 10:04:06 +02:00
my $userdb;
2020-02-20 23:34:02 +01:00
2018-01-24 22:32:08 +01:00
BEGIN {
eval {
require 't/test-lib.pm';
require 't/smtp.pm';
2019-08-29 10:04:06 +02:00
$userdb = tempdb();
2018-01-24 22:32:08 +01:00
};
}
my ( $res, $user, $pwd );
2022-05-15 23:36:12 +02:00
my $maintests = 22;
2018-01-24 22:32:08 +01:00
my $mailSend = 0;
my $mail2 = 0;
SKIP: {
eval
2018-11-26 14:40:21 +01:00
'require Email::Sender::Simple;use GD::SecurityImage;use Image::Magick;';
2018-01-24 22:32:08 +01:00
if ($@) {
skip 'Missing dependencies', $maintests;
}
eval { require DBI; require DBD::SQLite; };
if ($@) {
skip 'DBD::SQLite not found', $maintests;
}
2019-08-29 10:04:06 +02:00
my $dbh = DBI->connect("dbi:SQLite:dbname=$userdb");
2018-01-24 22:32:08 +01:00
$dbh->do(
'CREATE TABLE users (user text,password text,name text, mail text)');
$dbh->do(
2018-11-26 14:40:21 +01:00
"INSERT INTO users VALUES ('dwho','dwho','Doctor who','dwho\@badwolf.org')"
2018-01-24 22:32:08 +01:00
);
2019-02-07 09:27:56 +01:00
my $client = LLNG::Manager::Test->new( {
2018-11-26 14:40:21 +01:00
ini => {
logLevel => 'error',
useSafeJail => 1,
portalDisplayRegister => 1,
authentication => 'DBI',
userDB => 'Same',
passwordDB => 'DBI',
captcha_mail_enabled => 0,
portalDisplayResetPassword => 1,
2019-08-29 10:04:06 +02:00
dbiAuthChain => "dbi:SQLite:dbname=$userdb",
2018-11-26 14:40:21 +01:00
dbiAuthUser => '',
dbiAuthPassword => '',
dbiAuthTable => 'users',
dbiAuthLoginCol => 'user',
dbiAuthPasswordCol => 'password',
dbiAuthPasswordHash => '',
dbiDynamicHashEnabled => 0,
dbiMailCol => 'mail',
2022-05-15 23:36:12 +02:00
portalEnablePasswordDisplay => 1,
2022-05-13 23:27:52 +02:00
portalDisplayPasswordPolicy => 1,
passwordPolicyActivation => 0,
2018-11-16 22:02:43 +01:00
passwordResetAllowedRetries => 4,
2022-05-13 23:27:52 +02:00
passwordPolicyMinDigit => 2,
passwordPolicyMinSpeChar => 1,
passwordPolicySpecialChar => '__ALL__'
2018-01-24 22:32:08 +01:00
}
}
);
# Test form
# ------------------------
ok( $res = $client->_get( '/resetpwd', accept => 'text/html' ),
'Reset form', );
my ( $host, $url, $query ) = expectForm( $res, '#', undef, 'mail' );
$query = 'mail=dwho%40badwolf.org';
# Post email
2018-11-26 14:40:21 +01:00
ok(
$res = $client->_post(
2018-01-24 22:32:08 +01:00
'/resetpwd', IO::String->new($query),
length => length($query),
accept => 'text/html'
),
'Post mail'
);
ok( mail() =~ m#a href="http://auth.example.com/resetpwd\?(.*?)"#,
'Found link in mail' );
$query = $1;
2018-11-26 14:40:21 +01:00
ok(
$res = $client->_get(
2018-11-16 22:02:43 +01:00
'/resetpwd',
query => $query,
accept => 'text/html'
),
2018-01-24 22:32:08 +01:00
'Post mail token received by mail'
);
2018-11-16 22:02:43 +01:00
# Post mismatched passwords
2018-01-24 22:32:08 +01:00
( $host, $url, $query ) = expectForm( $res, '#', undef, 'token' );
2022-05-15 23:36:12 +02:00
ok( $res->[2]->[0] =~ /newpassword/s, ' Ask for a new password #1' )
or print STDERR Dumper( $res->[2]->[0] );
ok(
$res->[2]->[0] =~
2022-06-23 12:12:25 +02:00
m%<i id="toggle_newpassword" class="fa fa-eye-slash toggle-password">%,
2022-05-15 23:36:12 +02:00
' toggle newpassword icon found'
) or print STDERR Dumper( $res->[2]->[0] );
ok(
$res->[2]->[0] =~
2022-06-23 12:12:25 +02:00
m%<i id="toggle_confirmpassword" class="fa fa-eye-slash toggle-password">%,
2022-05-15 23:36:12 +02:00
' toggle confirmpassword icon found'
) or print STDERR Dumper( $res->[2]->[0] );
ok(
$res->[2]->[0] =~
m%<input id="newpassword" name="newpassword" type="password" class="form-control"%,
' input type password found'
) or print STDERR Dumper( $res->[2]->[0] );
2018-01-24 22:32:08 +01:00
2018-11-16 22:02:43 +01:00
$query .= '&newpassword=zz&confirmpassword=z';
2018-11-26 14:40:21 +01:00
ok(
$res = $client->_post(
2018-11-16 22:02:43 +01:00
'/resetpwd', IO::String->new($query),
length => length($query),
accept => 'text/html'
),
'Post mismatched passwords'
);
ok( $res->[2]->[0] =~ m%<span trmsg="34"></span>%, 'PE_34 found' )
2018-11-26 14:40:21 +01:00
or print STDERR Dumper( $res->[2]->[0] );
2018-11-16 22:02:43 +01:00
# Post empty password 1
( $host, $url, $query ) = expectForm( $res, '#', undef, 'token' );
ok( $res->[2]->[0] =~ /newpassword/s, ' Ask for a new password #2' );
$query .= '&newpassword=&confirmpassword=zz';
2018-11-26 14:40:21 +01:00
ok(
$res = $client->_post(
2018-11-16 22:02:43 +01:00
'/resetpwd', IO::String->new($query),
length => length($query),
accept => 'text/html'
),
'Post empty newpassword'
);
ok( $res->[2]->[0] =~ m%<span trmsg="67"></span>%, 'PE_67 found' )
2018-11-26 14:40:21 +01:00
or print STDERR Dumper( $res->[2]->[0] );
2018-11-16 22:02:43 +01:00
# Post empty password 2
( $host, $url, $query ) = expectForm( $res, '#', undef, 'token' );
2022-05-15 23:36:12 +02:00
ok( $res->[2]->[0] =~ /newpassword/s, ' Ask for a new password #3' )
or print STDERR Dumper( $res->[2]->[0] );
2018-11-16 22:02:43 +01:00
$query .= '&newpassword=zz&confirmpassword=';
2018-11-26 14:40:21 +01:00
ok(
$res = $client->_post(
2018-11-16 22:02:43 +01:00
'/resetpwd', IO::String->new($query),
length => length($query),
accept => 'text/html'
),
'Post empty confirmpassword'
);
ok( $res->[2]->[0] =~ m%<span trmsg="67"></span>%, 'PE_67 found' )
2018-11-26 14:40:21 +01:00
or print STDERR Dumper( $res->[2]->[0] );
2018-01-24 22:32:08 +01:00
# Post new password
2018-11-16 22:02:43 +01:00
( $host, $url, $query ) = expectForm( $res, '#', undef, 'token' );
ok( $res->[2]->[0] =~ /newpassword/s, ' Ask for a new password #4' );
2022-05-13 23:27:52 +02:00
ok(
$res->[2]->[0] !~ /passwordPolicySpecialChar/,
' Password special char list not found'
);
ok(
$res->[2]->[0] =~
/<span trspan="passwordPolicyMinDigit">Minimal digit characters:<\/span> 2/,
' Found password policy min digit == 2'
);
$query .= '&newpassword=zz11#&confirmpassword=zz11#';
2018-11-26 14:40:21 +01:00
ok(
$res = $client->_post(
2018-01-24 22:32:08 +01:00
'/resetpwd', IO::String->new($query),
length => length($query),
accept => 'text/html'
),
'Post new password'
);
ok( mail() =~ /Your password was changed/, 'Password was changed' );
2018-11-26 14:40:21 +01:00
ok(
$res = $client->_post(
'/',
2022-05-13 23:27:52 +02:00
IO::String->new('user=dwho&password=zz11#'),
length => 24
),
'Auth query'
);
expectOK($res);
my $id = expectCookie($res);
$client->logout($id);
2018-01-24 22:32:08 +01:00
#print STDERR Dumper($query);
}
count($maintests);
2018-01-24 22:32:08 +01:00
clean_sessions();
done_testing( count() );