3 use Test::More tests => 13;
5 use_ok('C4::Acquisition');
7 use_ok('C4::Bookseller');
11 use Koha::Acquisition::Order;
14 my $dbh = C4::Context->dbh;
15 $dbh->{AutoCommit} = 0;
16 $dbh->{RaiseError} = 1;
18 my $booksellerid = C4::Bookseller::AddBookseller(
21 address1 => "bookseller's address",
27 my ($biblionumber, $biblioitemnumber) = AddBiblio(MARC::Record->new, '');
29 my $bpid = AddBudgetPeriod({
30 budget_period_startdate => '01-01-2015',
31 budget_period_enddate => '12-31-2015',
32 budget_period_description => "budget desc"
35 my $budget_id = AddBudget({
36 budget_code => "ABCD",
37 budget_amount => "123.132",
38 budget_name => "Périodiques",
39 budget_notes => "This is a note",
40 budget_period_id => $bpid
43 my $subscriptionid = NewSubscription(
44 undef, "", undef, undef, $budget_id, $biblionumber,
45 '01-01-2013',undef, undef, undef, undef,
46 undef, undef, undef, undef, undef, undef,
47 1, "notes",undef, '01-01-2013', undef, undef,
48 undef, undef, 0, "intnotes", 0,
49 undef, undef, 0, undef, '31-12-2013', 0
51 die unless $subscriptionid;
53 my ($basket, $basketno);
54 ok($basketno = NewBasket($booksellerid, 1), "NewBasket( $booksellerid , 1 ) returns $basketno");
57 my $subscription = GetSubscription( $subscriptionid );
59 my $order = Koha::Acquisition::Order->new({
60 biblionumber => $subscription->{biblionumber},
61 entrydate => '01-01-2013',
65 notes => "This is a note",
66 basketno => $basketno,
71 subscriptionid => $subscription->{subscriptionid},
72 budget_id => $budget_id,
74 my $ordernumber = $order->{ordernumber};
76 my $is_currently_on_order = subscriptionCurrentlyOnOrder( $subscription->{subscriptionid} );
77 is ( $is_currently_on_order, 1, "The subscription is currently on order");
79 $order = GetLastOrderNotReceivedFromSubscriptionid( $subscription->{subscriptionid} );
80 is ( $order->{subscriptionid}, $subscription->{subscriptionid}, "test subscriptionid for the last order not received");
81 ok( $order->{ecost} == $cost, "test cost for the last order not received");
83 $dbh->do(q{DELETE FROM aqinvoices});
84 my $invoiceid = AddInvoice(invoicenumber => 'invoice1', booksellerid => $booksellerid, unknown => "unknown");
86 my ( $datereceived, $new_ordernumber ) = ModReceiveOrder(
88 biblionumber => $biblionumber,
89 ordernumber => $ordernumber,
90 quantityreceived => 1,
94 budget_id => $budget_id,
95 datereceived => '02-01-2013',
96 invoiceid => $invoiceid,
100 $order = GetLastOrderReceivedFromSubscriptionid( $subscription->{subscriptionid} );
101 is ( $order->{subscriptionid}, $subscription->{subscriptionid}, "test subscriptionid for the last order received");
102 ok( $order->{ecost} == $cost, "test cost for the last order received");
104 $order = GetLastOrderNotReceivedFromSubscriptionid( $subscription->{subscriptionid} );
105 is ( $order, undef, "test no not received order for a received order");
107 my @invoices = GetInvoices();
108 my @invoices_linked_to_subscriptions = grep { $_->{is_linked_to_subscriptions} } @invoices;
109 is(scalar(@invoices_linked_to_subscriptions), 1, 'GetInvoices() can identify invoices that are linked to a subscription');