return $self;
}
+=head3 pending_hold
+
+ my $is_pending_hold = $item->pending_hold();
+
+This method checks the tmp_holdsqueue to see if this item has been selected for a hold, but not filled yet and returns true or false
+
+=cut
+
+sub pending_hold {
+ my ( $self ) = @_;
+ my $pending_hold = $self->_result->tmp_holdsqueues;
+ return !C4::Context->preference('AllowItemsOnHoldCheckout') && $pending_hold->count ? 1: 0;
+}
+
=head2 Internal methods
=head3 _type
use Modern::Perl;
-use Test::More tests => 1;
+use Test::More tests => 2;
use Koha::Items;
use Koha::Database;
$schema->storage->txn_rollback;
};
+
+subtest 'pending_hold() tests' => sub {
+
+ plan tests => 3;
+
+ $schema->storage->txn_begin;
+
+ my $dbh = C4::Context->dbh;
+ my $item = $builder->build_sample_item({ itemlost => 0 });
+ my $itemnumber = $item->itemnumber;
+
+ # disable AllowItemsOnHoldCheckout as it ignores pending holds
+ t::lib::Mocks::mock_preference( 'AllowItemsOnHoldCheckout', 0 );
+ $dbh->do("INSERT INTO tmp_holdsqueue (surname,borrowernumber,itemnumber) VALUES ('Clamp',42,$itemnumber)");
+ ok( $item->pending_hold, "Yes, we have a pending hold");
+ t::lib::Mocks::mock_preference( 'AllowItemsOnHoldCheckout', 1 );
+ ok( !$item->pending_hold, "We don't consider a pending hold if hold items can be checked out");
+ t::lib::Mocks::mock_preference( 'AllowItemsOnHoldCheckout', 0 );
+ $dbh->do("DELETE FROM tmp_holdsqueue WHERE itemnumber=$itemnumber");
+ ok( !$item->pending_hold, "We don't have a pending hold if nothing in the tmp_holdsqueue");
+};