my $stylesheet;
+sub _get_best_default_xslt_filename {
+ my ($htdocs, $theme, $lang, $base_xslfile) = @_;
+
+ my @candidates = (
+ "$htdocs/$theme/$lang/xslt/${base_xslfile}", # exact match
+ "$htdocs/$theme/en/xslt/${base_xslfile}", # if not, preferred theme in English
+ "$htdocs/prog/$lang/xslt/${base_xslfile}", # if not, 'prog' theme in preferred language
+ "$htdocs/prog/en/xslt/${base_xslfile}", # otherwise, prog theme in English; should always
+ # exist
+ );
+ my $xslfilename;
+ foreach my $filename (@candidates) {
+ $xslfilename = $filename;
+ if (-f $filename) {
+ last; # we have a winner!
+ }
+ }
+ return $xslfilename;
+}
+
sub XSLTParse4Display {
my ( $biblionumber, $orig_record, $xslsyspref, $fixamps, $hidden_items ) = @_;
my $xslfilename = C4::Context->preference($xslsyspref);
$xslfile = C4::Context->preference('marcflavour') .
"slim2OPACResults.xsl";
}
- $xslfilename = "$htdocs/$theme/$lang/xslt/$xslfile";
- $xslfilename = "$htdocs/$theme/en/xslt/$xslfile" unless ( $lang ne 'en' && -f $xslfilename );
- $xslfilename = "$htdocs/prog/$lang/xslt/$xslfile" unless ( -f $xslfilename );
- $xslfilename = "$htdocs/prog/en/xslt/$xslfile" unless ( $lang ne 'en' && -f $xslfilename );
+ $xslfilename = _get_best_default_xslt_filename($htdocs, $theme, $lang, $xslfile);
}
if ( $xslfilename =~ m/\{langcode\}/ ) {
use strict;
use warnings;
-use Test::More tests => 1;
+use Test::More tests => 8;
+use File::Temp;
+use File::Path qw/make_path/;
BEGIN {
use_ok('C4::XSLT');
}
+my $dir = File::Temp->newdir();
+my @themes = ('prog', 'test');
+my @langs = ('en', 'es-ES');
+
+# create temporary files to be tested later
+foreach my $theme (@themes) {
+ foreach my $lang (@langs) {
+ make_path("$dir/$theme/$lang/xslt");
+ open my $fh, '>', "$dir/$theme/$lang/xslt/my_file.xslt";
+ print $fh "Theme $theme, language $lang";
+ close $fh;
+ }
+}
+
+sub find_and_slurp {
+ my ($dir, $theme, $lang) = @_;
+
+ my $filename = C4::XSLT::_get_best_default_xslt_filename($dir, $theme, $lang, 'my_file.xslt');
+ open my $fh, '<', $filename;
+ my $str = <$fh>;
+ close $fh;
+ return $str;
+}
+
+# These tests verify that we're finding the right XSLT file when present,
+# and falling back to the right XSLT file when an exact match is not present.
+is(find_and_slurp($dir, 'test', 'en' ), 'Theme test, language en', 'Found test/en');
+is(find_and_slurp($dir, 'test', 'es-ES'), 'Theme test, language es-ES', 'Found test/es-ES');
+is(find_and_slurp($dir, 'prog', 'en', ), 'Theme prog, language en', 'Found test/en');
+is(find_and_slurp($dir, 'prog', 'es-ES'), 'Theme prog, language es-ES', 'Found test/es-ES');
+is(find_and_slurp($dir, 'test', 'fr-FR'), 'Theme test, language en', 'Fell back to test/en for test/fr-FR');
+is(find_and_slurp($dir, 'nope', 'es-ES'), 'Theme prog, language es-ES', 'Fell back to prog/es-ES for nope/es-ES');
+is(find_and_slurp($dir, 'nope', 'fr-FR'), 'Theme prog, language en', 'Fell back to prog/en for nope/fr-FR');