Bug 11258: fix another case where holds queue made transfer requests that contradict...
authorKyle M Hall <kyle@bywatersolutions.com>
Fri, 15 Nov 2013 16:29:23 +0000 (08:29 -0800)
committerGalen Charlton <gmc@esilibrary.com>
Fri, 18 Apr 2014 15:23:23 +0000 (15:23 +0000)
commit79660377470e8d6ba9057eb59645886410852c92
tree5252c2fc3bf3573e573874b833525b0f17aa145a
parent0eff486041de1b37db73f21a4771593c4993990e
Bug 11258: fix another case where holds queue made transfer requests that contradict the library holds policy

This patch fixes a problem where the holds queue generator
was making requests where the pickup library is the
same as the item's library but not the patron's branch,
even if there is a "Default holds policy by item type" rule that states
this item can only fill holds for patrons of the same library as the
item.

Test Plan:
1) Create a test record with 2 items with different itemtypes
2) Set the Default holds policy by item type for the first
   item to "From any library"
3) Set the Default holds policy by item type for the second
   item to "From home library"
4) Place a record level hold for a patron from another library,
   but for pickup at the same library as the item is from
5) Rebuild the holds queue
6) View the holds queue, note the item is listed, though this
   patron cannot place a hold on this item
7) Apply this patch
8) Repeat step 5, note the hold is no longer in the queue

Signed-off-by: Liz Rea <liz@catalyst.net.nz>
automated tests pass, functional tests pass. Bug replicated, eradicated by patch.

Signed-off-by: Katrin Fischer <Katrin.Fischer.83@web.de>
I finally managed to reproduce this, patch works as described.
Passes tests and QA script, provided tests fail without patch, but
succeed with the patch.

Signed-off-by: Galen Charlton <gmc@esilibrary.com>
C4/HoldsQueue.pm
t/db_dependent/HoldsQueue.t