From: Fridolin Somers Date: Fri, 12 Sep 2014 13:21:18 +0000 (+0200) Subject: Bug 12913 - wrong inventory results when notforloan filter is not used X-Git-Url: http://git.rot13.org/?a=commitdiff_plain;h=358fb744c74cc63b7d2ae7d7e406ada205502ea8;p=koha.git Bug 12913 - wrong inventory results when notforloan filter is not used In inventory tool, there is a test on scanned items notforloan value : if the value is not one of authorized values, the inventory results displays the problem "Change item status". The bug is that if notforloan filter is not used, the notforloan values array is not filled and so all scanned items are marked with this problem. Test plan : - Check you have in default framework an item subfield mapped with items.notforloan and with an authorized value catergory, for example 'NOTFORLOAN' - Check the authorized value category has at least value '0' - Create a new value in this category, for example '9' - Create a biblio with default framework - Create an item with barcode='000AAA1', callnumber='ZZZAAA1' and notforloan=0 - Create an item with barcode='000AAA2', callnumber='ZZZAAA2' and notforloan=9 - Delete new value created above, for example '9' - Create a file 'barecodes.txt' containing 2 lines '000AAA1' and '000AAA2' - Go to inventory tool : /cgi-bin/koha/tools/inventory.pl - Choose file in 'Barcode file' - Enter item callnumber between 'ZZZ' and 'ZZZZ' - Check 'Compare barcodes list to results' - Submit => without patch, you get 2 results with problem 'Change item status' even for item with notforloan=0 => with patch, you get 1 result with 'Change item status' on item with notforloan=9 Signed-off-by: Nick Clemens Signed-off-by: Marcel de Rooy Signed-off-by: Kyle M Hall --- diff --git a/tools/inventory.pl b/tools/inventory.pl index ca98765c51..be57303837 100755 --- a/tools/inventory.pl +++ b/tools/inventory.pl @@ -86,6 +86,7 @@ for my $fwk ( @$frameworks ){ } my $statuses = []; +my @notforloans; for my $statfield (qw/items.notforloan items.itemlost items.withdrawn items.damaged/){ my $hash = {}; $hash->{fieldname} = $statfield; @@ -95,6 +96,9 @@ for my $statfield (qw/items.notforloan items.itemlost items.withdrawn items.dama my $arr = GetAuthorisedValues($hash->{authcode}); $hash->{values} = $arr; push @$statuses, $hash; + if ( $statfield eq 'items.notforloan') { + @notforloans = map { $_->{'authorised_value'} } @$arr; + } } } @@ -110,16 +114,6 @@ for my $authvfield (@$statuses) { } } -my $notforloanlist; -my $statussth = ''; -for my $authvfield (@$statuses) { - if ( scalar @{$staton->{$authvfield->{fieldname}}} > 0 ){ - my $joinedvals = join ',', @{$staton->{$authvfield->{fieldname}}}; - $statussth .= "$authvfield->{fieldname} in ($joinedvals) and "; - $notforloanlist = $joinedvals if ($authvfield->{fieldname} eq "items.notforloan"); - } -} -$statussth =~ s, and $,,g; $template->param( authorised_values => \@authorised_value_list, today => dt_from_string, @@ -131,14 +125,8 @@ $template->param( branch => $branch, datelastseen => $datelastseen, compareinv2barcd => $compareinv2barcd, - notforloanlist => $notforloanlist ); -my @notforloans; -if (defined $notforloanlist) { - @notforloans = split(/,/, $notforloanlist); -} - my @scanned_items; my @errorloop; if ( $uploadbarcodes && length($uploadbarcodes) > 0 ) {