5 use Test
::More tests
=> 16;
15 my $dbh = C4
::Context
->dbh;
16 $dbh->{AutoCommit
} = 0;
17 $dbh->{RaiseError
} = 1;
19 $dbh->do(q
|DELETE FROM issues
|);
20 $dbh->do(q
|DELETE FROM borrowers
|);
21 $dbh->do(q
|DELETE FROM items
|);
22 $dbh->do(q
|DELETE FROM branches
|);
23 $dbh->do(q
|DELETE FROM biblio
|);
24 $dbh->do(q
|DELETE FROM categories
|);
27 Koha
::Library
->new( { branchcode
=> $branchcode, branchname
=> 'Branch' } )->store;
29 my $categorycode = 'C';
30 $dbh->do( "INSERT INTO categories(categorycode) VALUES(?)",
31 undef, $categorycode );
33 my %item_branch_infos = (
34 homebranch
=> $branchcode,
35 holdingbranch
=> $branchcode,
38 my ($biblionumber1) = AddBiblio
( MARC
::Record
->new, '' );
40 AddItem
( { barcode
=> '0101', %item_branch_infos }, $biblionumber1 );
42 AddItem
( { barcode
=> '0102', %item_branch_infos }, $biblionumber1 );
44 my ($biblionumber2) = AddBiblio
( MARC
::Record
->new, '' );
46 AddItem
( { barcode
=> '0203', %item_branch_infos }, $biblionumber2 );
49 AddMember
( categorycode
=> $categorycode, branchcode
=> $branchcode );
51 AddMember
( categorycode
=> $categorycode, branchcode
=> $branchcode );
52 my $borrower1 = GetMember
( borrowernumber
=> $borrowernumber1 );
53 my $borrower2 = GetMember
( borrowernumber
=> $borrowernumber2 );
55 my $module = new Test
::MockModule
('C4::Context');
56 $module->mock( 'userenv', sub { { branch
=> $branchcode } } );
58 my $issues = C4
::Members
::GetAllIssues
();
59 is
( $issues, undef, 'GetAllIssues without borrower number returns undef' );
61 $issues = C4
::Members
::GetAllIssues
($borrowernumber1);
62 is
( @
$issues, 0, 'GetAllIssues returns the correct number of elements' );
63 $issues = C4
::Members
::GetAllIssues
($borrowernumber2);
64 is
( @
$issues, 0, 'GetAllIssues returns the correct number of elements' );
66 AddIssue
( $borrower1, '0101' );
67 $issues = C4
::Members
::GetAllIssues
($borrowernumber1);
68 my $issues_with_order =
69 C4
::Members
::GetAllIssues
( $borrowernumber1, 'date_due desc' );
70 is_deeply
( $issues, $issues_with_order,
71 'The value by default for the argument order in GellAllIssues is date_due_desc'
73 is
( @
$issues, 1, 'GetAllIssues returns the correct number of elements' );
74 is
( $issues->[0]->{itemnumber
}, $itemnumber1, '' );
75 $issues = C4
::Members
::GetAllIssues
($borrowernumber2);
76 is
( @
$issues, 0, 'GetAllIssues returns the correct number of elements' );
78 AddIssue
( $borrower1, '0102' );
79 $issues = C4
::Members
::GetAllIssues
($borrowernumber1);
80 is
( @
$issues, 2, 'GetAllIssues returns the correct number of elements' );
81 is
( $issues->[0]->{itemnumber
}, $itemnumber1, '' );
82 is
( $issues->[1]->{itemnumber
}, $itemnumber2, '' );
83 $issues = C4
::Members
::GetAllIssues
($borrowernumber2);
84 is
( @
$issues, 0, 'GetAllIssues returns the correct number of elements' );
86 AddIssue
( $borrower2, '0203' );
87 $issues = C4
::Members
::GetAllIssues
($borrowernumber1);
88 is
( @
$issues, 2, 'GetAllIssues returns the correct number of elements' );
89 is
( $issues->[0]->{itemnumber
}, $itemnumber1, '' );
90 is
( $issues->[1]->{itemnumber
}, $itemnumber2, '' );
91 $issues = C4
::Members
::GetAllIssues
($borrowernumber2);
92 is
( @
$issues, 1, 'GetAllIssues returns the correct number of elements' );
93 is
( $issues->[0]->{itemnumber
}, $itemnumber3, '' );