X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=t%2F3-normalize-marc.t;h=1f26929367fa1eda029d1f8b06cb94d9ecba73dc;hb=HEAD;hp=825c77fb17c962f0cf74a57540fc278b9ed3cb81;hpb=fa8b2abfe129777bd28197184fe95eb9b8f93fc9;p=webpac2 diff --git a/t/3-normalize-marc.t b/t/3-normalize-marc.t index 825c77f..1f26929 100755 --- a/t/3-normalize-marc.t +++ b/t/3-normalize-marc.t @@ -1,9 +1,9 @@ #!/usr/bin/perl -w use strict; -use blib; +use lib 'lib'; -use Test::More tests => 7; +use Test::More tests => 331; 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,96 @@ 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( $expect ); + + is_deeply( $marc, $expect, 'marc_clone same' ); +diag "marc_leader = ",dump( marc_leader ); + cmp_ok( WebPAC::Normalize::MARC::marc_leader()->{0}, 'eq', $rec->{leader}->[0], 'leader' ); + +} + +$rec = { + "000" => [2], + "001" => ["ocm00734950"], + "003" => ["OCoLC"], + "040" => [ + { + a => "DLC", + c => "BOS", + d => "TML", + i1 => "1", + i2 => "2", + subfields => ["a", 0, "c", 0, "d", 0], + }, + ], + 245 => [ + { + 1 => 2, + a => "A treatise on insanity /", + c => "translated from the French by D. D. Davis, with an introd. by Paul F. Cranefield.", + subfields => [1, 0, "a", 0, "c", 0], + i1 => '0', + i2 => '1', + }, + ], + leader => ["01237cam 2200301Ii 4500"], +}; + +test_marc_clone( $rec, [ + ["000", 2], + ["001", "ocm00734950"], + ["003", "OCoLC"], + ["040", 1,2, "a" => "DLC", "c" => "BOS", "d" => "TML"], + [ 245, 0,1, 1 => 2, "a" => "A treatise on insanity /", "c" => "translated from the French by D. D. Davis, with an introd. by Paul F. Cranefield." ], +] ); +