Bug 26384: Fix executable flags
[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 => 2;
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 $item_marc_1 = C4::Items::GetMarcItem( $item_1->biblionumber, $item_1->itemnumber );
33     my $item_field_1 = scalar $item_marc_1->field('952');
34     $builder->build({ source => 'Reserve', value=> { itemnumber => $item_1->itemnumber } });
35     $builder->build({ source => 'Branchtransfer', value=> { itemnumber => $item_1->itemnumber, datearrived => undef } });
36     ## END FIRST ITEM ##
37
38     ## SECOND ITEM HAS NO STATUSES ##
39     my $item_2 = $builder->build_sample_item;
40     my $item_marc_2 = C4::Items::GetMarcItem( $item_2->biblionumber, $item_2->itemnumber );
41     my $item_field_2 = scalar $item_marc_2->field('952');
42     ## END SECOND ITEM ##
43
44     # Create the responder
45     my $args={ PEER_NAME => 'PEER'};
46     my $zR = Koha::Z3950Responder->new({add_item_status_subfield => 'k'});
47     $zR->init_handler($args);
48
49     $args->{HANDLE}->add_item_status($item_field_1);
50     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");
51
52     $args->{HANDLE}->add_item_status($item_field_2);
53     is($item_field_2->subfield('k'),'Available',"Available status added as expected");
54
55 };
56
57 $schema->storage->txn_rollback;