Bug 26057: (QA follow-up) Fix Biblios, Reserves, Z3950Responder and XSLT tests
[koha.git] / t / db_dependent / Koha / Z3950Responder / Session.t
1 #!/usr/bin/perl
2
3 use Modern::Perl;
4 use Test::More tests => 3;
5 use t::lib::TestBuilder;
6 use C4::Items;
7
8 BEGIN {
9     use_ok('Koha::Z3950Responder');
10     use_ok('Koha::Z3950Responder::Session');
11 }
12
13 my $builder = t::lib::TestBuilder->new;
14 my $schema  = Koha::Database->new->schema;
15
16 $schema->storage->txn_begin;
17
18 subtest 'add_item_status' => sub {
19
20     plan tests => 3;
21
22     ## FIRST ITEM HAS ALL THE STATUSES ##
23     my $item_1 = $builder->build_sample_item(
24         {
25             onloan     => '2017-07-07',
26             itemlost   => 1,
27             notforloan => 1,
28             damaged    => 1,
29             withdrawn  => 1,
30         }
31     );
32     my ( $itemtag, $itemsubfield ) = C4::Biblio::GetMarcFromKohaField( "items.itemnumber" );
33     my $item_marc_1 = C4::Items::GetMarcItem( $item_1->biblionumber, $item_1->itemnumber );
34     my $item_field_1 = scalar $item_marc_1->field($itemtag);
35     $builder->build({ source => 'Reserve', value=> { itemnumber => $item_1->itemnumber } });
36     $builder->build(
37         {
38             source => 'Branchtransfer',
39             value  => {
40                 itemnumber    => $item_1->itemnumber,
41                 datearrived   => undef,
42                 datecancelled => undef
43             }
44         }
45     );
46     ## END FIRST ITEM ##
47
48     ## SECOND ITEM HAS NO STATUSES ##
49     my $item_2 = $builder->build_sample_item;
50     my $item_marc_2 = C4::Items::GetMarcItem( $item_2->biblionumber, $item_2->itemnumber );
51     my $item_field_2 = scalar $item_marc_2->field($itemtag);
52     ## END SECOND ITEM ##
53
54     # Create the responder
55     my $args={ PEER_NAME => 'PEER'};
56     my $zR = Koha::Z3950Responder->new({add_item_status_subfield => 'k'});
57     $zR->init_handler($args);
58
59     $args->{HANDLE}->add_item_status($item_field_1);
60     is($item_field_1->subfield('k'),"Checked Out, Lost, Not for Loan, Damaged, Withdrawn, In Transit, On Hold","All statuses added in one field as expected");
61
62     $args->{HANDLE}->add_item_status($item_field_2);
63     is($item_field_2->subfield('k'),'Available',"Available status added as expected");
64
65     is($item_field_2->subfield( $itemsubfield ), $item_2->itemnumber, "Itemnumber not removed when status added");
66
67 };
68
69 $schema->storage->txn_rollback;