/[webpac2]/trunk/t/3-normalize.t
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/t/3-normalize.t

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 571 by dpavlin, Mon Jul 3 14:30:22 2006 UTC revision 669 by dpavlin, Mon Sep 11 14:29:01 2006 UTC
# Line 2  Line 2 
2    
3  use strict;  use strict;
4    
5  use Test::More tests => 112;  use Test::More tests => 157;
6  use Test::Exception;  use Test::Exception;
7  use Cwd qw/abs_path/;  use Cwd qw/abs_path/;
8  use blib;  use blib;
# Line 360  sub test_s { Line 360  sub test_s {
360          #          #
361          # MARC          # MARC
362          #          #
363            _debug( 4 );
364    
365          test_s(qq{ marc_indicators('900',1,2) });          test_s(qq{ marc_indicators('900',1,2) });
366          test_s(qq{ marc('900','a', rec('200') ) });          test_s(qq{ marc('900','a', rec('200') ) });
367          my @marc;          my $marc;
368          ok(@marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");          ok($marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");
369          diag dump( \@marc ) if ($debug);          diag dump( $marc ) if ($debug);
370    
371          is_deeply( \@marc, [          is_deeply( $marc, [
372                  [ '900', 1, 2, 'a', '200a' ],                  [ '900', 1, 2, 'a', '200a' ],
373                  [ '900', 1, 2, 'a', '200-solo' ]                  [ '900', 1, 2, 'a', '200-solo' ]
374          ], 'correct marc with indicators');          ], 'correct marc with indicators');
# Line 375  sub test_s { Line 376  sub test_s {
376          test_s(qq{ marc_indicators('900',' ',9) });          test_s(qq{ marc_indicators('900',' ',9) });
377          test_s(qq{ marc_repeatable_subfield('900','a', rec('200') ) });          test_s(qq{ marc_repeatable_subfield('900','a', rec('200') ) });
378    
379          ok(@marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");          ok($marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");
380          diag dump( \@marc ) if ($debug);          diag dump( $marc ) if ($debug);
381    
382          is_deeply( \@marc, [          is_deeply( $marc, [
383                  [ '900', 1, 2, 'a', '200a', 'a', '200-solo' ],                  [ '900', 1, 2, 'a', '200a', 'a', '200-solo' ],
384                  [ '900', ' ', 9, 'a', '200a', 'a', '200-solo' ]                  [ '900', ' ', 9, 'a', '200a', 'a', '200-solo' ]
385          ], 'correct marc with repetable subfield');          ], 'correct marc with repetable subfield');
# Line 400  sub test_s { Line 401  sub test_s {
401                          test_s($r) if ($r);                          test_s($r) if ($r);
402                  }                  }
403    
404                  ok(my @marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");                  ok(my $marc = WebPAC::Normalize::_get_marc_fields(), "_get_marc_fields");
405                  diag dump( \@marc ) if ($debug);                  diag dump( $marc ) if ($debug);
406                  diag "expects:\n", dump($struct) if ($debug > 1);                  diag "expects:\n", dump($struct) if ($debug > 1);
407                  is_deeply( \@marc, $struct, $msg );                  is_deeply( $marc, $struct, $msg );
408          }          }
409    
410          test_rec_rules(          test_rec_rules(
# Line 478  sub test_s { Line 479  sub test_s {
479                  ],                  ],
480          );          );
481    
482            test_rec_rules(
483                    'marc_compose with + subfields',
484                    { '200' => [{ a => 'foo ; bar', b => 42, c => 'baz' }] },
485                    qq{
486                            marc_compose('900',
487                                    'a', rec(200,'a'),
488                                    '+', prefix(" * ", rec(200,'c')),
489                                    'b', rec(200,'b'),
490                                    '+', prefix(" : ", rec(200,'c')),
491                            );
492                    },
493                    [
494                            [ '900', ' ', ' ', 'a', 'foo ; bar * baz', 'b', '42 : baz' ]
495                    ],
496            );
497    
498          #          #
499          # test rules          # test rules
500          #          #
# Line 545  sub test_s { Line 562  sub test_s {
562          diag "leader: ", dump(marc_leader()) if ($debug);          diag "leader: ", dump(marc_leader()) if ($debug);
563          is_deeply(marc_leader(), { '06' => 42, 11 => 5 }, "marc_leader full");          is_deeply(marc_leader(), { '06' => 42, 11 => 5 }, "marc_leader full");
564    
         _debug(2);  
565          test_rule(          test_rule(
566                  'rec1(000)',                  'rec1(000)',
567                  { '000' => [ 42 ]},                  { '000' => [ 42 ]},
# Line 554  sub test_s { Line 570  sub test_s {
570          );          );
571    
572          test_rec_rules(          test_rec_rules(
573                  'marc_compose+split_rec_on',                  'marc(001,rec(000))',
574                  { '000' => [ 42 ]},                  { '000' => [ 42 ]},
575                  qq{                  qq{
576                          marc('001', rec('000') );                          marc('001', rec('000') );
577                  },                  },
578                  [                  [
579                          [ '001', ' ', ' ', 42, ]                          [ '001', 42, ]
580                    ],
581            );
582    
583            test_rec_rules(
584                    'marc_remove subfield',
585                    { '200' => [{ a => 42, b => 'bar', c => 'baz' }] },
586                    qq{
587                            marc('900', 'a', rec('200','a') );
588                            marc('900', 'b', rec('200','b') );
589                            marc_remove('900','b');
590                            marc('900', 'b', rec('200','c') );
591                            marc_remove('900','a');
592                    },
593                    [
594                            [ '900', ' ', ' ', 'b', 'baz' ],
595                    ],
596            );
597    
598            test_rec_rules(
599                    'marc_remove field',
600                    { '200' => [{ a => 42, b => 'bar', c => 'baz' }] },
601                    qq{
602                            marc('900', 'a', rec('200','a') );
603                            marc('900', 'b', rec('200','b') );
604                            marc('901', 'b', rec('200','b') );
605                            marc('901', 'c', rec('200','c') );
606                            marc_remove('900');
607                    },
608                    [
609                            [ '901', ' ', ' ', 'b', 'bar', 'c', 'baz' ],
610                    ],
611            );
612            test_rec_rules(
613                    'marc_duplicate',
614                    { '200' => [{ a => 42, b => 'bar', c => 'baz', d => 'bing', e => 'bong' }] },
615                    qq{
616                            marc('900', 'a', rec('200','a') );
617                            marc('900', 'b', rec('200','b') );
618                            marc_duplicate;
619                            marc_remove('900','b');
620                            marc('900', 'b', rec('200','c') );
621                            marc_duplicate;
622                            marc_remove('900','b');
623                            marc('900', 'b', rec('200','d') );
624                            marc_duplicate;
625                            marc_remove('900','b');
626                            marc('900', 'b', rec('200','e') );
627                    },
628                    [
629                            # this will return FIRST record
630                            [ '900', ' ', ' ', 'a', 42, 'b', 'bar' ],
631                    ],
632            );
633    
634            my $i = 0;
635            foreach my $v ( qw/bar baz bing bong/ ) {
636    
637                    ok($marc = WebPAC::Normalize::_get_marc_fields( offset => $i ),
638                            "_get_marc_fields( offset => $i )"
639                    );
640                    diag "marc $i = ", dump( $marc ) if ($debug);
641                    is_deeply( $marc,
642                            [ [ '900', ' ', ' ', 'a', 42, 'b', $v ] ],
643                            "MARC copy $i has $v",
644                    );
645                    $i++;
646            }
647    
648            test_rec_rules(
649                    'marc_original_order',
650                    {
651                            '200' => [ {
652                                    a => [ 'a1', 'a2' ], b => [ 'b1', 'b2' ], c => [ 'c1', 'c2' ],
653                                    subfields => [ qw/a 0 b 0 a 1 b 1 c 0 c 1/ ],
654                            }, {
655                                    a => [ 'a3', 'a4', 'a5' ], b => 'b3', c => 'c3',
656                                    subfields => [ qw/a 0 a 1 b 0 c 0 a 2/ ],
657                            } ],
658                    },
659                    qq{
660                            marc_original_order(900,200);
661                    },
662                    [
663                            [ '900', ' ', ' ', 'a', 'a1', 'b', 'b1', 'a', 'a2', 'b', 'b2', 'c', 'c1', 'c', 'c2', ],
664                            [ '900', ' ', ' ', 'a', 'a3', 'a', 'a4', 'b', 'b3', 'c', 'c3', 'a', 'a5', ],
665                  ],                  ],
666          );          );
667    
668            test_rule(
669                    'rec1 skips subfields',
670                    {
671                            '200' => [ {
672                                    a => [ 'a1', 'a2' ], b => [ 'b1', 'b2' ], c => [ 'c1', 'c2' ],
673                                    subfields => [ qw/a 0 b 0 a 1 b 1 c 0 c 1/ ],
674                            }, {
675                                    a => [ 'a3', 'a4', 'a5' ], b => 'b3', c => 'c3',
676                                    subfields => [ qw/a 0 a 1 b 0 c 0 a 2/ ],
677                            } ],
678                    },
679                    qq{
680                            rec1(200);
681                    },
682                    ['a1', 'b1', 'a2', 'b2', 'c1', 'c2', 'a3', 'a4', 'b3', 'c3', 'a5' ],
683            );
684    
685            is_deeply(
686                    [ _pack_subfields_hash({
687                            a => [ 'a1', 'a2' ], b => [ 'b1', 'b2' ], c => [ 'c1', 'c2' ],
688                            subfields => [ qw/a 0 b 0 a 1 b 1 c 0 c 1/ ],
689                    }) ],
690                    ['a1', 'b1', 'a2', 'b2', 'c1', 'c2'],
691                    '_pack_subfields_hash( $h )'
692            );
693    
694            cmp_ok(
695                    _pack_subfields_hash({
696                            a => [ 'a1', 'a2' ], b => [ 'b1', 'b2' ], c => [ 'c1', 'c2' ],
697                            subfields => [ qw/a 0 b 0 a 1 b 1 c 0 c 1/ ],
698                    }, 1),
699                    'eq',
700                    '^aa1^bb1^aa2^bb2^cc1^cc2',
701                    '_pack_subfields_hash( $h, 1 )'
702            );
703  }  }
704    

Legend:
Removed from v.571  
changed lines
  Added in v.669

  ViewVC Help
Powered by ViewVC 1.1.26