76d1509838
This is a collection of changes taken from different comments (but mostly comment 21 and comment 122). Passes qa and prove, on my machine at least. There's also a new test file, Passwordrecovery.t, which covers every method of C4::Passwordrecovery. To test: All normal checks plus : 1/ Receive the email 2/ Click on the link 3/ Change the pwd 4/ Click again on the link 5/ You should immediately get an error message Problems with Math/Random/Secure.pm, is solved in following patch, signing off Signed-off-by: Marc Veron <veron@veron.ch> Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl>
157 lines
6.1 KiB
Perl
Executable file
157 lines
6.1 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# This file is part of Koha.
|
|
#
|
|
# Koha is free software; you can redistribute it and/or modify it
|
|
# under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# Koha is distributed in the hope that it will be useful, but
|
|
# WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with Koha; if not, see <http://www.gnu.org/licenses>.
|
|
|
|
use Modern::Perl;
|
|
|
|
use C4::Context;
|
|
use C4::Letters;
|
|
use Koha::Database;
|
|
use Koha::Borrowers;
|
|
|
|
use Test::More tests => 16;
|
|
|
|
use_ok('C4::Passwordrecovery');
|
|
|
|
my $schema = Koha::Database->new()->schema();
|
|
$schema->storage->txn_begin();
|
|
|
|
my $dbh = C4::Context->dbh;
|
|
$dbh->{RaiseError} = 1;
|
|
|
|
#
|
|
# Start with fresh data
|
|
#
|
|
|
|
my $borrowernumber1 = '2000000000';
|
|
my $borrowernumber2 = '2000000001';
|
|
my $userid1 = "I83MFItzRpGPxD3vW0";
|
|
my $userid2 = "Gh5t43980hfSAOcvne";
|
|
my $email1 = $userid1 . '@koha-community.org';
|
|
my $email2 = $userid2 . '@koha-community.org';
|
|
my $uuid1 = "ABCD1234";
|
|
my $uuid2 = "WXYZ0987";
|
|
|
|
my $categorycode = 'S'; # staff
|
|
my $branch = $schema->resultset('Branch')->first(); # legit branch from your db
|
|
|
|
$schema->resultset('BorrowerPasswordRecovery')->delete_all();
|
|
|
|
$schema->resultset('Borrower')->create(
|
|
{
|
|
borrowernumber => $borrowernumber1,
|
|
surname => '',
|
|
address => '',
|
|
city => '',
|
|
userid => $userid1,
|
|
email => $email1,
|
|
categorycode => $categorycode,
|
|
branchcode => $branch,
|
|
}
|
|
);
|
|
$schema->resultset('Borrower')->create(
|
|
{
|
|
borrowernumber => $borrowernumber2,
|
|
surname => '',
|
|
address => '',
|
|
city => '',
|
|
userid => $userid2,
|
|
email => $email2,
|
|
categorycode => $categorycode,
|
|
branchcode => $branch,
|
|
}
|
|
);
|
|
|
|
$schema->resultset('BorrowerPasswordRecovery')->create(
|
|
{
|
|
borrowernumber => $borrowernumber1,
|
|
uuid => $uuid1,
|
|
valid_until => DateTime->now( time_zone => C4::Context->tz() )->add( days => 2 )->datetime()
|
|
}
|
|
);
|
|
$schema->resultset('BorrowerPasswordRecovery')->create(
|
|
{
|
|
borrowernumber => $borrowernumber2,
|
|
uuid => $uuid2,
|
|
valid_until => DateTime->now( time_zone => C4::Context->tz() )->subtract( days => 2 )->datetime()
|
|
}
|
|
);
|
|
|
|
can_ok( "C4::Passwordrecovery", qw(ValidateBorrowernumber GetValidLinkInfo SendPasswordRecoveryEmail CompletePasswordRecovery) );
|
|
|
|
################################################
|
|
# C4::Passwordrecovery::ValidateBorrowernumber #
|
|
################################################
|
|
|
|
ok( C4::Passwordrecovery::ValidateBorrowernumber($borrowernumber1), "[ValidateBorrowernumber] Borrower has a password recovery entry" );
|
|
ok( ! C4::Passwordrecovery::ValidateBorrowernumber($borrowernumber2), "[ValidateBorrowernumber] Borrower's number is not found; password recovery entry is expired" );
|
|
ok( ! C4::Passwordrecovery::ValidateBorrowernumber(9999), "[ValidateBorrowernumber] Borrower has no password recovery entry" );
|
|
|
|
##########################################
|
|
# C4::Passwordrecovery::GetValidLinkInfo #
|
|
##########################################
|
|
|
|
my ($bnum1, $uname1) = C4::Passwordrecovery::GetValidLinkInfo($uuid1);
|
|
my ($bnum2, $uname2) = C4::Passwordrecovery::GetValidLinkInfo($uuid2);
|
|
my ($bnum3, $uname3) = C4::Passwordrecovery::GetValidLinkInfo("THISISANINVALIDUUID");
|
|
|
|
is( $bnum1, $borrowernumber1, "[GetValidLinkInfo] Borrower has a valid link" );
|
|
is( $uname1, $userid1, "[GetValidLinkInfo] Borrower's username is fetched when a valid link is found" );
|
|
ok( ! defined($bnum2), "[GetValidLinkInfo] Borrower's link is no longer valid; entry is expired" );
|
|
ok( ! defined($bnum3), "[GetValidLinkInfo] Invalid UUID returns no borrowernumber" );
|
|
|
|
##################################################
|
|
# C4::Passwordrecovery::CompletePasswordRecovery #
|
|
##################################################
|
|
|
|
ok( C4::Passwordrecovery::CompletePasswordRecovery($uuid1) == 2, "[CompletePasswordRecovery] Completing a password recovery deletes the entry and expired entries" );
|
|
|
|
$schema->resultset('BorrowerPasswordRecovery')->create(
|
|
{
|
|
borrowernumber => $borrowernumber2,
|
|
uuid => $uuid2,
|
|
valid_until => DateTime->now( time_zone => C4::Context->tz() )->subtract( days => 2 )->datetime()
|
|
}
|
|
);
|
|
|
|
ok( C4::Passwordrecovery::CompletePasswordRecovery($uuid2) == 1, "[CompletePasswordRecovery] An expired or invalid UUID purges expired entries" );
|
|
ok( C4::Passwordrecovery::CompletePasswordRecovery($uuid2) == 0, "[CompletePasswordRecovery] Returns 0 on a clean table" );
|
|
|
|
###################################################
|
|
# C4::Passwordrecovery::SendPasswordRecoveryEmail #
|
|
###################################################
|
|
|
|
my $borrower = shift [ Koha::Borrowers->search( { userid => $userid1 } ) ];
|
|
ok( C4::Passwordrecovery::SendPasswordRecoveryEmail($borrower, $email1, 0) == 1, "[SendPasswordRecoveryEmail] Returns 1 on success" );
|
|
my $letters = C4::Letters::GetQueuedMessages( { borrowernumber => $borrowernumber1, limit => 99 } );
|
|
ok( scalar @$letters == 1, "[SendPasswordRecoveryEmail] There is a letter in the queue for our borrower");
|
|
|
|
my $bpr = $schema->resultset('BorrowerPasswordRecovery')->search( { borrowernumber => $borrowernumber1 } );
|
|
my $tempuuid1 = $bpr->next->uuid;
|
|
|
|
C4::Passwordrecovery::SendPasswordRecoveryEmail($borrower, $email1, 1);
|
|
|
|
$bpr = $schema->resultset('BorrowerPasswordRecovery')->search( { borrowernumber => $borrowernumber1 } );
|
|
my $tempuuid2 = $bpr->next->uuid;
|
|
|
|
$letters = C4::Letters::GetQueuedMessages( { borrowernumber => $borrowernumber1, limit => 99 } );
|
|
|
|
ok( $tempuuid1 ne $tempuuid2, "[SendPasswordRecoveryEmail] UPDATE == ON changes uuid in the database and updates the expirydate");
|
|
ok( scalar @$letters == 2, "[SendPasswordRecoveryEmail] UPDATE == ON sends a new letter with updated uuid");
|
|
|
|
$schema->storage->txn_rollback();
|
|
|
|
1;
|