1 |
#!/usr/bin/perl -w |
#!/usr/bin/perl -w |
2 |
|
|
3 |
use strict; |
use strict; |
|
|
|
|
use Test::More tests => 332; |
|
|
use Test::Exception; |
|
|
use Cwd qw/abs_path/; |
|
4 |
use blib; |
use blib; |
5 |
use File::Slurp; |
|
6 |
use Getopt::Long; |
use Test::More tests => 343; |
7 |
|
|
8 |
BEGIN { |
BEGIN { |
9 |
|
use_ok( 'WebPAC::Test' ); |
10 |
use_ok( 'WebPAC::Normalize' ); |
use_ok( 'WebPAC::Normalize' ); |
11 |
} |
} |
12 |
|
|
|
use Data::Dump qw/dump/; |
|
|
|
|
|
my $debug = 0; |
|
|
GetOptions( |
|
|
"debug+", \$debug |
|
|
); |
|
|
|
|
13 |
cmp_ok(_debug(1), '==', 1, '_debug level'); |
cmp_ok(_debug(1), '==', 1, '_debug level'); |
14 |
cmp_ok(_debug(0), '==', 0, '_debug level'); |
cmp_ok(_debug(0), '==', 0, '_debug level'); |
15 |
|
|
18 |
diag "debug level for WebPAC::Normalize is ", _debug( $debug - 2 ); |
diag "debug level for WebPAC::Normalize is ", _debug( $debug - 2 ); |
19 |
} |
} |
20 |
|
|
|
ok(my $abs_path = abs_path($0), "abs_path"); |
|
|
$abs_path =~ s#/[^/]*$#/#; |
|
|
diag "abs_path: $abs_path" if ($debug); |
|
|
|
|
21 |
my $rec1 = { |
my $rec1 = { |
22 |
'200' => [{ |
'200' => [{ |
23 |
'a' => '200a', |
'a' => '200a', |
162 |
|
|
163 |
ok(! _set_lookup( undef ), "set_lookup(undef)"); |
ok(! _set_lookup( undef ), "set_lookup(undef)"); |
164 |
|
|
165 |
_set_rec( $rec1 ); |
_set_ds( $rec1 ); |
166 |
|
|
167 |
cmp_ok( join(",", rec2('200','a') ), 'eq', '200a,200a*2', 'join rec2' ); |
cmp_ok( join(",", rec2('200','a') ), 'eq', '200a,200a*2', 'join rec2' ); |
168 |
cmp_ok( join(",", rec2('200','a'), rec2('200','b') ), 'eq', '200a,200a*2,200b', 'join rec2 rec2' ); |
cmp_ok( join(",", rec2('200','a'), rec2('200','b') ), 'eq', '200a,200a*2,200b', 'join rec2 rec2' ); |
177 |
|
|
178 |
# simple list manipulatons |
# simple list manipulatons |
179 |
cmp_ok( join('', prefix('ab', 'cd') ), 'eq', 'abcd', 'prefix'); |
cmp_ok( join('', prefix('ab', 'cd') ), 'eq', 'abcd', 'prefix'); |
180 |
|
cmp_ok( join('-', prefix('', 'x', 'y') ), 'eq', 'x-y', 'prefix empty'); |
181 |
|
cmp_ok( join('-', prefix(0, 'x', 'y') ), 'eq', '0x-0y', 'prefix 0'); |
182 |
|
|
183 |
cmp_ok( join('', suffix('xy', 'cd') ), 'eq', 'cdxy', 'suffix'); |
cmp_ok( join('', suffix('xy', 'cd') ), 'eq', 'cdxy', 'suffix'); |
184 |
|
cmp_ok( join('-', suffix('', 'x', 'y' ) ), 'eq', 'x-y', 'suffix empty'); |
185 |
|
cmp_ok( join('-', suffix(0, 'x', 'y' ) ), 'eq', 'x0-y0', 'suffix 0'); |
186 |
|
|
187 |
cmp_ok( join('', surround('->', '<-', 'a','b','c') ), 'eq', '->a<-->b<-->c<-', 'surround'); |
cmp_ok( join('', surround('->', '<-', 'a','b','c') ), 'eq', '->a<-->b<-->c<-', 'surround'); |
188 |
|
cmp_ok( join('-', surround('', '', 'x','y','z') ), 'eq', 'x-y-z', 'surround empty'); |
189 |
|
cmp_ok( join('-', surround(0, 0, 'x','y','z') ), 'eq', '0x0-0y0-0z0', 'surround 0 0'); |
190 |
|
|
191 |
# count |
# count |
192 |
my @el; |
my @el; |
358 |
|
|
359 |
#ok(! lookup('non-existent'), 'lookup non-existant' ); |
#ok(! lookup('non-existent'), 'lookup non-existant' ); |
360 |
|
|
361 |
_set_rec( $rec2 ); |
_set_ds( $rec2 ); |
362 |
|
|
363 |
test_s(qq{ |
test_s(qq{ |
364 |
tag('Title', |
search_display('Title', |
365 |
rec('200','a') |
rec('200','a') |
366 |
); |
); |
367 |
}); |
}); |
368 |
test_s(qq{ |
test_s(qq{ |
369 |
tag('Who', |
search_display('Who', |
370 |
join_with(" ", |
join_with(" ", |
371 |
rec('702','a'), |
rec('702','a'), |
372 |
rec('702','b') |
rec('702','b') |
417 |
test_check_ds('display'); |
test_check_ds('display'); |
418 |
|
|
419 |
_clean_ds(); |
_clean_ds(); |
420 |
test_s(qq{ tag('something', '42'); }); |
test_s(qq{ search_display('something', '42'); }); |
421 |
test_s(qq{ tag('empty', ''); }); |
test_s(qq{ search_display('empty', ''); }); |
422 |
test_check_ds('search'); |
test_check_ds('search'); |
423 |
test_check_ds('display'); |
test_check_ds('display'); |
424 |
|
|
425 |
_clean_ds(); |
_clean_ds(); |
426 |
|
test_s(qq{ sorted('something', '42'); }); |
427 |
|
test_s(qq{ sorted('empty', ''); }); |
428 |
|
test_check_ds('sorted'); |
429 |
|
|
430 |
|
_clean_ds(); |
431 |
my $n = read_file( "$abs_path/data/normalize.pl" ); |
my $n = read_file( "$abs_path/data/normalize.pl" ); |
432 |
$n .= "\n1;\n"; |
$n .= "\n1;\n"; |
433 |
#diag "normalize code:\n$n\n"; |
#diag "normalize code:\n$n\n"; |
445 |
my $rules = qq{ search('mixed', rec('200') ) }; |
my $rules = qq{ search('mixed', rec('200') ) }; |
446 |
|
|
447 |
_clean_ds(); |
_clean_ds(); |
448 |
_set_rec( $rec ); |
_set_ds( $rec ); |
449 |
test_s( $rules ); |
test_s( $rules ); |
450 |
ok($ds = _get_ds(), "get_ds"); |
ok($ds = _get_ds(), "get_ds"); |
451 |
is_deeply( $ds, { |
is_deeply( $ds, { |
452 |
'mixed' => { |
'mixed' => { |
453 |
'search' => [ '200a', '200b' ], |
'search' => [ '200a', '200b' ], |
|
'tag' => 'mixed' |
|
454 |
} |
} |
455 |
}, 'correct get_ds'); |
}, 'correct get_ds'); |
456 |
|
|
462 |
|
|
463 |
# wird and non-valid structure which is supported anyway |
# wird and non-valid structure which is supported anyway |
464 |
_clean_ds(); |
_clean_ds(); |
465 |
_set_rec({ |
_set_ds({ |
466 |
'200' => [{ |
'200' => [{ |
467 |
'a' => '200a', |
'a' => '200a', |
468 |
}, |
}, |
474 |
is_deeply( $ds, { |
is_deeply( $ds, { |
475 |
'mixed' => { |
'mixed' => { |
476 |
'search' => [ '200a', '200-solo' ], |
'search' => [ '200a', '200-solo' ], |
|
'tag' => 'mixed' |
|
477 |
} |
} |
478 |
}, 'correct get_ds'); |
}, 'correct get_ds'); |
479 |
|
|
512 |
my ($msg, $rec, $rules, $struct) = @_; |
my ($msg, $rec, $rules, $struct) = @_; |
513 |
|
|
514 |
_clean_ds(); |
_clean_ds(); |
515 |
_set_rec($rec); |
_set_ds($rec); |
516 |
|
|
517 |
foreach my $r (split(/;/, $rules)) { |
foreach my $r (split(/;\s*$/, $rules)) { |
518 |
$r =~ s/[\s\n\r]+/ /gs; |
$r =~ s/[\s\n\r]+/ /gs; |
519 |
$r =~ s/^\s+//gs; |
$r =~ s/^\s+//gs; |
520 |
$r =~ s/\s+$//gs; |
$r =~ s/\s+$//gs; |
521 |
|
diag "rule: $r" if $debug; |
522 |
test_s($r) if ($r); |
test_s($r) if ($r); |
523 |
} |
} |
524 |
|
|
622 |
sub test_rule { |
sub test_rule { |
623 |
my ($msg, $rec, $rule, $struct) = @_; |
my ($msg, $rec, $rule, $struct) = @_; |
624 |
_clean_ds(); |
_clean_ds(); |
625 |
_set_rec( $rec ); |
_set_ds( $rec ); |
626 |
$rule =~ s/\\/\\/gs; |
$rule =~ s/\\/\\/gs; |
627 |
my $r = test_s( $rule ); |
my $r = test_s( $rule ); |
628 |
diag "for ", dump($rec), " got:\n", dump($r), "\nexpect:\n" if ($debug > 1); |
diag "for ", dump($rec), " got:\n", dump($r), "\nexpect:\n" if ($debug > 1); |
833 |
'^aa1^bb1^aa2^bb2^cc1^cc2', |
'^aa1^bb1^aa2^bb2^cc1^cc2', |
834 |
'_pack_subfields_hash( $h, 1 )' |
'_pack_subfields_hash( $h, 1 )' |
835 |
); |
); |
836 |
|
|
837 |
|
_clean_ds(); |
838 |
|
test_s(qq{ |
839 |
|
marc_fixed('008', 0, 'abcdef'); |
840 |
|
marc_fixed('000', 5, '5'); |
841 |
|
marc_fixed('000', 10, 'A'); |
842 |
|
marc_fixed('000', 0, '0'); |
843 |
|
}); |
844 |
|
ok( my $m = WebPAC::Normalize::_get_marc_fields(), '_get_marc_fields'); |
845 |
|
diag dump( $m ); |
846 |
|
is_deeply( WebPAC::Normalize::_get_marc_fields(), |
847 |
|
[ |
848 |
|
["008", "abcdef"], |
849 |
|
# 0....5....10 |
850 |
|
["000", "0 5 A"] |
851 |
|
] |
852 |
|
); |
853 |
|
|
854 |
|
test_s(qq{ isbn_13( '1558607013', '978-1558607019' ) }); |
855 |
|
test_s(qq{ isbn_10( '1558607013', '978-1558607019' ) }); |
856 |
|
|
857 |
|
is_deeply( |
858 |
|
[ isbn_13( '1558607013', '978-1558607019' ) ], |
859 |
|
[ '978-1-55860-701-9', '978-1-55860-701-9', ], |
860 |
|
'isbn_13' ); |
861 |
|
|
862 |
|
is_deeply( |
863 |
|
[ isbn_10( '1558607013', '978-1558607019' ) ], |
864 |
|
[ '1-55860-701-3', '1-55860-701-3' ], |
865 |
|
'isbn_10' ); |
866 |
|
|
867 |
|
# frec |
868 |
|
|
869 |
|
my $rec = { |
870 |
|
'200' => [ { |
871 |
|
a => [ 'a1', 'a2' ], b => [ 'b1', 'b2' ], c => [ 'c1', 'c2' ], |
872 |
|
subfields => [ qw/a 0 b 0 a 1 b 1 c 0 c 1/ ], |
873 |
|
}, { |
874 |
|
a => [ 'a3', 'a4', 'a5' ], b => 'b3', c => 'c3', |
875 |
|
subfields => [ qw/a 0 a 1 b 0 c 0 a 2/ ], |
876 |
|
} ], |
877 |
|
}; |
878 |
|
|
879 |
|
test_rule( 'frec', $rec, qq{ frec(200) }, [ 'a1' ] ); |
880 |
|
test_rule( 'frec', $rec, qq{ frec(200,'a') }, [ 'a1' ] ); |
881 |
|
test_rule( 'frec', $rec, qq{ frec(200,'b') }, [ 'b1' ] ); |
882 |
|
test_rule( 'frec', $rec, qq{ frec(200,'c') }, [ 'c1' ] ); |
883 |
|
|
884 |
|
$rec->{'900'} = $rec->{'200'}; |
885 |
|
foreach my $sf ( qw/a b c/ ) { |
886 |
|
ok( frec_eq( '200' => $sf, '900' => $sf ), "frec_eq 200 == 900 $sf"); |
887 |
|
ok( ! frec_ne( '200' => $sf, '900' => $sf ), "! frec_ne 200 == 900 $sf"); |
888 |
|
} |
889 |
|
|
890 |
|
foreach my $sf ( qw/a b/ ) { |
891 |
|
ok( ! frec_eq( '200' => $sf, '200' => 'c' ), "! frec_eq 200 $sf == 200 c"); |
892 |
|
ok( frec_ne( '200' => $sf, '200' => 'c' ), "frec_ne 200 $sf == 200 c"); |
893 |
|
} |
894 |
|
|
895 |
|
# marc_template |
896 |
|
|
897 |
|
test_rec_rules( |
898 |
|
'marc_template', |
899 |
|
{ |
900 |
|
'225' => [{ |
901 |
|
'a' => 'a-1-1', |
902 |
|
'i' => 'i-1-1', |
903 |
|
'v' => 'v-1-1', |
904 |
|
'w' => 'w-1-1', |
905 |
|
'h' => 'h-1-1', |
906 |
|
'x' => 'x-1-1', |
907 |
|
},{ |
908 |
|
'a' => 'a-2-1', |
909 |
|
'v' => 'v-2-1', |
910 |
|
'i' => 'i-2-1', |
911 |
|
},{ |
912 |
|
'a' => 'a-3-1', |
913 |
|
'i' => 'i-3-1', |
914 |
|
'v' => 'v-3-1', |
915 |
|
},{ |
916 |
|
'a' => 'a-4-1', |
917 |
|
'v' => 'v-4-1', |
918 |
|
'i' => 'i-4-1', |
919 |
|
'w' => 'w-4-1', |
920 |
|
},{ |
921 |
|
'a' => 'a-5-1', |
922 |
|
}], |
923 |
|
}, |
924 |
|
qq{ |
925 |
|
marc_template( |
926 |
|
from => 225, to => 440, |
927 |
|
subfields_rename => [ |
928 |
|
'a' => 'a', |
929 |
|
'x' => 'x', |
930 |
|
'v' => 'v', |
931 |
|
'h' => 'n', |
932 |
|
'i' => 'p', |
933 |
|
'w' => 'v', |
934 |
|
], |
935 |
|
marc_template => [ |
936 |
|
'a', |
937 |
|
'a, |x ; |v. |n, |p ; |v', |
938 |
|
'a ; |v. |p ; |v', |
939 |
|
'a. |p ; |v', |
940 |
|
], |
941 |
|
); |
942 |
|
}, |
943 |
|
[ |
944 |
|
[440, " ", " ", "a", "a-1-1", "x", "x-1-1", "v", "v-1-1", "n", "h-1-1", "p", "i-1-1", "v", "w-1-1", ], |
945 |
|
[440, " ", " ", "a", "a-2-1", "p", "i-2-1", "v", "v-2-1"], |
946 |
|
[440, " ", " ", "a", "a-3-1", "p", "i-3-1", "v", "v-3-1"], |
947 |
|
[440, " ", " ", "a", "a-4-1", "v", "v-4-1", "p", "i-4-1", "v", "w-4-1"], |
948 |
|
[440, " ", " ", "a", "a-5-1"], |
949 |
|
], |
950 |
|
); |
951 |
} |
} |
952 |
|
|