/[webpac2]/trunk/t/3-normalize-marc.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

Annotation of /trunk/t/3-normalize-marc.t

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1368 - (hide annotations)
Mon Mar 12 19:00:00 2012 UTC (12 years, 1 month ago) by dpavlin
File MIME type: application/x-troff
File size: 4257 byte(s)
marc_original_order support for leader and fixed fields

1 dpavlin 1021 #!/usr/bin/perl -w
2    
3     use strict;
4 dpavlin 1256 use lib 'lib';
5 dpavlin 1021
6 dpavlin 1368 use Test::More tests => 331;
7 dpavlin 1021
8     BEGIN {
9     use_ok( 'WebPAC::Test' );
10     use_ok( 'WebPAC::Normalize' );
11     use_ok( 'WebPAC::Normalize::MARC' );
12     }
13    
14 dpavlin 1037 _debug( $debug - 1 ) if $debug > 1;
15    
16 dpavlin 1021 my $rec = {
17     '225' => [{
18     'a' => 'a-1-1',
19     'i' => 'i-1-1',
20     'v' => 'v-1-1',
21     'w' => 'w-1-1',
22     'h' => 'h-1-1',
23     'x' => 'x-1-1',
24     },{
25     'a' => 'a-2-1',
26     'v' => 'v-2-1',
27     'i' => 'i-2-1',
28     },{
29     'a' => 'a-3-1',
30     'i' => 'i-3-1',
31     'v' => 'v-3-1',
32     },{
33     'a' => 'a-4-1',
34     'v' => 'v-4-1',
35     'i' => 'i-4-1',
36     'w' => 'w-4-1',
37     },{
38 dpavlin 1026 'a' => 'a-5-1',
39     'v' => 'v-5-1',
40     'i' => 'i-5-1',
41 dpavlin 1021 },{
42 dpavlin 1026 'a' => 'a-6-1',
43     'i' => 'i-6-1',
44     'w' => 'w-6-1',
45     },{
46     'a' => 'a-7-1',
47 dpavlin 1029 },{
48     'a' => 'a-8-1',
49     'v' => 'v-8-1',
50     },{
51     'v' => 'v-9-1',
52 dpavlin 1062 },{
53     'v' => '0',
54 dpavlin 1021 }],
55     };
56    
57 dpavlin 1036 sub test_marc_template {
58     my $rec = shift;
59 dpavlin 1021
60 dpavlin 1038 ok( _clean_ds(), '_clean_ds' );
61 dpavlin 1036 ok( _set_ds( $rec ), '_set_ds' );
62 dpavlin 1021
63 dpavlin 1047 ok( marc_indicators( 440, '0', '1' ), 'marc_indicators' );
64    
65 dpavlin 1036 ok( marc_template(
66     from => 225, to => 440,
67     subfields_rename => [
68     'a' => 'a',
69     'x' => 'x',
70     'v' => 'v',
71     'h' => 'n',
72     'i' => 'p',
73     'w' => 'v',
74     ],
75     isis_template => [
76     'a ; |v. |i',
77     'a. |i ; |w',
78     ],
79     marc_template => [
80     'a',
81     'a ;|v',
82     'a.|p',
83     'a, |x ; |v. |n, |p ; |v',
84     'a ; |v. |p ; |v',
85     'v',
86     ],
87     ), 'marc_template' );
88 dpavlin 1021
89 dpavlin 1036 ok(my $marc = WebPAC::Normalize::MARC::_get_marc_fields(), "_get_marc_fields");
90     diag " _get_marc_fields = ",dump( $marc ) if $debug;
91    
92 dpavlin 1047 ok( marc_indicators( 440, 'x', 'y' ), 'marc_indicators' );
93    
94 dpavlin 1036 return $marc;
95     }
96    
97     my $marc_out = [
98 dpavlin 1047 [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"],
99     [440, "0", "1", "a", "a-2-1 ; ", "v", "v-2-1. ", "p", "i-2-1"],
100     [440, "0", "1", "a", "a-3-1 ; ", "v", "v-3-1. ", "p", "i-3-1"],
101     [440, "0", "1", "a", "a-4-1 ; ", "v", "v-4-1. ", "p", "i-4-1 ; ", "v", "w-4-1"],
102     [440, "0", "1", "a", "a-5-1 ; ", "v", "v-5-1. ", "p", "i-5-1"],
103     [440, "0", "1", "a", "a-6-1. ", "p", "i-6-1 ; ", "v", "w-6-1"],
104     [440, "0", "1", "a", "a-7-1"],
105     [440, "0", "1", "a", "a-8-1 ;", "v", "v-8-1"],
106     [440, "0", "1", "v", "v-9-1"],
107 dpavlin 1062 [440, 0, 1, "v", 0],
108 dpavlin 1036 ];
109    
110     is_deeply( test_marc_template($rec), $marc_out , 'is_deeply');
111    
112     my $max_occ = $#{ $rec->{225} };
113    
114     foreach my $from ( 0 .. $max_occ - 1 ) {
115 dpavlin 1038 foreach my $to ( $from + 1 .. $max_occ ) {
116     my @orig_rec = @{ $rec->{225} };
117 dpavlin 1036 my $new_rec = {
118 dpavlin 1038 225 => [ splice( @orig_rec, $from, $to ) ],
119 dpavlin 1036 };
120 dpavlin 1038 diag "$from-$to new_rec = ",dump( $new_rec ) if $debug;
121 dpavlin 1036
122 dpavlin 1038 my @expect = @$marc_out;
123     my $expect_marc = [ splice( @expect, $from, $to ) ];
124     diag "$from-$to expect_marc = ",dump( $expect_marc ) if $debug;
125    
126     is_deeply( test_marc_template($new_rec), $expect_marc, "$from-$to is_deeply");
127    
128 dpavlin 1036 }
129     }
130 dpavlin 1108
131     sub test_marc_clone {
132 dpavlin 1109 my ( $rec, $expect ) = @_;
133 dpavlin 1108
134     ok( _clean_ds(), '_clean_ds' );
135     ok( _set_ds( $rec ), '_set_ds' );
136    
137 dpavlin 1109 ok( ! marc_clone, 'marc_clone' );
138 dpavlin 1108
139     ok(my $marc = WebPAC::Normalize::MARC::_get_marc_fields(), "_get_marc_fields");
140 dpavlin 1109 # diag "rec = ",dump( $rec );
141 dpavlin 1368 diag "marc = ",dump( $marc );
142     diag "expect = ",dump( $expect );
143 dpavlin 1108
144 dpavlin 1109 is_deeply( $marc, $expect, 'marc_clone same' );
145 dpavlin 1368 diag "marc_leader = ",dump( marc_leader );
146     cmp_ok( WebPAC::Normalize::MARC::marc_leader()->{0}, 'eq', $rec->{leader}->[0], 'leader' );
147 dpavlin 1108
148     }
149    
150 dpavlin 1368 $rec = {
151     "000" => [2],
152     "001" => ["ocm00734950"],
153 dpavlin 1111 "003" => ["OCoLC"],
154     "040" => [
155     {
156     a => "DLC",
157     c => "BOS",
158     d => "TML",
159 dpavlin 1368 i1 => "1",
160     i2 => "2",
161     subfields => ["a", 0, "c", 0, "d", 0],
162 dpavlin 1111 },
163     ],
164     245 => [
165     {
166     1 => 2,
167     a => "A treatise on insanity /",
168     c => "translated from the French by D. D. Davis, with an introd. by Paul F. Cranefield.",
169     subfields => [1, 0, "a", 0, "c", 0],
170 dpavlin 1368 i1 => '0',
171     i2 => '1',
172 dpavlin 1111 },
173     ],
174     leader => ["01237cam 2200301Ii 4500"],
175     };
176    
177     test_marc_clone( $rec, [
178 dpavlin 1368 ["000", 2],
179     ["001", "ocm00734950"],
180     ["003", "OCoLC"],
181     ["040", 1,2, "a" => "DLC", "c" => "BOS", "d" => "TML"],
182     [ 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." ],
183 dpavlin 1109 ] );
184 dpavlin 1108

Properties

Name Value
svn:executable *

  ViewVC Help
Powered by ViewVC 1.1.26