r1735@llin: dpavlin | 2008-09-06 11:54:01 +0200
[webpac2] / t / 3-normalize-marc.t
index 825c77f..721d78b 100755 (executable)
@@ -3,7 +3,7 @@
 use strict;
 use blib;
 
-use Test::More tests => 7;
+use Test::More tests => 330;
 
 BEGIN {
        use_ok( 'WebPAC::Test' );
@@ -49,14 +49,19 @@ my $rec = {
                'v' => 'v-8-1',
        },{
                'v' => 'v-9-1',
+       },{
+               'v' => '0',
        }],
 };
 
 sub test_marc_template {
        my $rec = shift;
 
+       ok( _clean_ds(), '_clean_ds' );
        ok( _set_ds( $rec ), '_set_ds' );
 
+       ok( marc_indicators( 440, '0', '1' ), 'marc_indicators' );
+
        ok( marc_template(
                from => 225, to => 440,
                subfields_rename => [
@@ -84,37 +89,67 @@ sub test_marc_template {
        ok(my $marc = WebPAC::Normalize::MARC::_get_marc_fields(), "_get_marc_fields");
        diag " _get_marc_fields = ",dump( $marc ) if $debug;
 
+       ok( marc_indicators( 440, 'x', 'y' ), 'marc_indicators' );
+
        return $marc;
 }
 
 my $marc_out = [
-       [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"],
-       [440, " ", " ", "v", "v-9-1"],
-       [440, " ", " ", "a", "a-2-1 ; ", "v", "v-2-1. ", "p", "i-2-1"],
-       [440, " ", " ", "a", "a-3-1 ; ", "v", "v-3-1. ", "p", "i-3-1"],
-       [440, " ", " ", "a", "a-4-1 ; ", "v", "v-4-1. ", "p", "i-4-1 ; ", "v", "w-4-1"],
-       [440, " ", " ", "a", "a-5-1 ; ", "v", "v-5-1. ", "p", "i-5-1"],
-       [440, " ", " ", "a", "a-6-1. ", "p", "i-6-1 ; ", "v", "w-6-1"],
-       [440, " ", " ", "a", "a-7-1"],
-       [440, " ", " ", "a", "a-8-1 ;", "v", "v-8-1"],
+       [440, "0", "1", "a", "a-1-1, ", "x", "x-1-1 ; ", "v", "v-1-1. ", "n", "h-1-1, ", "p", "i-1-1 ; ", "v", "w-1-1"],
+       [440, "0", "1", "a", "a-2-1 ; ", "v", "v-2-1. ", "p", "i-2-1"],
+       [440, "0", "1", "a", "a-3-1 ; ", "v", "v-3-1. ", "p", "i-3-1"],
+       [440, "0", "1", "a", "a-4-1 ; ", "v", "v-4-1. ", "p", "i-4-1 ; ", "v", "w-4-1"],
+       [440, "0", "1", "a", "a-5-1 ; ", "v", "v-5-1. ", "p", "i-5-1"],
+       [440, "0", "1", "a", "a-6-1. ", "p", "i-6-1 ; ", "v", "w-6-1"],
+       [440, "0", "1", "a", "a-7-1"],
+       [440, "0", "1", "a", "a-8-1 ;", "v", "v-8-1"],
+       [440, "0", "1", "v", "v-9-1"],
+       [440, 0, 1, "v", 0],
 ];
 
 is_deeply( test_marc_template($rec), $marc_out , 'is_deeply');
 
-__END__
-
 my $max_occ = $#{ $rec->{225} };
 
 foreach my $from ( 0 .. $max_occ - 1 ) {
-       foreach my $to ( 1 .. $max_occ ) {
+       foreach my $to ( $from + 1 .. $max_occ ) {
+               my @orig_rec = @{ $rec->{225} };
                my $new_rec = {
-                       225 => [ splice( @{ $rec->{225} }, $from, $to ) ],
+                       225 => [ splice( @orig_rec, $from, $to ) ],
                };
-               diag "new_rec = ",dump( $new_rec ) if $debug;
-       
-               my $expect_marc = [ splice( @{ $marc_out }, $from, $to ) ];
-               diag "expect_marc = ",dump( $expect_marc ) if $debug;
+               diag "$from-$to new_rec = ",dump( $new_rec ) if $debug;
+
+               my @expect = @$marc_out;
+               my $expect_marc = [ splice( @expect, $from, $to ) ];
+               diag "$from-$to expect_marc = ",dump( $expect_marc ) if $debug;
+
+               is_deeply( test_marc_template($new_rec), $expect_marc, "$from-$to is_deeply");
 
-               is_deeply( [ test_marc_template($rec) ], $expect_marc, 'is_deeply');
        }
 }
+
+sub test_marc_clone {
+       my ( $rec, $expect ) = @_;
+
+       ok( _clean_ds(), '_clean_ds' );
+       ok( _set_ds( $rec ), '_set_ds' );
+
+       ok( ! marc_clone, 'marc_clone' );
+
+       ok(my $marc = WebPAC::Normalize::MARC::_get_marc_fields(), "_get_marc_fields");
+#      diag "rec = ",dump( $rec );
+#      diag "marc = ",dump( $marc );
+#      diag "expect = ",dump( $marc );
+
+       is_deeply( $marc, $expect, 'marc_clone same' );
+
+}
+
+test_marc_clone( {
+       '900' => [{ 'a' => '900a', 'b' => '900b',       subfields => [ qw/a 0 b 0/ ]    }],
+       '901' => [{ 'c' => '901c',                                      subfields => [ qw/c 0/ ]                }],
+}, [
+   [900, " ", " ", "a", "900a", "b", "900b"],
+   [901, " ", " ", "c", "901c"],
+] );
+