From: Bill Erickson Date: Tue, 29 Jul 2014 19:11:44 +0000 (-0400) Subject: LP#1308239 precat holds fulfillment logic repair X-Git-Url: https://old-git.evergreen-ils.org/?a=commitdiff_plain;h=e46f3323b4acb152d666b92c0ba5f4442b9ac2c0;p=evergreen%2Fpines.git LP#1308239 precat holds fulfillment logic repair In cases where there is no hold on a precat copy, avoid trying to find "related" holds, in part because it's unnecessary, but also because the implementation assumes a fleshed $self->volume object, which is not present during precat checkout. Signed-off-by: Bill Erickson Signed-off-by: Jason Stephenson --- diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ/Circulate.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ/Circulate.pm index 896102d3af..f37c0fbf44 100644 --- a/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ/Circulate.pm +++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ/Circulate.pm @@ -1792,7 +1792,9 @@ sub find_related_user_hold { my($self, $copy, $patron) = @_; my $e = $self->editor; - return undef if $self->volume->id == OILS_PRECAT_CALL_NUMBER; + # holds on precat copies are always copy-level, so this call will + # always return undef. Exit early. + return undef if $self->is_precat; return undef unless $U->ou_ancestor_setting_value( $self->circ_lib, 'circ.checkout_fills_related_hold', $e);