Koha/t/db_dependent/RecordProcessor_EmbedSeeFromHeadings.t
Julian Maurice 96cc447045 Bug 25898: Prohibit indirect object notation
Signed-off-by: Tomas Cohen Arazi <tomascohen@theke.io>

Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de>

Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
2020-10-15 12:56:30 +02:00

114 lines
3.3 KiB
Perl
Executable file

#!/usr/bin/perl
# Copyright 2012 C & P Bibliography Services
#
# 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.
#
# 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 <http://www.gnu.org/licenses>.
use strict;
use warnings;
use File::Spec;
use MARC::Record;
use Koha::MetadataRecord::Authority;
use Test::More;
use Test::MockModule;
use Test::MockObject;
BEGIN {
use_ok('Koha::RecordProcessor');
}
my $module = Test::MockModule->new('MARC::Record');
$module->mock('new_from_xml', sub {
my $record = MARC::Record->new;
$record->add_fields(
[ '001', '1234' ],
[ '150', ' ', ' ', a => 'Cooking' ],
[ '450', ' ', ' ', a => 'Cookery' ],
);
return $record;
});
my $bib = MARC::Record->new;
$bib->add_fields(
[ '245', '0', '4', a => 'The Ifrane cookbook' ],
[ '650', ' ', ' ', a => 'Cooking', 9 => '1234' ]
);
my $resultbib = MARC::Record->new;
$resultbib->add_fields(
[ '245', '0', '4', a => 'The Ifrane cookbook' ],
[ '650', ' ', ' ', a => 'Cooking', 9 => '1234' ],
[ '650', 'z', ' ', a => 'Cookery' ]
);
my $processor = Koha::RecordProcessor->new( { filters => ( 'EmbedSeeFromHeadings' ) } );
is(ref($processor), 'Koha::RecordProcessor', 'Created record processor');
my $result = $processor->process($bib);
is_deeply($result, $resultbib, 'Inserted see-from heading to record');
subtest "EmbedSeeFromHeadings should skip holdings fields" => sub {
plan tests => 1;
my $biblio_record = MARC::Record->new;
$biblio_record->add_fields(
[ '245', '0', '4', a => 'The Ifrane cookbook' ],
[ '952', ' ', ' ', a => 'Cooking', 9 => '1234' ]
);
my $record_copy = MARC::Record->new;
$record_copy->add_fields(
[ '245', '0', '4', a => 'The Ifrane cookbook' ],
[ '952', ' ', ' ', a => 'Cooking', 9 => '1234' ]
);
my $koha_authority = Test::MockModule->new('Koha::MetadataRecord::Authority');
$koha_authority->mock( 'get_from_authid', sub {
my $auth_record = MARC::Record->new;
$auth_record->add_fields(
[ '001', '1234' ],
[ '150', ' ', ' ', a => 'Cooking' ],
[ '450', ' ', ' ', a => 'Cookery' ],
);
my $authority_object = Test::MockObject->new();
$authority_object->mock( 'authid', sub { return '1234'; });
$authority_object->mock( 'authtype', sub { return 'TOPIC_TERM'; });
$authority_object->mock( 'schema', sub { return 'marc21'; });
$authority_object->mock( 'record', sub { return $auth_record; });
return $authority_object;
});
my $processor = Koha::RecordProcessor->new({
filters => ( 'EmbedSeeFromHeadings' )
});
my $result = $processor->process($biblio_record);
is_deeply($result, $record_copy, 'Holdings fields not processed to introduce See-from heading');
};
done_testing();