From e9e6dc2ee92b036c291a4f71a766382042fc830d Mon Sep 17 00:00:00 2001 From: Galen Charlton Date: Thu, 5 May 2022 12:44:26 -0400 Subject: [PATCH] LP#1971745: work around issue that can cause large hold shelf lists to fail This patch addresses an issue where hold shelf lists with more than ~350 rows can fail to be retrieved. It works by making the open-ils.circ.hold.wide_hash.stream method fetch the holds from an open-ils.storage method in one fell swoop, rather than both streaming the list from open-ils.storage and streaming it back to the client that invoked the open-ils.circ method. I suspect that this is working around a subtle OpenSRF bug when bidirectional streaming is in play, but I'm not positive. To test ------- [1] Set up an environment with hundreds or thousands of holds on a shelf at an OU. [2] Attempt to display the holds shelf list. [3] It may fail; if it doesn't, try with even larger number of holds or by setting up a test system that has ejabberd s2s going on to service requests. [4] Apply the patch and repeat step 2. This time, the holds shelf list should be consistently retrieved. There will also be a user-visible change: the spinner on the AngularJS holds shelf page will pause for a few seconds, then start advancing. Signed-off-by: Galen Charlton Signed-off-by: Josh Stompro --- .../src/perlmods/lib/OpenILS/Application/Circ/Holds.pm | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ/Holds.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ/Holds.pm index 178278dcc5..6e9878be21 100644 --- a/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ/Holds.pm +++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ/Holds.pm @@ -3672,29 +3672,29 @@ sub stream_wide_holds { my $st = OpenSRF::AppSession->create('open-ils.storage'); my $req = $st->request( - 'open-ils.storage.action.live_holds.wide_hash', + 'open-ils.storage.action.live_holds.wide_hash.atomic', $restrictions, $order_by, $limit, $offset ); - my $count = $req->recv; - if(!$count) { + my $results = $req->recv; + if(!$results) { return 0; } - if(UNIVERSAL::isa($count,"Error")) { - throw $count ($count->stringify); + if(UNIVERSAL::isa($results,"Error")) { + throw OpenSRF::EX::ERROR ("Error fetch hold shelf list"); } - $count = $count->content; + my @rows = @{ $results->content }; # Force immediate send of count response my $mbc = $client->max_bundle_count; $client->max_bundle_count(1); - $client->respond($count); + $client->respond(shift @rows); $client->max_bundle_count($mbc); - while (my $hold = $req->recv) { - $client->respond($hold->content) if $hold->content; + foreach my $hold (@rows) { + $client->respond($hold) if $hold; } $client->respond_complete; -- 2.11.0