4 use Test::More tests => 14;
15 my $dbh = C4::Context->dbh;
16 my $schema = Koha::Database->new()->schema();
19 $dbh->{RaiseError} = 1;
20 $schema->storage->txn_begin();
22 $dbh->do(q{INSERT INTO itemtypes (itemtype) VALUES ('GTI_I_TEST')});
23 $schema->resultset('Category')->create({ categorycode => 'GTI_C_TEST' });
24 $schema->resultset('Branch')->create({ branchcode => 'GTI_B_1', branchname => 'GTI_B_1' });
25 $schema->resultset('Branch')->create({ branchcode => 'GTI_B_2', branchname => 'GTI_B_2' });
27 my $c4_context = Test::MockModule->new('C4::Context');
28 $c4_context->mock('userenv', sub {
29 { branch => 'GTI_B_1' }
31 C4::Context->set_preference('item-level_itypes', '0');
33 my $biblionumber = create_biblio('Test 1', 'GTI_I_TEST');
35 barcode => 'GTI_BARCODE_001',
36 homebranch => 'GTI_B_1',
40 $biblionumber = create_biblio('Test 2', 'GTI_I_TEST');
42 barcode => 'GTI_BARCODE_002',
43 homebranch => 'GTI_B_2',
46 my $borrowernumber = AddMember(
48 categorycode => 'GTI_C_TEST',
49 branchcode => 'GTI_B_1'
51 my $borrower = GetMember(borrowernumber => $borrowernumber);
53 AddIssue($borrower, 'GTI_BARCODE_001');
54 AddIssue($borrower, 'GTI_BARCODE_002');
60 my @issues = GetTopIssues({count => 10, itemtype => 'GTI_I_TEST'});
61 is(scalar @issues, 2);
62 is($issues[0]->{title}, 'Test 1');
63 is($issues[1]->{title}, 'Test 2');
65 @issues = GetTopIssues({count => 1, itemtype => 'GTI_I_TEST'});
66 is(scalar @issues, 1);
67 is($issues[0]->{title}, 'Test 1');
69 @issues = GetTopIssues({count => 10, branch => 'GTI_B_2'});
70 is(scalar @issues, 1);
71 is($issues[0]->{title}, 'Test 2');
73 @issues = GetTopIssues({count => 10, ccode => 'GTI_CCODE'});
74 is(scalar @issues, 1);
75 is($issues[0]->{title}, 'Test 1');
77 @issues = GetTopIssues({count => 10, itemtype => 'GTI_I_TEST', newness => 1});
78 is(scalar @issues, 2);
79 is($issues[0]->{title}, 'Test 1');
80 is($issues[1]->{title}, 'Test 2');
84 SET datecreated = DATE_SUB(datecreated, INTERVAL 2 DAY)
85 WHERE biblionumber = ?
86 }, undef, $biblionumber);
88 @issues = GetTopIssues({count => 10, itemtype => 'GTI_I_TEST', newness => 1});
89 is(scalar @issues, 1);
90 is($issues[0]->{title}, 'Test 1');
96 $schema->storage->txn_rollback();
99 my ($title, $itemtype) = @_;
101 my ($title_tag, $title_subfield) = GetMarcFromKohaField('biblio.title', '');
102 my ($it_tag, $it_subfield) = GetMarcFromKohaField('biblioitems.itemtype', '');
104 my $record = MARC::Record->new();
105 $record->append_fields(
106 MARC::Field->new($title_tag, ' ', ' ', $title_subfield => $title),
107 MARC::Field->new($it_tag, ' ', ' ', $it_subfield => $itemtype),
110 return AddBiblio($record, '');