Bug 22899: Add pending_hold method to Koha::Item
[koha.git] / t / db_dependent / Koha / Item.t
1 #!/usr/bin/perl
2
3 # Copyright 2019 Koha Development team
4 #
5 # This file is part of Koha
6 #
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
11 #
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
16 #
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
19
20 use Modern::Perl;
21
22 use Test::More tests => 2;
23
24 use Koha::Items;
25 use Koha::Database;
26
27 use t::lib::TestBuilder;
28 use t::lib::Mocks;
29
30 my $schema  = Koha::Database->new->schema;
31 my $builder = t::lib::TestBuilder->new;
32
33 subtest 'hidden_in_opac() tests' => sub {
34
35     plan tests => 4;
36
37     $schema->storage->txn_begin;
38
39     my $item  = $builder->build_sample_item({ itemlost => 2 });
40     my $rules = {};
41
42     # disable hidelostitems as it interteres with OpachiddenItems for the calculation
43     t::lib::Mocks::mock_preference( 'hidelostitems', 0 );
44
45     ok( !$item->hidden_in_opac, 'No rules passed, shouldn\'t hide' );
46     ok( !$item->hidden_in_opac({ rules => $rules }), 'Empty rules passed, shouldn\'t hide' );
47
48     # enable hidelostitems to verify correct behaviour
49     t::lib::Mocks::mock_preference( 'hidelostitems', 1 );
50     ok( $item->hidden_in_opac, 'Even with no rules, item should hide because of hidelostitems syspref' );
51
52     # disable hidelostitems
53     t::lib::Mocks::mock_preference( 'hidelostitems', 0 );
54     my $withdrawn = $item->withdrawn + 1; # make sure this attribute doesn't match
55
56     $rules = { withdrawn => [$withdrawn], itype => [ $item->itype ] };
57
58     ok( $item->hidden_in_opac({ rules => $rules }), 'Rule matching itype passed, should hide' );
59
60
61
62     $schema->storage->txn_rollback;
63 };
64
65 subtest 'pending_hold() tests' => sub {
66
67     plan tests => 3;
68
69     $schema->storage->txn_begin;
70
71     my $dbh = C4::Context->dbh;
72     my $item  = $builder->build_sample_item({ itemlost => 0 });
73     my $itemnumber = $item->itemnumber;
74
75     # disable AllowItemsOnHoldCheckout as it ignores pending holds
76     t::lib::Mocks::mock_preference( 'AllowItemsOnHoldCheckout', 0 );
77     $dbh->do("INSERT INTO tmp_holdsqueue (surname,borrowernumber,itemnumber) VALUES ('Clamp',42,$itemnumber)");
78     ok( $item->pending_hold, "Yes, we have a pending hold");
79     t::lib::Mocks::mock_preference( 'AllowItemsOnHoldCheckout', 1 );
80     ok( !$item->pending_hold, "We don't consider a pending hold if hold items can be checked out");
81     t::lib::Mocks::mock_preference( 'AllowItemsOnHoldCheckout', 0 );
82     $dbh->do("DELETE FROM tmp_holdsqueue WHERE itemnumber=$itemnumber");
83     ok( !$item->pending_hold, "We don't have a pending hold if nothing in the tmp_holdsqueue");
84 };