e5cb2154b1ccb5305c21a91d083005b5e2ab385c
[koha-ffzg.git] / t / db_dependent / Koha / Account.t
1 #!/usr/bin/perl
2
3 # Copyright 2018 Koha Development team
4 #
5 # This file is part of Koha
6 #
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
11 #
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
16 #
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>
19
20 use Modern::Perl;
21
22 use Test::More tests => 2;
23
24 use Koha::Account;
25 use Koha::Account::Lines;
26 use Koha::Account::Offsets;
27
28 use t::lib::Mocks;
29 use t::lib::TestBuilder;
30
31 my $schema  = Koha::Database->new->schema;
32 my $builder = t::lib::TestBuilder->new;
33
34 subtest 'outstanding_debits() tests' => sub {
35
36     plan tests => 12;
37
38     $schema->storage->txn_begin;
39
40     my $patron = $builder->build_object({ class => 'Koha::Patrons' });
41
42     my @generated_lines;
43     push @generated_lines, Koha::Account::Line->new({ borrowernumber => $patron->id, amountoutstanding => 1 })->store;
44     push @generated_lines, Koha::Account::Line->new({ borrowernumber => $patron->id, amountoutstanding => 2 })->store;
45     push @generated_lines, Koha::Account::Line->new({ borrowernumber => $patron->id, amountoutstanding => 3 })->store;
46     push @generated_lines, Koha::Account::Line->new({ borrowernumber => $patron->id, amountoutstanding => 4 })->store;
47
48     my $account = $patron->account;
49     my $lines   = $account->outstanding_debits();
50
51     is( $lines->total_outstanding, 10, 'Outstandig debits total is correctly calculated' );
52
53     my $i = 0;
54     foreach my $line ( @{ $lines->as_list } ) {
55         my $fetched_line = Koha::Account::Lines->find( $generated_lines[$i]->id );
56         is_deeply( $line->unblessed, $fetched_line->unblessed, "Fetched line matches the generated one ($i)" );
57         $i++;
58     }
59
60     my $patron_2 = $builder->build_object({ class => 'Koha::Patrons' });
61     Koha::Account::Line->new({ borrowernumber => $patron_2->id, amountoutstanding => -2 })->store;
62     my $just_one = Koha::Account::Line->new({ borrowernumber => $patron_2->id, amountoutstanding =>  3 })->store;
63     Koha::Account::Line->new({ borrowernumber => $patron_2->id, amountoutstanding => -6 })->store;
64     $lines = $patron_2->account->outstanding_debits();
65     is( $lines->total_outstanding, 3, "Total if some outstanding debits and some credits is only debits" );
66     is( $lines->count, 1, "With 1 outstanding debits, we get back a Lines object with 1 lines" );
67     my $the_line = Koha::Account::Lines->find( $just_one->id );
68     is_deeply( $the_line->unblessed, $lines->next->unblessed, "We get back the one correct line");
69
70     my $patron_3 = $builder->build_object({ class => 'Koha::Patrons' });
71     Koha::Account::Line->new({ borrowernumber => $patron_2->id, amountoutstanding => -2 })->store;
72     Koha::Account::Line->new({ borrowernumber => $patron_2->id, amountoutstanding => -20 })->store;
73     Koha::Account::Line->new({ borrowernumber => $patron_2->id, amountoutstanding => -200 })->store;
74     $lines = $patron_3->account->outstanding_debits();
75     is( $lines->total_outstanding, 0, "Total if no outstanding debits total is 0" );
76     is( $lines->count, 0, "With 0 outstanding debits, we get back a Lines object with 0 lines" );
77
78     my $patron_4 = $builder->build_object({ class => 'Koha::Patrons' });
79     $lines = $patron_4->account->outstanding_debits();
80     is( $lines->total_outstanding, 0, "Total if no outstanding debits is 0" );
81     is( $lines->count, 0, "With no outstanding debits, we get back a Lines object with 0 lines" );
82
83     $schema->storage->txn_rollback;
84 };
85
86 subtest 'add_credit() tests' => sub {
87
88     plan tests => 13;
89
90     $schema->storage->txn_begin;
91
92     # delete logs and statistics
93     $schema->resultset('ActionLog')->search()->delete();
94     $schema->resultset('Statistic')->search()->delete();
95
96     my $patron  = $builder->build_object( { class => 'Koha::Patrons' } );
97     my $account = Koha::Account->new( { patron_id => $patron->borrowernumber } );
98
99     is( $account->balance, 0, 'Patron has no balance' );
100
101     # Disable logs
102     t::lib::Mocks::mock_preference( 'FinesLog', 0 );
103
104     my $line_1 = $account->add_credit(
105         {   amount      => 25,
106             description => 'Payment of 25',
107             library_id  => $patron->branchcode,
108             note        => 'not really important',
109             user_id     => $patron->id
110         }
111     );
112
113     is( $account->balance, -25, 'Patron has a balance of -25' );
114     is( $schema->resultset('ActionLog')->count(), 0, 'No log was added' );
115     is( $schema->resultset('Statistic')->count(), 1, 'Action added to statistics' );
116     is( $line_1->accounttype, $Koha::Account::account_type->{'payment'}, 'Account type is correctly set' );
117
118     # Enable logs
119     t::lib::Mocks::mock_preference( 'FinesLog', 1 );
120
121     my $sip_code = "1";
122     my $line_2 = $account->add_credit(
123         {   amount      => 37,
124             description => 'Payment of 37',
125             library_id  => $patron->branchcode,
126             note        => 'not really important',
127             user_id     => $patron->id,
128             sip         => $sip_code
129         }
130     );
131
132     is( $account->balance, -62, 'Patron has a balance of -25' );
133     is( $schema->resultset('ActionLog')->count(), 1, 'Log was added' );
134     is( $schema->resultset('Statistic')->count(), 2, 'Action added to statistics' );
135     is( $line_2->accounttype, $Koha::Account::account_type->{'payment'} . $sip_code, 'Account type is correctly set' );
136
137     # offsets have the credit_id set to accountlines_id, and debit_id is undef
138     my $offset_1 = Koha::Account::Offsets->search({ credit_id => $line_1->id })->next;
139     my $offset_2 = Koha::Account::Offsets->search({ credit_id => $line_2->id })->next;
140
141     is( $offset_1->credit_id, $line_1->id, 'No debit_id is set for credits' );
142     is( $offset_1->debit_id, undef, 'No debit_id is set for credits' );
143     is( $offset_2->credit_id, $line_2->id, 'No debit_id is set for credits' );
144     is( $offset_2->debit_id, undef, 'No debit_id is set for credits' );
145
146     $schema->storage->txn_rollback;
147 };