X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=t%2FBiblio.t;h=0d140bed60cd4b784cb9feb0a001c209dab12a8f;hb=32fc535b8a71483b401b964b273cb280758ea8f4;hp=c18605869a7c343aff2dfc4160af89df531a2a17;hpb=f0fc240e91634bc538a527b79d0fae4af96abaa0;p=koha.git diff --git a/t/Biblio.t b/t/Biblio.t index c18605869a..0d140bed60 100755 --- a/t/Biblio.t +++ b/t/Biblio.t @@ -1,14 +1,178 @@ #!/usr/bin/perl + +# This file is part of Koha. +# +# Koha is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3 of the License, or +# (at your option) any later version. # -# This Koha test module is a stub! -# Add more tests here!!! +# Koha is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Koha; if not, see . + +use Modern::Perl; + +use Test::More; +use Test::MockModule; +use Test::Warn; + +plan tests => 47; + +use_ok('C4::Biblio'); + +my $db = Test::MockModule->new('Koha::Database'); +$db->mock( _new_schema => sub { return Schema(); } ); + +my @arr; +my $ret; + +warning_is { @arr = AddBiblio(undef, q{}) } + { carped => 'AddBiblio called with undefined record'}, + "AddBiblio returns carped warning on undef record"; + +my $elements = @arr; + +is($elements, 0, 'Add Biblio returns empty array for undef record'); + +warning_is { $ret = ModBiblio(undef, 0, '') } + { carped => 'No record passed to ModBiblio'}, + "ModBiblio returns carped warning on undef record"; + +is( $ret, 0, 'ModBiblio returns zero if not passed rec'); + +warning_is { $ret = BiblioAutoLink(undef, q{}) } + { carped => 'Undefined record passed to BiblioAutoLink'}, + "BiblioAutoLink returns carped warning on undef record"; + +is( $ret, 0, 'BiblioAutoLink returns zero if not passed rec'); + +warning_is { $ret = GetRecordValue('100', undef, q{}) } + { carped => 'GetRecordValue called with undefined record'}, + "GetRecordValue returns carped warning on undef record"; + +ok( !defined $ret, 'GetRecordValue returns undef if not passed rec'); + +warning_is { @arr = LinkBibHeadingsToAuthorities(q{}, q{}) } + { carped => 'LinkBibHeadingsToAuthorities called on undefined bib record'}, + "LinkBibHeadingsToAuthorities returns carped warning on undef record"; + +is($arr[0], 0, 'LinkBibHeadingsToAuthorities correct error return'); + +warning_is { $ret = GetCOinSBiblio() } + { carped => 'GetCOinSBiblio called with undefined record'}, + "GetCOinSBiblio returns carped warning on undef record"; + +ok( !defined $ret, 'GetCOinSBiblio returns undef if not passed rec'); + +warning_is { $ret = GetMarcPrice(undef, 'MARC21') } + { carped => 'GetMarcPrice called on undefined record'}, + "GetMarcPrice returns carped warning on undef record"; + +ok( !defined $ret, 'GetMarcPrice returns undef if not passed rec'); + +warning_is { $ret = GetMarcQuantity(undef, 'MARC21') } + { carped => 'GetMarcQuantity called on undefined record'}, + "GetMarcQuantity returns carped warning on undef record"; + +ok( !defined $ret, 'GetMarcQuantity returns undef if not passed rec'); + +warning_is { $ret = GetMarcControlnumber() } + { carped => 'GetMarcControlnumber called on undefined record'}, + "GetMarcControlnumber returns carped warning on undef record"; + +ok( !defined $ret, 'GetMarcControlnumber returns undef if not passed rec'); + +warning_is { $ret = GetMarcISBN() } + { carped => 'GetMarcISBN called on undefined record'}, + "GetMarcISBN returns carped warning on undef record"; + +ok( !defined $ret, 'GetMarcISBN returns undef if not passed rec'); + +warning_is { $ret = GetMarcISSN() } + { carped => 'GetMarcISSN called on undefined record'}, + "GetMarcISSN returns carped warning on undef record"; + +ok( !defined $ret, 'GetMarcISSN returns undef if not passed rec'); + +warning_is { $ret = GetMarcNotes() } + { carped => 'GetMarcNotes called on undefined record'}, + "GetMarcNotes returns carped warning on undef record"; + +ok( !defined $ret, 'GetMarcNotes returns undef if not passed rec'); + +warning_is { $ret = GetMarcSubjects() } + { carped => 'GetMarcSubjects called on undefined record'}, + "GetMarcSubjects returns carped warning on undef record"; + +ok( !defined $ret, 'GetMarcSubjects returns undef if not passed rec'); + +warning_is { $ret = GetMarcAuthors() } + { carped => 'GetMarcAuthors called on undefined record'}, + "GetMarcAuthors returns carped warning on undef record"; + +ok( !defined $ret, 'GetMarcAuthors returns undef if not passed rec'); + +warning_is { $ret = GetMarcUrls() } + { carped => 'GetMarcUrls called on undefined record'}, + "GetMarcUrls returns carped warning on undef record"; + +ok( !defined $ret, 'GetMarcUrls returns undef if not passed rec'); + +warning_is { $ret = GetMarcSeries() } + { carped => 'GetMarcSeries called on undefined record'}, + "GetMarcSeries returns carped warning on undef record"; + +ok( !defined $ret, 'GetMarcSeries returns undef if not passed rec'); + +warning_is { $ret = GetMarcHosts() } + { carped => 'GetMarcHosts called on undefined record'}, + "GetMarcHosts returns carped warning on undef record"; + +ok( !defined $ret, 'GetMarcHosts returns undef if not passed rec'); + +my $hash_ref; + +warning_is { $hash_ref = TransformMarcToKoha( undef) } + { carped => 'TransformMarcToKoha called with undefined record'}, + "TransformMarcToKoha returns carped warning on undef record"; + +isa_ok( $hash_ref, 'HASH'); + +$elements = keys %{$hash_ref}; + +is($elements, 0, 'Empty hashref returned for undefined record in TransformMarcToKoha'); + +warning_is { $ret = ModBiblioMarc() } + { carped => 'ModBiblioMarc passed an undefined record'}, + "ModBiblioMarc returns carped warning on undef record"; + +ok( !defined $ret, 'ModBiblioMarc returns undef if not passed rec'); + +warning_is { $ret = RemoveAllNsb() } + { carped => 'RemoveAllNsb called with undefined record'}, + "RemoveAllNsb returns carped warning on undef record"; + +ok( !defined $ret, 'RemoveAllNsb returns undef if not passed rec'); + +warning_is { $ret = GetMarcBiblio() } + { carped => 'GetMarcBiblio called without parameters'}, + "GetMarcBiblio returns carped warning on no parameters"; + +warning_is { $ret = GetMarcBiblio({ biblionumber => undef }) } + { carped => 'GetMarcBiblio called with undefined biblionumber'}, + "GetMarcBiblio returns carped warning on undef biblionumber"; -use strict; -use warnings; +ok( !defined $ret, 'GetMarcBiblio returns undef if not passed a biblionumber'); -use Test::More tests => 1; +warnings_like { $ret = UpdateTotalIssues() } + [ { carped => qr/GetMarcBiblio called with undefined biblionumber/ }, + { carped => qr/UpdateTotalIssues could not get biblio record/ } ], + "UpdateTotalIssues returns carped warnings if biblio record does not exist"; -BEGIN { - use_ok('C4::Biblio'); -} +ok( !defined $ret, 'UpdateTotalIssues returns carped warning if biblio record does not exist');