159 lines
4.5 KiB
Perl
Executable file
159 lines
4.5 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
#
|
|
# This file is a test script for C4::VirtualShelves.pm
|
|
# Author : Antoine Farnault, antoine@koha-fr.org
|
|
#
|
|
|
|
use Test;
|
|
use strict;
|
|
use C4::Context;
|
|
|
|
# Making 30 tests.
|
|
BEGIN { plan tests => 112 }
|
|
|
|
# Getting some borrowers from database.
|
|
my $dbh = C4::Context->dbh;
|
|
my $query = qq/
|
|
SELECT borrowernumber
|
|
FROM borrowers
|
|
LIMIT 10
|
|
/;
|
|
my $sth = $dbh->prepare($query);
|
|
$sth->execute;
|
|
my @borrowers;
|
|
while(my $borrower = $sth->fetchrow){
|
|
push @borrowers, $borrower;
|
|
}
|
|
|
|
# Getting some itemnumber from database
|
|
my $query = qq/
|
|
SELECT itemnumber
|
|
FROM items
|
|
LIMIT 10
|
|
/;
|
|
my $sth = $dbh->prepare($query);
|
|
$sth->execute;
|
|
my @items;
|
|
while(my $item = $sth->fetchrow){
|
|
push @items, $item;
|
|
}
|
|
|
|
# Getting some biblionumbers from database
|
|
my $query = qq/
|
|
SELECT biblionumber
|
|
FROM biblio
|
|
LIMIT 10
|
|
/;
|
|
my $sth = $dbh->prepare($query);
|
|
$sth->execute;
|
|
my @biblionumbers;
|
|
while(my $biblionumber = $sth->fetchrow){
|
|
push @biblionumbers, $biblionumber;
|
|
}
|
|
|
|
# ---
|
|
my $delete_virtualshelf = qq/
|
|
DELETE FROM virtualshelves WHERE 1
|
|
/;
|
|
my $delete_virtualshelfcontent =qq/
|
|
DELETE FROM virtualshelfcontents WHERE 1
|
|
/;
|
|
|
|
my $sth = $dbh->prepare($delete_virtualshelf);
|
|
$sth->execute;
|
|
my $sth = $dbh->prepare($delete_virtualshelfcontent);
|
|
$sth->execute;
|
|
# ---
|
|
|
|
#----------------------------------------------------------------------#
|
|
#
|
|
# TESTS START HERE
|
|
#
|
|
#----------------------------------------------------------------------#
|
|
|
|
use C4::VirtualShelves;
|
|
my $version = C4::VirtualShelves->VERSION;
|
|
print "\n----------Testing C4::VirtualShelves version ".$version."--------\n";
|
|
|
|
ok($version); # First test: the module is loaded & the version is readable.
|
|
|
|
|
|
#-----------------------TEST AddShelf function------------------------#
|
|
# usage : $shelfnumber = &AddShelf( $shelfname, $owner, $category);
|
|
|
|
# creating 10 good shelves.
|
|
my @shelves;
|
|
for(my $i=0; $i<10;$i++){
|
|
my $ShelfNumber = AddShelf("Shelf_".$i,$borrowers[$i] || '',int(rand(3))+1);
|
|
die "test Not ok, remove some shelves before" if ($ShelfNumber == -1);
|
|
ok($ShelfNumber); # Shelf creation successful;
|
|
push @shelves, $ShelfNumber if ok($ShelfNumber);
|
|
}
|
|
|
|
ok(10,scalar @shelves); # 10 shelves in @shelves;
|
|
|
|
# try to create some shelf which already exists.
|
|
for(my $i=0;$i<10;$i++){
|
|
my $badNumShelf = AddShelf("Shelf_".$i,$borrowers[$i] || '','');
|
|
ok(-1,$badNumShelf); # AddShelf returns -1 if name already exist.
|
|
}
|
|
|
|
#-----------TEST AddToShelf & &AddToShelfFromBiblio & GetShelfContents & DelFromShelf functions--------------#
|
|
# usage : &AddToShelf($itemnumber, $shelfnumber);
|
|
# usage : $itemlist = &GetShelfContents($shelfnumber);
|
|
# usage : $itemlist = GetShelfContents($shelfnumber);
|
|
|
|
for(my $i=0; $i<10;$i++){
|
|
my $item = $items[int(rand(9))];
|
|
my $shelfnumber = $shelves[int(rand(9))];
|
|
|
|
my ($itemlistBefore,$countbefore) = GetShelfContents($shelfnumber);
|
|
AddToShelf($item,$shelfnumber);
|
|
my ($itemlistAfter,$countafter) = GetShelfContents($shelfnumber);
|
|
ok($countbefore,$countafter - 1); # the item has been successfuly added.
|
|
|
|
|
|
# same thing with AddToShelfFromBiblio
|
|
my $biblionumber = $biblionumbers[int(rand(10))];
|
|
&AddToShelfFromBiblio($biblionumber, $shelfnumber);
|
|
my ($AfterAgain,$countagain) = GetShelfContents($shelfnumber);
|
|
ok($countafter, $countagain -1);
|
|
}
|
|
|
|
#-----------------------TEST ModShelf & GetShelf functions------------------------#
|
|
# usage : ModShelf($shelfnumber, $shelfname, $owner, $category )
|
|
# usage : (shelfnumber,shelfname,owner,category) = GetShelf($shelfnumber);
|
|
|
|
for(my $i=0; $i<10;$i++){
|
|
my $rand = int(rand(9));
|
|
my $numA = $shelves[$rand];
|
|
my $shelf = { shelfname => "NewName_".$rand,
|
|
owner => $borrowers[$rand],
|
|
category => int(rand(3))+1 };
|
|
|
|
ModShelf($numA,$shelf);
|
|
my ($numB,$nameB,$ownerB,$categoryB) = GetShelf($numA);
|
|
|
|
ok($numA,$numB);
|
|
ok($shelf->{shelfname},$nameB);
|
|
ok($shelf->{owner},$ownerB);
|
|
ok($shelf->{category},$categoryB);
|
|
}
|
|
|
|
#-----------------------TEST DelShelf & DelFromShelf functions------------------------#
|
|
# usage : ($status) = &DelShelf($shelfnumber);
|
|
# usage : &DelFromShelf( $itemnumber, $shelfnumber);
|
|
|
|
for(my $i=0; $i<10;$i++){
|
|
my $shelfnumber = $shelves[$i];
|
|
my $status = DelShelf($shelfnumber);
|
|
if($status){
|
|
my ($items,$count) = GetShelfContents($shelfnumber);
|
|
ok($status,$count);
|
|
foreach (@$items){ # delete all the item in this shelf
|
|
DelFromShelf($_{'itemnumber'},$shelfnumber);
|
|
}
|
|
ok(DelShelf($shelfnumber));
|
|
}
|
|
}
|