r971@llin: dpavlin | 2006-09-24 20:04:20 +0200
[webpac2] / t / 3-normalize.t
index 748dc4e..e5ab7ab 100755 (executable)
@@ -2,7 +2,7 @@
 
 use strict;
 
-use Test::More tests => 99;
+use Test::More tests => 157;
 use Test::Exception;
 use Cwd qw/abs_path/;
 use blib;
@@ -150,9 +150,10 @@ sub test_s {
        $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;
 }
 
 {
@@ -359,14 +360,15 @@ sub test_s {
        #
        # 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');
@@ -374,10 +376,10 @@ sub test_s {
        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');
@@ -399,10 +401,10 @@ sub test_s {
                        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(
@@ -477,6 +479,22 @@ sub test_s {
                ],
        );
 
+       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
        #
@@ -496,13 +514,25 @@ sub test_s {
                '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(
@@ -525,5 +555,150 @@ sub test_s {
                        ]
                ],
        );
+
+       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 )'
+       );
 }