Bug 22563: (follow-up) Corrections for tests
[koha.git] / t / db_dependent / Circulation / NoIssuesChargeGuarantees.t
1 #!/usr/bin/perl
2
3 # This file is part of Koha.
4 #
5 # Koha is free software; you can redistribute it and/or modify it
6 # under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 3 of the License, or
8 # (at your option) any later version.
9 #
10 # Koha is distributed in the hope that it will be useful, but
11 # WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
14 #
15 # You should have received a copy of the GNU General Public License
16 # along with Koha; if not, see <http://www.gnu.org/licenses>.
17
18 use Modern::Perl;
19
20 use Test::More tests => 6;
21
22 use t::lib::TestBuilder;
23 use t::lib::Mocks;
24
25 use C4::Circulation qw( CanBookBeIssued );
26 use Koha::Account;
27 use Koha::Account::Lines;
28 use Koha::Account::Offsets;
29
30 my $schema = Koha::Database->new->schema;
31 $schema->storage->txn_begin;
32
33 my $builder = t::lib::TestBuilder->new();
34
35 my $item = $builder->build(
36     {
37         source => 'Item',
38         value  => {
39             biblionumber => $builder->build( { source => 'Biblioitem' } )->{biblionumber},
40             notforloan => 0,
41             withdrawn  => 0
42         }
43     }
44 );
45
46 my $patron_category = $builder->build({ source => 'Category', value => { categorycode => 'NOT_X', category_type => 'P', enrolmentfee => 0 } });
47 my $patron = $builder->build_object(
48     {
49         class => 'Koha::Patrons',
50         value => {
51             categorycode => $patron_category->{categorycode},
52         }
53     }
54 );
55 my $guarantee = $builder->build(
56     {
57         source => 'Borrower',
58         value  => {
59             guarantorid => $patron->borrowernumber,
60             categorycode => $patron_category->{categorycode},
61         }
62     }
63 );
64
65 t::lib::Mocks::mock_preference( 'NoIssuesChargeGuarantees', '5.00' );
66 t::lib::Mocks::mock_preference( 'AllowFineOverride', '' );
67
68 my ( $issuingimpossible, $needsconfirmation ) = CanBookBeIssued( $patron, $item->{barcode} );
69 is( $issuingimpossible->{DEBT_GUARANTEES}, undef, "Patron can check out item" );
70
71 my $account = Koha::Account->new( { patron_id => $guarantee->{borrowernumber} } );
72 $account->add_debit({ amount => 10.00, type => 'lost_item', interface => 'test' });
73 ( $issuingimpossible, $needsconfirmation ) = CanBookBeIssued( $patron, $item->{barcode} );
74 is( $issuingimpossible->{DEBT_GUARANTEES} + 0, '10.00' + 0, "Patron cannot check out item due to debt for guarantee" );
75
76 my $accountline = Koha::Account::Lines->search({ borrowernumber => $guarantee->{borrowernumber} })->next();
77 is( $accountline->amountoutstanding, "10.000000", "Found 10.00 amount outstanding" );
78 is( $accountline->accounttype, "LOST", "Account type is LOST" );
79
80 my $offset = Koha::Account::Offsets->search({ debit_id => $accountline->id })->next();
81 is( $offset->type, 'Lost Item', 'Got correct offset type' );
82 is( $offset->amount, '10.000000', 'Got amount of $10.00' );
83
84 $schema->storage->txn_rollback;
85