Bug 12748 - Fixes duplicate serials with an "expected" status bug

Added a new sub to Serials.pm to be able to get serials with their statuses.
Now the sub ModSerialStatus checks for other serials with an "expected" status before doing anything.

Also modified Serials.t to be able to test those changes.

Test Plan
1) Apply patch
2) Run ./t/db_dependent/Serials.t
3) Validate that there are no errors
4) Go on "Serial collection information" page for a serial of your choice
5) Click on "Generate next"
6) Change the status of the original serial from "late" to "expected"
7) Change the newly generated serial from "expected" to "delete"
8) Validate that there are no new serials created by instruction 7 and that the serial was deleted
9) Run ./t/db_dependent/Serials.t

With QA Fixes

- Use the constant instead of the code (1 vs EXPECTED)
- Avoid interpolation in query
- use selectall_arrayref instead of fetchall_arrayref

Signed-off-by: Liz Rea <liz@catalyst.net.nz>

Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>

Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com>
This commit is contained in:
remi 2015-08-11 11:10:45 -04:00 committed by Kyle M Hall
parent 42cd9ca144
commit 10fd9f5ec0
2 changed files with 26 additions and 3 deletions

View file

@ -1174,8 +1174,10 @@ sub ModSerialStatus {
}
}
# create new waited entry if needed (ie : was a "waited" and has changed)
if ( $oldstatus == EXPECTED && $status != EXPECTED ) {
# create new expected entry if needed (ie : was "expected" and has changed)
# BUG 12748: Check if there are no other expected issues.
my $otherIssueExpected = scalar findSerialByStatus(EXPECTED, $subscriptionid);
if ( !$otherIssueExpected && $oldstatus == EXPECTED && $status != EXPECTED ) {
my $subscription = GetSubscription($subscriptionid);
my $pattern = C4::Serials::Numberpattern::GetSubscriptionNumberpattern($subscription->{numberpattern});
@ -2697,6 +2699,24 @@ sub _can_do_on_subscription {
return 0;
}
=head2 findSerialByStatus
@serials = findSerialByStatus($status, $subscriptionid);
Returns an array of serials matching a given status and subscription id.
=cut
sub findSerialByStatus{
my($status, $subscriptionid) = @_;
my $dbh = C4::Context->dbh;
my $query = q| SELECT * from serial
WHERE status = ?
AND subscriptionid = ?
|;
my $serials = $dbh->selectall_arrayref( $query, { Slice => {} }, $status, $subscriptionid );
return @$serials;
}
1;
__END__

5
t/db_dependent/Serials.t Normal file → Executable file
View file

@ -15,7 +15,7 @@ use C4::Bookseller;
use C4::Biblio;
use C4::Budgets;
use Koha::DateUtils;
use Test::More tests => 45;
use Test::More tests => 48;
BEGIN {
use_ok('C4::Serials');
@ -173,6 +173,7 @@ is(C4::Serials::ModSubscriptionHistory(), undef, 'test modding subscription hist
is(C4::Serials::ModSerialStatus(),undef, 'test modding serials');
is(C4::Serials::findSerialByStatus(), 0, 'test finding serial by status with no parameters');
is(C4::Serials::NewIssue(), undef, 'test getting 0 when nothing is entered');
is(C4::Serials::HasSubscriptionStrictlyExpired(), undef, 'test if the subscriptions has expired');
@ -218,6 +219,8 @@ for my $status ( @statuses ) {
$counter++;
}
# Here we have 15 serials with statuses : 2*2 + 5*3 + 2*4 + 1*41 + 1*42 + 1*43 + 1*44 + 1*5 + 1*1
my @serialsByStatus = C4::Serials::findSerialByStatus(2,$subscriptionid);
is(@serialsByStatus,2,"findSerialByStatus returns all serials with chosen status");
( $total_issues, @serials ) = C4::Serials::GetSerials( $subscriptionid );
is( $total_issues, @statuses + 1, "GetSerials returns total_issues" );
my @arrived_missing = map { my $status = $_->{status}; ( grep { /^$status$/ } qw( 2 4 41 42 43 44 5 ) ) ? $_ : () } @serials;