Koha/t/db_dependent/Reserves/CancelExpiredReserves.t
Fridolin Somers caa1712d9f Bug 29976: (Bug 21729 follow-up) fix holds unit tests
Bug 21729 added to holds table the column patron_expiration_date.

Currently test suite is failing :
https://jenkins.koha-community.org/view/master/job/Koha_Master_D10/516/testReport/

We must fix where TestBuilder is creating with source Reserve and data expirationdate :
  t/db_dependent/Holds/WaitingReserves.t
  t/db_dependent/Reserves/CancelExpiredReserves.t

Note that t/db_dependent/Reserves/CancelExpiredReserves.t does not fail
without this patch but surely we prefere change it also.

Test plan :
prove t/db_dependent/Holds/WaitingReserves.t
prove t/db_dependent/Reserves/CancelExpiredReserves.t

Signed-off-by: David Nind <david@davidnind.com>

Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
Signed-off-by: Fridolin Somers <fridolin.somers@biblibre.com>
2022-02-01 21:39:39 -10:00

226 lines
7.1 KiB
Perl
Executable file

#!/usr/bin/perl
use Modern::Perl;
use Test::More tests => 4;
use t::lib::Mocks;
use t::lib::TestBuilder;
use C4::Members;
use C4::Reserves qw( CancelExpiredReserves );
use Koha::Database;
use Koha::DateUtils qw( dt_from_string );
use Koha::Holds;
my $schema = Koha::Database->new->schema;
$schema->storage->txn_begin;
subtest 'CancelExpiredReserves tests incl. holidays' => sub {
plan tests => 4;
my $builder = t::lib::TestBuilder->new();
t::lib::Mocks::mock_preference('ExpireReservesOnHolidays', 0);
# Waiting holds could be cancelled only if ExpireReservesMaxPickUpDelay is set to "allow", see bug 19260
t::lib::Mocks::mock_preference('ExpireReservesMaxPickUpDelay', 1);
my $today = dt_from_string();
my $reserve_reservedate = $today->clone;
$reserve_reservedate->subtract(days => 30);
my $reserve1_expirationdate = $today->clone;
$reserve1_expirationdate->add(days => 1);
# Reserve not expired
my $reserve1 = $builder->build({
source => 'Reserve',
value => {
reservedate => $reserve_reservedate,
patron_expiration_date => $reserve1_expirationdate,
cancellationdate => undef,
priority => 0,
found => 'W',
},
});
CancelExpiredReserves();
my $r1 = Koha::Holds->find($reserve1->{reserve_id});
ok($r1, 'Reserve 1 should not be canceled.');
my $reserve2_expirationdate = $today->clone;
$reserve2_expirationdate->subtract(days => 1);
# Reserve expired
my $reserve2 = $builder->build({
source => 'Reserve',
value => {
reservedate => $reserve_reservedate,
patron_expiration_date => $reserve2_expirationdate,
cancellationdate => undef,
priority => 0,
found => 'W',
},
});
CancelExpiredReserves();
my $r2 = Koha::Holds->find($reserve2->{reserve_id});
is($r2, undef,'reserve 2 should be canceled.');
# Reserve expired on holiday
my $reserve3 = $builder->build({
source => 'Reserve',
value => {
reservedate => $reserve_reservedate,
patron_expiration_date => $reserve2_expirationdate,
branchcode => 'LIB1',
cancellationdate => undef,
priority => 0,
found => 'W',
},
});
Koha::Caches->get_instance()->flush_all();
my $holiday = $builder->build({
source => 'SpecialHoliday',
value => {
branchcode => 'LIB1',
day => $today->day,
month => $today->month,
year => $today->year,
title => 'My holiday',
isexception => 0
},
});
CancelExpiredReserves();
my $r3 = Koha::Holds->find($reserve3->{reserve_id});
ok($r3,'Reserve 3 should not be canceled.');
t::lib::Mocks::mock_preference('ExpireReservesOnHolidays', 1);
CancelExpiredReserves();
$r3 = Koha::Holds->find($reserve3->{reserve_id});
is($r3, undef,'Reserve 3 should be canceled.');
};
subtest 'Test handling of waiting reserves by CancelExpiredReserves' => sub {
plan tests => 2;
Koha::Holds->delete;
my $builder = t::lib::TestBuilder->new();
my $category = $builder->build({ source => 'Category' });
my $branchcode = $builder->build({ source => 'Branch' })->{ branchcode };
my $item = $builder->build_sample_item;
my $itemnumber = $item->itemnumber;
my $borrowernumber = $builder->build({ source => 'Borrower', value => { categorycode => $category->{categorycode}, branchcode => $branchcode }})->{borrowernumber};
my $resdate = dt_from_string->add( days => -20 );
my $expdate = dt_from_string->add( days => -2 );
my $notexpdate = dt_from_string->add( days => 2 );
my $hold1 = Koha::Hold->new({
branchcode => $branchcode,
borrowernumber => $borrowernumber,
biblionumber => $item->biblionumber,
priority => 1,
reservedate => $resdate,
expirationdate => $notexpdate,
found => undef,
})->store;
my $hold2 = Koha::Hold->new({
branchcode => $branchcode,
borrowernumber => $borrowernumber,
biblionumber => $item->biblionumber,
priority => 2,
reservedate => $resdate,
expirationdate => $expdate,
found => undef,
})->store;
my $hold3 = Koha::Hold->new({
branchcode => $branchcode,
borrowernumber => $borrowernumber,
biblionumber => $item->biblionumber,
itemnumber => $itemnumber,
priority => 0,
reservedate => $resdate,
expirationdate => $expdate,
found => 'W',
})->store;
t::lib::Mocks::mock_preference( 'ExpireReservesMaxPickUpDelay', 0 );
CancelExpiredReserves();
my $count1 = Koha::Holds->search->count;
is( $count1, 2, 'Only the non-waiting expired holds should be cancelled');
t::lib::Mocks::mock_preference( 'ExpireReservesMaxPickUpDelay', 1 );
CancelExpiredReserves();
my $count2 = Koha::Holds->search->count;
is( $count2, 1, 'Also the waiting expired hold should be cancelled now');
};
subtest 'Test handling of in transit reserves by CancelExpiredReserves' => sub {
plan tests => 2;
my $builder = t::lib::TestBuilder->new();
t::lib::Mocks::mock_preference( 'ExpireReservesMaxPickUpDelay', 1 );
my $expdate = dt_from_string->add( days => -2 );
my $reserve = $builder->build({
source => 'Reserve',
value => {
patron_expiration_date => '2018-01-01',
found => 'T',
cancellationdate => undef,
suspend => 0,
suspend_until => undef
}
});
my $count = Koha::Holds->search->count;
CancelExpiredReserves();
is(Koha::Holds->search->count, $count-1, "Transit hold is cancelled if ExpireReservesMaxPickUpDelay set");
t::lib::Mocks::mock_preference( 'ExpireReservesMaxPickUpDelay', 0 );
my $reserve2 = $builder->build({
source => 'Reserve',
value => {
patron_expiration_date => '2018-01-01',
found => 'T',
cancellationdate => undef,
suspend => 0,
suspend_until => undef
}
});
CancelExpiredReserves();
is(Koha::Holds->search->count, $count-1, "Transit hold is cancelled if ExpireReservesMaxPickUpDelay unset");
};
subtest 'Test handling of cancellation reason if passed' => sub {
plan tests => 2;
my $builder = t::lib::TestBuilder->new();
my $expdate = dt_from_string->add( days => -2 );
my $reserve = $builder->build({
source => 'Reserve',
value => {
patron_expiration_date => '2018-01-01',
found => 'T',
cancellationdate => undef,
suspend => 0,
suspend_until => undef
}
});
my $reserve_id = $reserve->{reserve_id};
my $count = Koha::Holds->search->count;
CancelExpiredReserves("EXPIRED");
is(Koha::Holds->search->count, $count-1, "Hold is cancelled when reason is passed");
my $old_reserve = Koha::Old::Holds->find($reserve_id);
is($old_reserve->cancellation_reason, 'EXPIRED', "Hold cancellation_reason was set correctly");
};
$schema->storage->txn_rollback;