Bug 12537: Don't retrieve XISBN results for the same biblionumber
[koha-equinox.git] / t / db_dependent / XISBN.t
1 #!/usr/bin/perl
2 #
3 # This Koha test module is a stub!
4 # Add more tests here!!!
5
6 use Modern::Perl;
7
8 use Test::More tests => 5;
9 use MARC::Record;
10 use C4::Biblio;
11 use C4::XISBN;
12 use C4::Context;
13 use C4::Search;
14 use Koha::Database;
15 use t::lib::Mocks;
16 use Test::MockModule;
17
18 BEGIN {
19     use_ok('C4::XISBN');
20 }
21
22 my $schema = Koha::Database->new->schema;
23 $schema->storage->txn_begin;
24
25 my $search_module = new Test::MockModule('C4::Search');
26
27 $search_module->mock('SimpleSearch', \&Mock_SimpleSearch );
28 my $errors;
29 my $context = C4::Context->new;
30
31 my ( $biblionumber_tag, $biblionumber_subfield ) =
32   GetMarcFromKohaField( 'biblio.biblionumber', '' );
33 my ( $isbn_tag, $isbn_subfield ) =
34   GetMarcFromKohaField( 'biblioitems.isbn', '' );
35
36 # Harry Potter and the Sorcerer's Stone, 1st American ed. 1997
37 my $isbn1 = '0590353403';
38 # ThingISBN match : Silent Wing, First Edition 1998
39 my $isbn2 = '0684843897';
40 # XISBN match : Harry Potter and the Sorcerer's Stone,
41 # 1. Scholastic mass market paperback printing1.
42 my $isbn3 = '043936213X';
43
44 my $biblionumber1 = _add_biblio_with_isbn($isbn1);
45 my $biblionumber2 = _add_biblio_with_isbn($isbn2);
46 my $biblionumber3 = _add_biblio_with_isbn($isbn3);
47
48 my $trial = C4::XISBN::_get_biblio_from_xisbn($isbn1);
49 is( $trial->{biblionumber},
50     $biblionumber1, "Gets biblionumber like the previous test." );
51
52 ## Test ThingISBN
53 t::lib::Mocks::mock_preference( 'ThingISBN', 1 );
54
55 my $results_thingisbn;
56 eval { $results_thingisbn = C4::XISBN::get_xisbns($isbn1); };
57 SKIP: {
58     skip "Problem retrieving ThingISBN", 1
59         unless $@ eq '';
60     is( $results_thingisbn->[0]->{biblionumber},
61         $biblionumber3,
62         "Gets correct biblionumber from a book with a similar isbn using ThingISBN." );
63 }
64
65 eval { $results_thingisbn = C4::XISBN::get_xisbns($isbn1,$biblionumber1); };
66 SKIP: {
67     skip "Problem retrieving ThingISBN", 1
68         unless $@ eq '';
69     is( $results_thingisbn->[0]->{biblionumber},
70         $biblionumber3,
71         "Gets correct biblionumber from a different book with a similar isbn using ThingISBN." );
72 }
73
74 eval { $results_thingisbn = C4::XISBN::get_xisbns($isbn1,$biblionumber3); };
75 SKIP: {
76     skip "Problem retrieving ThingISBN", 1
77         unless $@ eq '';
78     is( $results_thingisbn->[0]->{biblionumber},
79         undef,
80         "Doesn't get biblionumber if the biblionumber matches the one passed to the sub." );
81 }
82
83 # Util subs
84
85 # Add new biblio with isbn and return biblionumber
86 sub _add_biblio_with_isbn {
87     my $isbn = shift;
88
89     my $marc_record = MARC::Record->new;
90     my $field = MARC::Field->new( $isbn_tag, '', '', $isbn_subfield => $isbn );
91     $marc_record->append_fields($field);
92     my ( $biblionumber, $biblioitemnumber ) = AddBiblio( $marc_record, '' );
93     return $biblionumber;
94 }
95
96 # Mocked subs
97
98 # C4::Search::SimpleSearch
99 sub Mock_SimpleSearch {
100     my $query = shift;
101     my @results;
102
103     $query =~ s/-//g;
104     my $ret_biblionumber;
105     if ( $query =~ /$isbn1/ ) {
106         $ret_biblionumber = $biblionumber1;
107     }
108     elsif ( $query =~ /$isbn2/ ) {
109         $ret_biblionumber = $biblionumber2;
110     }
111     elsif ( $query =~ /$isbn3/ ) {
112         $ret_biblionumber = $biblionumber3;
113     }
114
115     my $record = MARC::Record->new;
116     $record->leader('     ngm a22     7a 4500');
117     my $biblionumber_field;
118     if ( $biblionumber_tag < 10 ) {
119         $biblionumber_field =
120           MARC::Field->new( $biblionumber_tag, $ret_biblionumber );
121     }
122     else {
123         $biblionumber_field = MARC::Field->new( $biblionumber_tag, '', '',
124             $biblionumber_subfield => $ret_biblionumber );
125     }
126     $record->append_fields($biblionumber_field);
127
128     push @results, $record->as_xml();
129
130     return ( undef, \@results, 1 );
131 }