Marcel de Rooy
ab1cb8a3c0
Prevent a crash on wrong contents for ItemsDeniedRenewal pref as we did before. Note: Could be a provisional measure (no band aid to repeat anywhere) until we resolve this in preferences.pl. Test plan: Without this patch: Change ItemsDeniedRenewal to 'nonsense' Run perl -MKoha::Items -e'Koha::Items->find(X)->is_denied_renewal; print "OK\n"' => Replace X by a valid itemnumber Crashes with: Can't use string ("nonsense") as a HASH ref ... No OK print. Apply this patch Run perl -MKoha::Items -e'Koha::Items->find(X)->is_denied_renewal; print "OK\n"' => Replace X by a valid itemnumber Warns only with: Hashref expected for ItemsDeniedRenewal. You got OK. Clear ItemsDeniedRenewal Try again. No warning anymore. Run t/Context.t Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl> Signed-off-by: Tomas Cohen Arazi <tomascohen@theke.io>
215 lines
8.7 KiB
Perl
Executable file
215 lines
8.7 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 DBI;
|
|
use Test::More tests => 34;
|
|
use Test::MockModule;
|
|
use Test::Warn;
|
|
use YAML::XS;
|
|
|
|
use t::lib::Mocks;
|
|
|
|
BEGIN {
|
|
use_ok('C4::Context');
|
|
}
|
|
|
|
subtest 'yaml_preference() tests' => sub {
|
|
|
|
plan tests => 6;
|
|
|
|
my $data = [ 'uno', 'dos', { 'tres' => 'cuatro' } ];
|
|
|
|
my $context = Test::MockModule->new( 'C4::Context' );
|
|
$context->mock( 'preference', YAML::XS::Dump($data) );
|
|
|
|
my $pref = C4::Context->new->yaml_preference( 'nothing' );
|
|
|
|
is_deeply( $pref, $data, 'yaml_preference returns the right structure' );
|
|
|
|
$context->mock( 'preference', qq{- uno: dsa\n\t- dos: asd} );
|
|
warning_like
|
|
{ $pref = C4::Context->new->yaml_preference('nothing') }
|
|
qr/^Unable to parse nothing syspref/,
|
|
'Invalid YAML on syspref throws a warning';
|
|
is( $pref, undef, 'Invalid YAML on syspref makes it return undef' );
|
|
|
|
$context->mock( 'preference', sub { return '{ a : 1 }' });
|
|
is( ref( C4::Context->new->yaml_preference('ItemsDeniedRenewal') ), 'HASH', 'Got a hash as expected' );
|
|
$context->mock( 'preference', sub { return '[ 1, 2 ]' });
|
|
warning_like { $pref = C4::Context->new->yaml_preference('ITEMSDENIEDRENEWAL') } qr/Hashref expected/, 'Array not accepted for ItemsDeniedRenewal';
|
|
is( $pref, undef, 'Returned undef' );
|
|
|
|
$context->unmock( 'preference' );
|
|
};
|
|
|
|
subtest 'needs_install() tests' => sub {
|
|
|
|
plan tests => 2;
|
|
|
|
t::lib::Mocks::mock_preference( 'Version', '3.0.0' );
|
|
is( C4::Context->needs_install, 0, 'Preference is defined, no need to install' );
|
|
|
|
t::lib::Mocks::mock_preference( 'Version', undef ); # the behaviour when ->preference fails to fetch
|
|
is( C4::Context->needs_install, 1, "->preference(Version) is not defined, need to install" );
|
|
};
|
|
|
|
subtest 'csv_delimiter() tests' => sub {
|
|
|
|
plan tests => 4;
|
|
|
|
t::lib::Mocks::mock_preference( 'CSVDelimiter', undef );
|
|
is( C4::Context->csv_delimiter, ',', "csv_delimiter returns comma if system preference CSVDelimiter is undefined" );
|
|
|
|
t::lib::Mocks::mock_preference( 'CSVDelimiter', '' );
|
|
is( C4::Context->csv_delimiter, ',', "csv_delimiter returns comma if system preference CSVDelimiter is empty string" );
|
|
|
|
t::lib::Mocks::mock_preference( 'CSVDelimiter', ';' );
|
|
is( C4::Context->csv_delimiter, ';', "csv_delimiter returns semicolon if system preference CSVDelimiter is semicolon" );
|
|
|
|
t::lib::Mocks::mock_preference( 'CSVDelimiter', 'tabulation' );
|
|
is( C4::Context->csv_delimiter, "\t", "csv_delimiter returns '\t' if system preference CSVDelimiter is tabulation" );
|
|
};
|
|
|
|
subtest 'default_catalog_sort_by() tests' => sub {
|
|
|
|
plan tests => 5;
|
|
|
|
my $context = Test::MockModule->new( 'C4::Context' );
|
|
|
|
$context->mock( 'interface', 'intranet' );
|
|
|
|
t::lib::Mocks::mock_preference( 'defaultSortField', undef );
|
|
is( C4::Context->default_catalog_sort_by, undef, "default_catalog_sort_by() returns undef if system preference defaultSortField is undefined" );
|
|
|
|
t::lib::Mocks::mock_preference( 'defaultSortField', 'title' );
|
|
t::lib::Mocks::mock_preference( 'defaultSortOrder', 'az' );
|
|
is( C4::Context->default_catalog_sort_by, 'title_az', "default_catalog_sort_by() returns concatenation of system preferences defaultSortField and defaultSortOrder" );
|
|
|
|
t::lib::Mocks::mock_preference( 'defaultSortField', 'relevance' );
|
|
is( C4::Context->default_catalog_sort_by, 'relevance', "default_catalog_sort_by() returns only system preference defaultSortField if it is relevance" );
|
|
|
|
$context->mock( 'interface', 'opac' );
|
|
|
|
t::lib::Mocks::mock_preference( 'OPACdefaultSortField', 'pubdate' );
|
|
t::lib::Mocks::mock_preference( 'OPACdefaultSortOrder', 'desc' );
|
|
is( C4::Context->default_catalog_sort_by, 'pubdate_desc', "default_catalog_sort_by() returns concatenation of system preferences OPACdefaultSortField and OPACdefaultSortOrder" );
|
|
|
|
t::lib::Mocks::mock_preference( 'OPACdefaultSortField', 'relevance' );
|
|
is( C4::Context->default_catalog_sort_by, 'relevance', "default_catalog_sort_by() returns only system preference OPACdefaultSortField if it is relevance" );
|
|
|
|
$context->unmock( 'interface' );
|
|
};
|
|
|
|
my $context = Test::MockModule->new('C4::Context');
|
|
my $userenv = {};
|
|
|
|
$context->mock('userenv', sub {
|
|
return $userenv;
|
|
});
|
|
|
|
local $SIG{__WARN__} = sub { die $_[0] };
|
|
|
|
eval { C4::Context::IsSuperLibrarian(); };
|
|
like ( $@, qr/not defined/, "IsSuperLibrarian logs an error if no userenv is defined" );
|
|
|
|
$userenv->{flags} = 42;
|
|
my $is_super_librarian = eval{ C4::Context::IsSuperLibrarian() };
|
|
is ( $@, q||, "IsSuperLibrarian does not log an error if userenv is defined" );
|
|
is ( $is_super_librarian, 0, "With flag=42, it is not a super librarian" );
|
|
|
|
$userenv->{flags} = 421;
|
|
$is_super_librarian = eval{ C4::Context::IsSuperLibrarian() };
|
|
is ( $@, q||, "IsSuperLibrarian does not log an error if userenv is defined" );
|
|
is ( $is_super_librarian, 1, "With flag=1, it is a super librarian" );
|
|
|
|
$userenv->{flags} = undef;
|
|
$is_super_librarian = eval{ C4::Context::IsSuperLibrarian() };
|
|
is ( $@, q||, "IsSuperLibrarian does not log an error if \$userenv->{flags} is undefined" );
|
|
is ( $is_super_librarian, 0, "With flag=undef, it is not a super librarian" );
|
|
|
|
$userenv->{flags} = 0;
|
|
$is_super_librarian = eval{ C4::Context::IsSuperLibrarian() };
|
|
is ( $@, q||, "IsSuperLibrarian does not log an error if \$userenv->{flags} is equal to 0" );
|
|
is ( $is_super_librarian, 0, "With flag=0, it is not a super librarian" );
|
|
|
|
# C4::Context::interface
|
|
my $lastwarn;
|
|
local $SIG{__WARN__} = sub { $lastwarn = $_[0] };
|
|
is(C4::Context->interface, 'opac','interface defaults to opac');
|
|
is(C4::Context->interface('foobar'), 'opac', 'interface foobar');
|
|
like($lastwarn, qr/invalid interface : 'foobar'/, 'interface warn on foobar');
|
|
is(C4::Context->interface, 'opac', 'interface still opac');
|
|
is(C4::Context->interface('intranet'), 'intranet', 'interface intranet');
|
|
is(C4::Context->interface, 'intranet', 'interface still intranet');
|
|
is(C4::Context->interface('foobar'), 'intranet', 'interface foobar again');
|
|
is(C4::Context->interface, 'intranet', 'interface still intranet');
|
|
is(C4::Context->interface('OPAC'), 'opac', 'interface OPAC uc');
|
|
is(C4::Context->interface, 'opac', 'interface still opac');
|
|
#Bug 14751
|
|
is( C4::Context->interface( 'SiP' ), 'sip', 'interface SiP' );
|
|
is( C4::Context->interface( 'COMMANDLINE' ), 'commandline', 'interface commandline uc' );
|
|
is( C4::Context->interface( 'CRON' ), 'cron', 'interface cron uc' );
|
|
|
|
{
|
|
local %ENV = %ENV;
|
|
delete $ENV{HTTPS};
|
|
is( C4::Context->https_enabled, 0, "Undefined HTTPS env returns 0");
|
|
$ENV{HTTPS} = '1';
|
|
is( C4::Context->https_enabled, 0, "Invalid 1 HTTPS env returns 0");
|
|
$ENV{HTTPS} = 'off';
|
|
is( C4::Context->https_enabled, 0, "off HTTPS env returns 0");
|
|
$ENV{HTTPS} = 'OFF';
|
|
is( C4::Context->https_enabled, 0, "OFF HTTPS env returns 0");
|
|
$ENV{HTTPS} = 'on';
|
|
is( C4::Context->https_enabled, 1, "on HTTPS env returns 1");
|
|
$ENV{HTTPS} = 'ON';
|
|
is( C4::Context->https_enabled, 1, "ON HTTPS env returns 1");
|
|
}
|
|
|
|
subtest 'psgi_env and is_internal_PSGI_request' => sub {
|
|
|
|
plan tests => 11;
|
|
|
|
local %ENV = ( no_plack => 1 );
|
|
ok( !C4::Context->psgi_env, 'no_plack' );
|
|
$ENV{plackishere} = 1;
|
|
ok( !C4::Context->psgi_env, 'plackishere is wrong' );
|
|
$ENV{'plack.ishere'} = 1;
|
|
ok( C4::Context->psgi_env, 'plack.ishere' );
|
|
delete $ENV{'plack.ishere'};
|
|
ok( !C4::Context->psgi_env, 'plack.ishere was here' );
|
|
$ENV{'plack_env'} = 1;
|
|
ok( C4::Context->psgi_env, 'plack_env' );
|
|
delete $ENV{'plack_env'};
|
|
$ENV{'psgi_whatever'} = 1;
|
|
ok( !C4::Context->psgi_env, 'psgi_whatever' );
|
|
delete $ENV{'psgi_whatever'};
|
|
$ENV{'psgi.whatever'} = 1;
|
|
ok( C4::Context->psgi_env, 'psgi.whatever' );
|
|
delete $ENV{'psgi.whatever'};
|
|
$ENV{'PSGI.UPPERCASE'} = 1;
|
|
ok( C4::Context->psgi_env, 'PSGI uppercase' );
|
|
|
|
$ENV{'REQUEST_URI'} = '/intranet/whatever';
|
|
ok( !C4::Context->is_internal_PSGI_request, 'intranet not considered internal in regex' );
|
|
$ENV{'REQUEST_URI'} = '/api/v1/tralala';
|
|
ok( C4::Context->is_internal_PSGI_request, 'api considered internal in regex' );
|
|
delete $ENV{'PSGI.UPPERCASE'};
|
|
ok( !C4::Context->is_internal_PSGI_request, 'api but no longer PSGI' );
|
|
};
|