Bug 14494: Unit tests for CanBookBeIssued related to dateexpiry
authorJonathan Druart <jonathan.druart@koha-community.org>
Thu, 9 Jul 2015 08:52:28 +0000 (09:52 +0100)
committerTomas Cohen Arazi <tomascohen@unc.edu.ar>
Mon, 20 Jul 2015 13:16:24 +0000 (10:16 -0300)
Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl>
Moved the test on its own. Nicer than adding TestBuilder in the final part
of the test. No warnings/errors from TestBuilder, no dependency..

Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com>
Signed-off-by: Tomas Cohen Arazi <tomascohen@unc.edu.ar>
t/db_dependent/Circulation_dateexpiry.t [new file with mode: 0644]

diff --git a/t/db_dependent/Circulation_dateexpiry.t b/t/db_dependent/Circulation_dateexpiry.t
new file mode 100644 (file)
index 0000000..0c4d728
--- /dev/null
@@ -0,0 +1,68 @@
+#!/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 DateTime;
+use Time::HiRes qw/gettimeofday/;
+use C4::Members;
+use Koha::DateUtils;
+use t::lib::TestBuilder;
+use Test::More tests => 1;
+
+subtest 'Tests for CanBookBeIssued related to dateexpiry' => sub {
+    plan tests => 4;
+    date_expiry();
+};
+
+sub date_expiry {
+    my $builder = t::lib::TestBuilder->new();
+    my $item    = $builder->build( { source => 'Item' } );
+    my $patron  = $builder->build(
+        {   source => 'Borrower',
+            value  => { dateexpiry => '9999-12-31' }
+        }
+    );
+    $patron->{flags} = C4::Members::patronflags( $patron );
+    my $duration = gettimeofday();
+    my ( $issuingimpossible, $needsconfirmation ) = C4::Circulation::CanBookBeIssued( $patron, $item->{barcode} );
+    $duration = gettimeofday() - $duration;
+    cmp_ok $duration, '<', 1, "CanBookBeIssued should not be take more than 1s if the patron is expired";
+    is( not( exists $issuingimpossible->{EXPIRED} ), 1, 'The patron should not be considered as expired if dateexpiry is 9999-*' );
+
+    $item = $builder->build( { source => 'Item' } );
+    $patron = $builder->build(
+        {   source => 'Borrower',
+            value  => { dateexpiry => '0000-00-00' }
+        }
+    );
+    $patron->{flags} = C4::Members::patronflags( $patron );
+    ( $issuingimpossible, $needsconfirmation ) = C4::Circulation::CanBookBeIssued( $patron, $item->{barcode} );
+    is( $issuingimpossible->{EXPIRED}, 1, 'The patron should be considered as expired if dateexpiry is 0000-00-00' );
+
+    my $tomorrow = dt_from_string->add_duration( DateTime::Duration->new( days => 1 ) );
+    $item = $builder->build( { source => 'Item' } );
+    $patron = $builder->build(
+        {   source => 'Borrower',
+            value  => { dateexpiry => output_pref( { dt => $tomorrow, dateonly => 1, dateformat => 'sql' } ) },
+        }
+    );
+    $patron->{flags} = C4::Members::patronflags( $patron );
+    ( $issuingimpossible, $needsconfirmation ) = C4::Circulation::CanBookBeIssued( $patron, $item->{barcode} );
+    is( not( exists $issuingimpossible->{EXPIRED} ), 1, 'The patron should not be considered as expired if dateexpiry is tomorrow' );
+
+}