Bug 9809: Update unit tests
[koha.git] / t / db_dependent / Holds / RevertWaitingStatus.t
1 #!/usr/bin/perl
2
3 use Modern::Perl;
4
5 use t::lib::Mocks;
6 use C4::Context;
7 use C4::Branch;
8
9 use Test::More tests => 3;
10 use MARC::Record;
11 use C4::Biblio;
12 use C4::Items;
13 use C4::Members;
14 use C4::Reserves;
15
16 my $dbh = C4::Context->dbh;
17
18 # Start transaction
19 $dbh->{AutoCommit} = 0;
20 $dbh->{RaiseError} = 1;
21
22 $dbh->do("DELETE FROM reserves");
23 $dbh->do("DELETE FROM old_reserves");
24
25 local $SIG{__WARN__} = sub { warn $_[0] unless $_[0] =~ /redefined/ };
26 *C4::Context::userenv = \&Mock_userenv;
27
28 sub Mock_userenv {
29     my $userenv = { flags => 1, id => '1', branch => 'CPL' };
30     return $userenv;
31 }
32
33 my $borrowers_count = 3;
34
35 # Setup Test------------------------
36 # Helper biblio.
37 diag("Creating biblio instance for testing.");
38 my ( $bibnum, $title, $bibitemnum ) = create_helper_biblio();
39
40 # Helper item for that biblio.
41 diag("Creating item instance for testing.");
42 my $item_barcode = 'my_barcode';
43 my ( $item_bibnum, $item_bibitemnum, $itemnumber ) = AddItem(
44     { homebranch => 'CPL', holdingbranch => 'CPL', barcode => $item_barcode },
45     $bibnum );
46
47 # Create some borrowers
48 my @borrowernumbers;
49 foreach my $i ( 1 .. $borrowers_count ) {
50     my $borrowernumber = AddMember(
51         firstname    => 'my firstname',
52         surname      => 'my surname ' . $i,
53         categorycode => 'S',
54         branchcode   => 'CPL',
55     );
56     push @borrowernumbers, $borrowernumber;
57 }
58
59 my $biblionumber = $bibnum;
60
61 my @branches = GetBranchesLoop();
62 my $branch   = $branches[0][0]{value};
63
64 # Create five item level holds
65 foreach my $borrowernumber (@borrowernumbers) {
66     AddReserve(
67         $branch,
68         $borrowernumber,
69         $biblionumber,
70         my $bibitems   = q{},
71         my $priority,
72         my $resdate,
73         my $expdate,
74         my $notes = q{},
75         $title,
76         my $checkitem,
77         my $found,
78     );
79 }
80
81 ModReserveAffect( $itemnumber, $borrowernumbers[0] );
82 C4::Circulation::AddIssue( GetMember( borrowernumber => $borrowernumbers[1] ),
83     $item_barcode, my $datedue, my $cancelreserve = 'revert' );
84
85 my $priorities = $dbh->selectall_arrayref(
86     "SELECT priority FROM reserves ORDER BY priority ASC");
87 ok( scalar @$priorities == 2,   'Only 2 holds remain in the reserves table' );
88 ok( $priorities->[0]->[0] == 1, 'First hold has a priority of 1' );
89 ok( $priorities->[1]->[0] == 2, 'Second hold has a priority of 2' );
90
91 # Helper method to set up a Biblio.
92 sub create_helper_biblio {
93     my $bib   = MARC::Record->new();
94     my $title = 'Silence in the library';
95     $bib->append_fields(
96         MARC::Field->new( '100', ' ', ' ', a => 'Moffat, Steven' ),
97         MARC::Field->new( '245', ' ', ' ', a => $title ),
98     );
99     return ( $bibnum, $title, $bibitemnum ) = AddBiblio( $bib, '' );
100 }