Bug 27149: Unit 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({ source => 'Branchtransfer', value=> { itemnumber => $item_1->itemnumber, datearrived => undef } });
37     ## END FIRST ITEM ##
38
39     ## SECOND ITEM HAS NO STATUSES ##
40     my $item_2 = $builder->build_sample_item;
41     my $item_marc_2 = C4::Items::GetMarcItem( $item_2->biblionumber, $item_2->itemnumber );
42     my $item_field_2 = scalar $item_marc_2->field($itemtag);
43     ## END SECOND ITEM ##
44
45     # Create the responder
46     my $args={ PEER_NAME => 'PEER'};
47     my $zR = Koha::Z3950Responder->new({add_item_status_subfield => 'k'});
48     $zR->init_handler($args);
49
50     $args->{HANDLE}->add_item_status($item_field_1);
51     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");
52
53     $args->{HANDLE}->add_item_status($item_field_2);
54     is($item_field_2->subfield('k'),'Available',"Available status added as expected");
55
56     is($item_field_2->subfield( $itemsubfield ), $item_2->itemnumber, "Itemnumber not removed when status added");
57
58 };
59
60 $schema->storage->txn_rollback;