Bug 15407: Koha::Patron::Categories - replace C4::Category->all
[srvgit] / t / db_dependent / Members / GetAllIssues.t
1 #!/usr/bin/perl
2
3 use Modern::Perl;
4
5 use Test::More tests => 16;
6 use Test::MockModule;
7
8 use C4::Biblio;
9 use C4::Items;
10 use C4::Members;
11 use C4::Circulation;
12 use Koha::Libraries;
13 use MARC::Record;
14
15 my $dbh = C4::Context->dbh;
16 $dbh->{AutoCommit} = 0;
17 $dbh->{RaiseError} = 1;
18
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|);
25
26 my $branchcode = 'B';
27 Koha::Library->new( { branchcode => $branchcode, branchname => 'Branch' } )->store;
28
29 my $categorycode = 'C';
30 $dbh->do( "INSERT INTO categories(categorycode) VALUES(?)",
31     undef, $categorycode );
32
33 my %item_branch_infos = (
34     homebranch    => $branchcode,
35     holdingbranch => $branchcode,
36 );
37
38 my ($biblionumber1) = AddBiblio( MARC::Record->new, '' );
39 my $itemnumber1 =
40   AddItem( { barcode => '0101', %item_branch_infos }, $biblionumber1 );
41 my $itemnumber2 =
42   AddItem( { barcode => '0102', %item_branch_infos }, $biblionumber1 );
43
44 my ($biblionumber2) = AddBiblio( MARC::Record->new, '' );
45 my $itemnumber3 =
46   AddItem( { barcode => '0203', %item_branch_infos }, $biblionumber2 );
47
48 my $borrowernumber1 =
49   AddMember( categorycode => $categorycode, branchcode => $branchcode );
50 my $borrowernumber2 =
51   AddMember( categorycode => $categorycode, branchcode => $branchcode );
52 my $borrower1 = GetMember( borrowernumber => $borrowernumber1 );
53 my $borrower2 = GetMember( borrowernumber => $borrowernumber2 );
54
55 my $module = new Test::MockModule('C4::Context');
56 $module->mock( 'userenv', sub { { branch => $branchcode } } );
57
58 my $issues = C4::Members::GetAllIssues();
59 is( $issues, undef, 'GetAllIssues without borrower number returns undef' );
60
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' );
65
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'
72 );
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' );
77
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' );
85
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, '' );
94
95 $dbh->rollback();