Bug 9394: (follow-up) modernize test cases
[koha.git] / t / db_dependent / Holds.t
1 #!/usr/bin/perl
2
3 use strict;
4 use warnings;
5 use C4::Branch;
6
7 use Test::More tests => 19;
8 use MARC::Record;
9 use C4::Biblio;
10 use C4::Items;
11 use C4::Members;
12
13 BEGIN {
14     use FindBin;
15     use lib $FindBin::Bin;
16     use_ok('C4::Reserves');
17 }
18
19 my $dbh = C4::Context->dbh;
20
21 # Start transaction
22 $dbh->{AutoCommit} = 0;
23 $dbh->{RaiseError} = 1;
24
25 my $borrowers_count = 5;
26
27 # Setup Test------------------------
28 # Helper biblio.
29 diag("Creating biblio instance for testing.");
30 my ($bibnum, $title, $bibitemnum) = create_helper_biblio();
31
32 # Helper item for that biblio.
33 diag("Creating item instance for testing.");
34 my ($item_bibnum, $item_bibitemnum, $itemnumber) = AddItem({ homebranch => 'CPL', holdingbranch => 'CPL' } , $bibnum);
35
36 # Create some borrowers
37 my @borrowernumbers;
38 foreach (1..$borrowers_count) {
39     my $borrowernumber = AddMember(
40         firstname =>  'my firstname',
41         surname => 'my surname ' . $_,
42         categorycode => 'S',
43         branchcode => 'CPL',
44     );
45     push @borrowernumbers, $borrowernumber;
46 }
47
48 my $biblionumber   = $bibnum;
49
50 my @branches = GetBranchesLoop();
51 my $branch = $branches[0][0]{value};
52
53 # Create five item level holds
54 foreach my $borrowernumber ( @borrowernumbers ) {
55     AddReserve(
56         $branch,
57         $borrowernumber,
58         $biblionumber,
59         my $constraint = 'a',
60         my $bibitems = q{},
61         my $priority,
62         my $resdate,
63         my $expdate,
64         my $notes = q{},
65         $title,
66         my $checkitem = $itemnumber,
67         my $found,
68     );
69 }
70
71
72 my ($count, $reserves) = GetReservesFromBiblionumber($biblionumber);
73 is( $count, $borrowers_count, "Test GetReserves()" );
74
75
76 my ( $reservedate, $borrowernumber, $branchcode, $reserve_id ) = GetReservesFromItemnumber($itemnumber);
77 ok($reserve_id, "Test GetReservesFromItemnumber()");
78
79
80 my ( $reserve ) = GetReservesFromBorrowernumber($borrowernumbers[0]);
81 ok( $reserve->{'borrowernumber'} eq $borrowernumbers[0], "Test GetReservesFromBorrowernumber()");
82
83
84 ok( GetReserveCount( $borrowernumbers[0] ), "Test GetReserveCount()" );
85
86
87 CancelReserve({ 'reserve_id' => $reserve_id });
88 ($count, $reserves) = GetReservesFromBiblionumber($biblionumber);
89 ok( $count == $borrowers_count - 1, "Test CancelReserve()" );
90
91
92 ( $reservedate, $borrowernumber, $branchcode, $reserve_id ) = GetReservesFromItemnumber($itemnumber);
93 ModReserve({
94     reserve_id    => $reserve_id,
95     rank          => '4',
96     branchcode    => $branch,
97     itemnumber    => $itemnumber,
98     suspend_until => C4::Dates->new("2013-01-01","iso")->output(),
99 });
100 $reserve = GetReserve( $reserve_id );
101 ok( $reserve->{'priority'} eq '4', "Test GetReserve(), priority changed correctly" );
102 ok( $reserve->{'suspend'}, "Test GetReserve(), suspend hold" );
103 ok( $reserve->{'suspend_until'} eq '2013-01-01 00:00:00', "Test GetReserve(), suspend until date" );
104
105 ToggleSuspend( $reserve_id );
106 $reserve = GetReserve( $reserve_id );
107 ok( !$reserve->{'suspend'}, "Test ToggleSuspend(), no date" );
108
109 ToggleSuspend( $reserve_id, '2012-01-01' );
110 $reserve = GetReserve( $reserve_id );
111 ok( $reserve->{'suspend_until'} eq '2012-01-01 00:00:00', "Test ToggleSuspend(), with date" );
112
113 AutoUnsuspendReserves();
114 $reserve = GetReserve( $reserve_id );
115 ok( !$reserve->{'suspend'}, "Test AutoUnsuspendReserves()" );
116
117 # Add a new hold for the borrower whose hold we canceled earlier, this time at the bib level
118 AddReserve(
119     $branch,
120     $borrowernumber,
121     $biblionumber,
122     my $constraint = 'a',
123     my $bibitems = q{},
124     my $priority,
125     my $resdate,
126     my $expdate,
127     my $notes = q{},
128     $title,
129     my $checkitem,
130     my $found,
131 );
132 ( $reserve ) = GetReservesFromBorrowernumber($borrowernumber);
133 my $reserveid = C4::Reserves::GetReserveId(
134     {
135         biblionumber => $biblionumber,
136         borrowernumber => $borrowernumber
137     }
138 );
139 is( $reserveid, $reserve->{reserve_id}, "Test GetReserveId" );
140 ModReserveMinusPriority( $itemnumber, $reserve->{'reserve_id'} );
141 ( $reserve ) = GetReservesFromBorrowernumber($borrowernumber);
142 ok( $reserve->{'itemnumber'} eq $itemnumber, "Test ModReserveMinusPriority()" );
143
144
145 my $reserve2 = GetReserveInfo( $reserve->{'reserve_id'} );
146 ok( $reserve->{'reserve_id'} eq $reserve2->{'reserve_id'}, "Test GetReserveInfo()" );
147
148
149 ($count, $reserves) = GetReservesFromBiblionumber($biblionumber,1);
150 $reserve = $reserves->[1];
151 AlterPriority( 'top', $reserve->{'reserve_id'} );
152 $reserve = GetReserve( $reserve->{'reserve_id'} );
153 ok( $reserve->{'priority'} eq '1', "Test AlterPriority(), move to top" );
154
155 AlterPriority( 'down', $reserve->{'reserve_id'} );
156 $reserve = GetReserve( $reserve->{'reserve_id'} );
157 ok( $reserve->{'priority'} eq '2', "Test AlterPriority(), move down" );
158
159 AlterPriority( 'up', $reserve->{'reserve_id'} );
160 $reserve = GetReserve( $reserve->{'reserve_id'} );
161 ok( $reserve->{'priority'} eq '1', "Test AlterPriority(), move up" );
162
163 AlterPriority( 'bottom', $reserve->{'reserve_id'} );
164 $reserve = GetReserve( $reserve->{'reserve_id'} );
165 ok( $reserve->{'priority'} eq '5', "Test AlterPriority(), move to bottom" );
166
167 # Helper method to set up a Biblio.
168 sub create_helper_biblio {
169     my $bib = MARC::Record->new();
170     my $title = 'Silence in the library';
171     $bib->append_fields(
172         MARC::Field->new('100', ' ', ' ', a => 'Moffat, Steven'),
173         MARC::Field->new('245', ' ', ' ', a => $title),
174     );
175     return ($bibnum, $title, $bibitemnum) = AddBiblio($bib, '');
176 }