use strict;
-use Test::More tests => 99;
+use Test::More tests => 157;
use Test::Exception;
use Cwd qw/abs_path/;
use blib;
$eval_t = substr($eval_t,0,$max_eval_output) . '...' if (length($eval_t) > $max_eval_output);
$eval_t =~ s/\\/\\\\/gs;
- my $v = eval "$t";
- ok(! $@, $@ ? dump_error($@, $t) : "eval: $eval_t");
- $v;
+ my @__ret;
+ eval "\@__ret = $t";
+ ok(! $@, $@ ? dump_error($@, $t) : "eval: $eval_t = " . dump(@__ret));
+ return \@__ret;
}
{
#
# MARC
#
+ _debug( 4 );
test_s(qq{ marc_indicators('900',1,2) });
test_s(qq{ marc('900','a', rec('200') ) });
- my @marc;
- ok(@marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");
- diag dump( \@marc ) if ($debug);
+ my $marc;
+ ok($marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");
+ diag dump( $marc ) if ($debug);
- is_deeply( \@marc, [
+ is_deeply( $marc, [
[ '900', 1, 2, 'a', '200a' ],
[ '900', 1, 2, 'a', '200-solo' ]
], 'correct marc with indicators');
test_s(qq{ marc_indicators('900',' ',9) });
test_s(qq{ marc_repeatable_subfield('900','a', rec('200') ) });
- ok(@marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");
- diag dump( \@marc ) if ($debug);
+ ok($marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");
+ diag dump( $marc ) if ($debug);
- is_deeply( \@marc, [
+ is_deeply( $marc, [
[ '900', 1, 2, 'a', '200a', 'a', '200-solo' ],
[ '900', ' ', 9, 'a', '200a', 'a', '200-solo' ]
], 'correct marc with repetable subfield');
test_s($r) if ($r);
}
- ok(my @marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");
- diag dump( \@marc ) if ($debug);
+ ok(my $marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");
+ diag dump( $marc ) if ($debug);
diag "expects:\n", dump($struct) if ($debug > 1);
- is_deeply( \@marc, $struct, $msg );
+ is_deeply( $marc, $struct, $msg );
}
test_rec_rules(
],
);
+ test_rec_rules(
+ 'marc_compose with + subfields',
+ { '200' => [{ a => 'foo ; bar', b => 42, c => 'baz' }] },
+ qq{
+ marc_compose('900',
+ 'a', rec(200,'a'),
+ '+', prefix(" * ", rec(200,'c')),
+ 'b', rec(200,'b'),
+ '+', prefix(" : ", rec(200,'c')),
+ );
+ },
+ [
+ [ '900', ' ', ' ', 'a', 'foo ; bar * baz', 'b', '42 : baz' ]
+ ],
+ );
+
#
# test rules
#
'split_rec_on',
{ '200' => [{ a => 'foo ; bar', b => 42, c => 'baz' }] },
qq{ split_rec_on('200','a', qr/\\s*;\\s*/, 1) },
- 'foo',
+ [ 'foo' ],
);
test_rule(
'split_rec_on',
{ '200' => [{ a => 'foo ; bar', b => 42, c => 'baz' }] },
qq{ split_rec_on('200','a', qr/\\s*;\\s*/, 2) },
- 'bar',
+ [ 'bar' ],
+ );
+ test_rule(
+ 'split_rec_on no part',
+ { '200' => [{ a => 'foo ; bar', b => 42, c => 'baz' }] },
+ qq{ split_rec_on('200','a', qr/\\s*;\\s*/) },
+ [ 'foo', 'bar' ],
+ );
+ test_rule(
+ 'split_rec_on no record',
+ {},
+ qq{ split_rec_on('200','a', qr/\\s*;\\s*/) },
+ [ '' ],
);
test_rec_rules(
]
],
);
+
+ cmp_ok(marc_leader('06',42), '==', 42, 'marc_leader');
+ cmp_ok(marc_leader('11',5), '==', 5, 'marc_leader');
+ ok(marc_leader(), 'marc_leader get');
+ diag "leader: ", dump(marc_leader()) if ($debug);
+ is_deeply(marc_leader(), { '06' => 42, 11 => 5 }, "marc_leader full");
+
+ test_rule(
+ 'rec1(000)',
+ { '000' => [ 42 ]},
+ qq{ rec('000') },
+ [ 42 ],
+ );
+
+ test_rec_rules(
+ 'marc(001,rec(000))',
+ { '000' => [ 42 ]},
+ qq{
+ marc('001', rec('000') );
+ },
+ [
+ [ '001', 42, ]
+ ],
+ );
+
+ test_rec_rules(
+ 'marc_remove subfield',
+ { '200' => [{ a => 42, b => 'bar', c => 'baz' }] },
+ qq{
+ marc('900', 'a', rec('200','a') );
+ marc('900', 'b', rec('200','b') );
+ marc_remove('900','b');
+ marc('900', 'b', rec('200','c') );
+ marc_remove('900','a');
+ },
+ [
+ [ '900', ' ', ' ', 'b', 'baz' ],
+ ],
+ );
+
+ test_rec_rules(
+ 'marc_remove field',
+ { '200' => [{ a => 42, b => 'bar', c => 'baz' }] },
+ qq{
+ marc('900', 'a', rec('200','a') );
+ marc('900', 'b', rec('200','b') );
+ marc('901', 'b', rec('200','b') );
+ marc('901', 'c', rec('200','c') );
+ marc_remove('900');
+ },
+ [
+ [ '901', ' ', ' ', 'b', 'bar', 'c', 'baz' ],
+ ],
+ );
+ test_rec_rules(
+ 'marc_duplicate',
+ { '200' => [{ a => 42, b => 'bar', c => 'baz', d => 'bing', e => 'bong' }] },
+ qq{
+ marc('900', 'a', rec('200','a') );
+ marc('900', 'b', rec('200','b') );
+ marc_duplicate;
+ marc_remove('900','b');
+ marc('900', 'b', rec('200','c') );
+ marc_duplicate;
+ marc_remove('900','b');
+ marc('900', 'b', rec('200','d') );
+ marc_duplicate;
+ marc_remove('900','b');
+ marc('900', 'b', rec('200','e') );
+ },
+ [
+ # this will return FIRST record
+ [ '900', ' ', ' ', 'a', 42, 'b', 'bar' ],
+ ],
+ );
+
+ my $i = 0;
+ foreach my $v ( qw/bar baz bing bong/ ) {
+
+ ok($marc = WebPAC::Normalize::_get_marc_fields( offset => $i ),
+ "_get_marc_fields( offset => $i )"
+ );
+ diag "marc $i = ", dump( $marc ) if ($debug);
+ is_deeply( $marc,
+ [ [ '900', ' ', ' ', 'a', 42, 'b', $v ] ],
+ "MARC copy $i has $v",
+ );
+ $i++;
+ }
+
+ test_rec_rules(
+ 'marc_original_order',
+ {
+ '200' => [ {
+ a => [ 'a1', 'a2' ], b => [ 'b1', 'b2' ], c => [ 'c1', 'c2' ],
+ subfields => [ qw/a 0 b 0 a 1 b 1 c 0 c 1/ ],
+ }, {
+ a => [ 'a3', 'a4', 'a5' ], b => 'b3', c => 'c3',
+ subfields => [ qw/a 0 a 1 b 0 c 0 a 2/ ],
+ } ],
+ },
+ qq{
+ marc_original_order(900,200);
+ },
+ [
+ [ '900', ' ', ' ', 'a', 'a1', 'b', 'b1', 'a', 'a2', 'b', 'b2', 'c', 'c1', 'c', 'c2', ],
+ [ '900', ' ', ' ', 'a', 'a3', 'a', 'a4', 'b', 'b3', 'c', 'c3', 'a', 'a5', ],
+ ],
+ );
+
+ test_rule(
+ 'rec1 skips subfields',
+ {
+ '200' => [ {
+ a => [ 'a1', 'a2' ], b => [ 'b1', 'b2' ], c => [ 'c1', 'c2' ],
+ subfields => [ qw/a 0 b 0 a 1 b 1 c 0 c 1/ ],
+ }, {
+ a => [ 'a3', 'a4', 'a5' ], b => 'b3', c => 'c3',
+ subfields => [ qw/a 0 a 1 b 0 c 0 a 2/ ],
+ } ],
+ },
+ qq{
+ rec1(200);
+ },
+ ['a1', 'b1', 'a2', 'b2', 'c1', 'c2', 'a3', 'a4', 'b3', 'c3', 'a5' ],
+ );
+
+ is_deeply(
+ [ _pack_subfields_hash({
+ a => [ 'a1', 'a2' ], b => [ 'b1', 'b2' ], c => [ 'c1', 'c2' ],
+ subfields => [ qw/a 0 b 0 a 1 b 1 c 0 c 1/ ],
+ }) ],
+ ['a1', 'b1', 'a2', 'b2', 'c1', 'c2'],
+ '_pack_subfields_hash( $h )'
+ );
+
+ cmp_ok(
+ _pack_subfields_hash({
+ a => [ 'a1', 'a2' ], b => [ 'b1', 'b2' ], c => [ 'c1', 'c2' ],
+ subfields => [ qw/a 0 b 0 a 1 b 1 c 0 c 1/ ],
+ }, 1),
+ 'eq',
+ '^aa1^bb1^aa2^bb2^cc1^cc2',
+ '_pack_subfields_hash( $h, 1 )'
+ );
}