Jonathan Druart
f1f9c6dc74
.pm must not have -x .t must have -x .pl must have -x Test plan: Apply only the first patch, run the tests and confirm that the failures make sense Apply this patch and confirm that the test now returns green Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl> Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
153 lines
6.3 KiB
Perl
Executable file
153 lines
6.3 KiB
Perl
Executable file
#!/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.
|
|
#
|
|
# 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 Modern::Perl;
|
|
|
|
use Test::More tests => 2;
|
|
|
|
use C4::Context;
|
|
use Koha::Caches;
|
|
use Koha::Database;
|
|
use Koha::MarcSubfieldStructures;
|
|
use Koha::Template::Plugin::AuthorisedValues;
|
|
|
|
use t::lib::TestBuilder;
|
|
use t::lib::Mocks;
|
|
|
|
my $schema = Koha::Database->schema;
|
|
my $builder = t::lib::TestBuilder->new;
|
|
|
|
subtest 'GetByCode' => sub {
|
|
plan tests => 4;
|
|
|
|
$schema->storage->txn_begin;
|
|
|
|
my $avc =
|
|
$builder->build_object( { class => 'Koha::AuthorisedValueCategories' } );
|
|
my $av_1 = $builder->build_object(
|
|
{
|
|
class => 'Koha::AuthorisedValues',
|
|
value => { category => $avc->category_name }
|
|
}
|
|
);
|
|
my $av_2 = $builder->build_object(
|
|
{
|
|
class => 'Koha::AuthorisedValues',
|
|
value => { category => $avc->category_name }
|
|
}
|
|
);
|
|
my $description =
|
|
Koha::Template::Plugin::AuthorisedValues->GetByCode( $avc->category_name,
|
|
$av_1->authorised_value );
|
|
is( $description, $av_1->lib, 'GetByCode should return the correct dsecription' );
|
|
my $opac_description =
|
|
Koha::Template::Plugin::AuthorisedValues->GetByCode( $avc->category_name,
|
|
$av_1->authorised_value, 'opac' );
|
|
is( $opac_description, $av_1->opac_description, 'GetByCode should return the correct opac_description' );
|
|
$av_1->lib_opac(undef)->store;
|
|
$opac_description =
|
|
Koha::Template::Plugin::AuthorisedValues->GetByCode( $avc->category_name,
|
|
$av_1->authorised_value, 'opac' );
|
|
is( $opac_description, $av_1->lib, 'GetByCode should return the staff description if the lib_opac is not filled' );
|
|
|
|
$description =
|
|
Koha::Template::Plugin::AuthorisedValues->GetByCode( $avc->category_name,
|
|
'does_not_exist' );
|
|
is( $description, 'does_not_exist', 'GetByCode should return the code passed if the AV does not exist' );
|
|
|
|
$schema->storage->txn_rollback;
|
|
};
|
|
|
|
subtest 'GetDescriptionByKohaField' => sub {
|
|
|
|
plan tests => 8;
|
|
|
|
$schema->storage->txn_begin;
|
|
|
|
my $avc = $builder->build_object( { class => 'Koha::AuthorisedValueCategories' } );
|
|
|
|
# Create a framework mapping
|
|
$builder->build_object(
|
|
{
|
|
class => 'Koha::MarcSubfieldStructures',
|
|
value => {
|
|
|
|
tagfield => '988',
|
|
tagsubfield => 'a',
|
|
liblibrarian => 'Dummy field',
|
|
libopac => 'Dummy field',
|
|
kohafield => 'dummy.field',
|
|
authorised_value => $avc->category_name,
|
|
frameworkcode => q{},
|
|
}
|
|
}
|
|
)->store;
|
|
|
|
# Make sure we are not catch by cache
|
|
Koha::Caches->get_instance->flush_all;
|
|
my $av_1 = $builder->build_object(
|
|
{ class => 'Koha::AuthorisedValues',
|
|
value => { category => $avc->category_name, lib_opac => 'lib_opac', lib => 'lib' }
|
|
}
|
|
)->store;
|
|
my $av_2 = $builder->build_object(
|
|
{ class => 'Koha::AuthorisedValues',
|
|
value => { category => $avc->category_name, lib_opac => undef, lib => 'lib' }
|
|
}
|
|
)->store;
|
|
my $av_3 = $builder->build_object(
|
|
{ class => 'Koha::AuthorisedValues',
|
|
value => { category => $avc->category_name, lib_opac => undef, lib => undef }
|
|
}
|
|
)->store;
|
|
|
|
my $non_existent_av = $builder->build_object(
|
|
{
|
|
class => 'Koha::AuthorisedValues',
|
|
value => { category => $avc->category_name, }
|
|
}
|
|
)->store->delete;
|
|
|
|
# Opac display
|
|
my $av = Koha::Template::Plugin::AuthorisedValues->GetDescriptionByKohaField(
|
|
{ opac => 1, kohafield => 'dummy.field', authorised_value => $av_1->authorised_value } );
|
|
is( $av, 'lib_opac', 'For OPAC: The OPAC description should be displayed if exists' );
|
|
$av = Koha::Template::Plugin::AuthorisedValues->GetDescriptionByKohaField(
|
|
{ opac => 1, kohafield => 'dummy.field', authorised_value => $av_2->authorised_value } );
|
|
is( $av, 'lib', 'For OPAC: The staff description should be displayed if none exists for OPAC' );
|
|
$av = Koha::Template::Plugin::AuthorisedValues->GetDescriptionByKohaField(
|
|
{ opac => 1, kohafield => 'dummy.field', authorised_value => $av_3->authorised_value } );
|
|
is( $av, $av_3->authorised_value, 'For OPAC: If both OPAC and staff descriptions are missing, the code should be displayed');
|
|
$av = Koha::Template::Plugin::AuthorisedValues->GetDescriptionByKohaField(
|
|
{ opac => 1, kohafield => 'dummy.field', authorised_value => $non_existent_av } );
|
|
is( $av, $non_existent_av, 'For OPAC: If both OPAC and staff descriptions are missing, the parameter should be displayed');
|
|
|
|
# Staff display
|
|
$av = Koha::Template::Plugin::AuthorisedValues->GetDescriptionByKohaField(
|
|
{ kohafield => 'dummy.field', authorised_value => $av_1->authorised_value } );
|
|
is( $av, 'lib', 'The staff description should be displayed' );
|
|
$av = Koha::Template::Plugin::AuthorisedValues->GetDescriptionByKohaField(
|
|
{ kohafield => 'dummy.field', authorised_value => $av_3->authorised_value } );
|
|
is( $av, $av_3->authorised_value, 'If both OPAC and staff descriptions are missing, the code should be displayed');
|
|
$av = Koha::Template::Plugin::AuthorisedValues->GetDescriptionByKohaField(
|
|
{ kohafield => 'dummy.field', authorised_value => $non_existent_av } );
|
|
is( $av, $non_existent_av, 'If both OPAC and staff descriptions are missing, the parameter should be displayed');
|
|
$av = Koha::Template::Plugin::AuthorisedValues->GetDescriptionByKohaField(
|
|
{ kohafield => 'dummy.field', authorised_value => undef } );
|
|
is( $av, '', 'If both OPAC and staff descriptions are missing, and the parameter is undef, an empty string should be displayed');
|
|
|
|
$schema->storage->txn_rollback;
|
|
};
|