2 |
|
|
3 |
use strict; |
use strict; |
4 |
|
|
5 |
use Test::More tests => 157; |
use Test::More tests => 311; |
6 |
use Test::Exception; |
use Test::Exception; |
7 |
use Cwd qw/abs_path/; |
use Cwd qw/abs_path/; |
8 |
use blib; |
use blib; |
32 |
$abs_path =~ s#/[^/]*$#/#; |
$abs_path =~ s#/[^/]*$#/#; |
33 |
diag "abs_path: $abs_path" if ($debug); |
diag "abs_path: $abs_path" if ($debug); |
34 |
|
|
|
#throws_ok { new WebPAC::Normalize::XML( lookup_regex => 'foo' ) } qr/pair/, "lookup_regex without lookup"; |
|
|
|
|
35 |
my $rec1 = { |
my $rec1 = { |
36 |
'200' => [{ |
'200' => [{ |
37 |
'a' => '200a', |
'a' => '200a', |
107 |
}; |
}; |
108 |
|
|
109 |
|
|
110 |
my $lookup1 = { |
my $lookup_hash1 = { |
111 |
'00900' => [ |
'db1' => { |
112 |
'lookup 1', |
'input1' => { |
113 |
'lookup 2', |
'key1' => { 1 => 1 }, |
114 |
], |
'key2' => { 2 => 1 }, |
115 |
|
}, |
116 |
|
'input2' => { |
117 |
|
'key3' => { 3 => 1 }, |
118 |
|
'key4' => { 4 => 1 }, |
119 |
|
}, |
120 |
|
}, |
121 |
|
'db2' => { |
122 |
|
'input3' => { |
123 |
|
'key5' => { 5 => 1 }, |
124 |
|
'key6' => { 6 => 1 }, |
125 |
|
}, |
126 |
|
} |
127 |
}; |
}; |
128 |
|
|
129 |
my $lookup2 = { |
my $lookup_hash2 = { |
130 |
'00900' => 'lookup', |
'db3' => { |
131 |
|
'input4' => { |
132 |
|
'key7' => { 7 => 1 }, |
133 |
|
'key8' => { 8 => 1 }, |
134 |
|
}, |
135 |
|
} |
136 |
}; |
}; |
137 |
|
|
|
|
|
138 |
sub test { |
sub test { |
139 |
print dump( @_ ), ("-" x 78), "\n"; |
print dump( @_ ), ("-" x 78), "\n"; |
140 |
ok( defined(@_) ); |
ok( defined(@_) ); |
194 |
cmp_ok( join('', suffix('xy', 'cd') ), 'eq', 'cdxy', 'suffix'); |
cmp_ok( join('', suffix('xy', 'cd') ), 'eq', 'cdxy', 'suffix'); |
195 |
cmp_ok( join('', surround('->', '<-', 'a','b','c') ), 'eq', '->a<-->b<-->c<-', 'surround'); |
cmp_ok( join('', surround('->', '<-', 'a','b','c') ), 'eq', '->a<-->b<-->c<-', 'surround'); |
196 |
|
|
197 |
|
# lookups |
198 |
|
|
199 |
|
throws_ok { _set_load_row() } qr/CODE/, 'empty _set_load_row()'; |
200 |
|
|
201 |
|
ok(_set_load_row(sub { |
202 |
|
my ($database,$input,$mfn) = @_; |
203 |
|
diag "load_row( $database, $input, $mfn )"; |
204 |
|
cmp_ok( $#_, '==', 2, 'have 3 arguments'); |
205 |
|
ok($database, '_load_row database'); |
206 |
|
ok($input, '_load_row input'); |
207 |
|
ok($mfn, '_load_row mfn'); |
208 |
|
return { |
209 |
|
'900' => [{ x => '900x-' . $mfn , y => '900y-' . $mfn }], |
210 |
|
} |
211 |
|
|
212 |
|
}), '_set_load_row'); |
213 |
|
|
214 |
|
my @v = qw/foo bar baz aaa bbb ccc ddd/; |
215 |
|
|
216 |
|
my @accumulated; |
217 |
|
|
218 |
|
for my $i ( 0 .. $#v ) { |
219 |
|
|
220 |
|
my $mfn = 1000 + $i; |
221 |
|
|
222 |
|
ok(WebPAC::Normalize::_set_config({ '_mfn' => $mfn }), "_set_config _mfn=$mfn"); |
223 |
|
|
224 |
|
my $size = $#v + 1; |
225 |
|
|
226 |
|
cmp_ok( |
227 |
|
save_into_lookup('db','input','key', sub { @v }), |
228 |
|
'==', $size, "save_into_lookup $size values" |
229 |
|
); |
230 |
|
|
231 |
|
ok(my $l = WebPAC::Normalize::_get_lookup(), '_get_lookup'); |
232 |
|
diag "_get_lookup = ", dump($l); |
233 |
|
|
234 |
|
my @lookup; |
235 |
|
|
236 |
|
ok(@lookup = lookup( |
237 |
|
sub { |
238 |
|
diag "in show"; |
239 |
|
rec('900','x'); |
240 |
|
}, |
241 |
|
'db','input','key', |
242 |
|
sub { |
243 |
|
return @v; |
244 |
|
} |
245 |
|
), |
246 |
|
"lookup db/input/key"); |
247 |
|
|
248 |
|
push @accumulated, '900x-' . $mfn; |
249 |
|
|
250 |
|
is_deeply(\@lookup, \@accumulated, "lookup db/input/key"); |
251 |
|
|
252 |
|
shift @v; |
253 |
|
|
254 |
|
} |
255 |
|
|
256 |
|
ok(my $l = WebPAC::Normalize::_get_lookup(), '_get_lookup'); |
257 |
|
diag "_get_lookup = ", dump($l); |
258 |
|
|
259 |
|
is_deeply( $l, { |
260 |
|
db => { |
261 |
|
input => { |
262 |
|
key => { |
263 |
|
foo => { 1000 => 1 }, |
264 |
|
bar => { 1000 => 1, 1001 => 1 }, |
265 |
|
baz => { 1000 => 1, 1001 => 1, 1002 => 1 }, |
266 |
|
aaa => { 1000 => 1, 1001 => 1, 1002 => 1, 1003 => 1 }, |
267 |
|
bbb => { 1000 => 1, 1001 => 1, 1002 => 1, 1003 => 1, 1004 => 1 }, |
268 |
|
ccc => { 1000 => 1, 1001 => 1, 1002 => 1, 1003 => 1, 1004 => 1, 1005 => 1 }, |
269 |
|
ddd => { 1000 => 1, 1001 => 1, 1002 => 1, 1003 => 1, 1004 => 1, 1005 => 1, 1006 => 1 }, |
270 |
|
}, |
271 |
|
}, |
272 |
|
}, |
273 |
|
}, 'lookup data'); |
274 |
|
|
275 |
|
####### |
276 |
|
|
277 |
|
diag "lookup_hash1 = ", dump($lookup_hash1); |
278 |
|
ok(_set_lookup( $lookup_hash1 ), '_set_lookup $lookup_hash1'); |
279 |
|
|
280 |
|
throws_ok { _set_load_row() } qr/CODE/, 'empty _set_load_row()'; |
281 |
|
|
282 |
|
ok(_set_load_row(sub { |
283 |
|
my ($database,$input,$mfn) = @_; |
284 |
|
diag "load_row( $database, $input, $mfn )"; |
285 |
|
cmp_ok( $#_, '==', 2, 'have 3 arguments'); |
286 |
|
ok($database, 'database'); |
287 |
|
ok($input, 'input'); |
288 |
|
ok($mfn, 'mfn'); |
289 |
|
|
290 |
|
}), '_set_load_row'); |
291 |
|
|
292 |
|
|
293 |
|
# cmp_ok(lookup( |
294 |
|
# sub { |
295 |
|
# 'found' |
296 |
|
# }, |
297 |
|
# 'db1','input1','key1', |
298 |
|
# sub { |
299 |
|
# rec('200','a') |
300 |
|
# } |
301 |
|
# ), 'eq', 'found', 'lookup db1/input1/key1'); |
302 |
|
|
303 |
|
|
|
_set_lookup( $lookup1 ); |
|
304 |
|
|
305 |
cmp_ok( |
# cmp_ok( |
306 |
join_with(" i ", |
# lookup( |
307 |
lookup( |
# ), |
308 |
regex( 's/^/00/', |
# 'eq', 'lookup 1 i lookup 2', 'join lookup regex rec2'); |
|
rec2('902','z') |
|
|
) |
|
|
) |
|
|
), |
|
|
'eq', 'lookup 1 i lookup 2', 'join lookup regex rec2'); |
|
309 |
|
|
310 |
# check join_with operations |
# check join_with operations |
311 |
|
|
349 |
|
|
350 |
# test lookups |
# test lookups |
351 |
|
|
352 |
_set_lookup( $lookup2 ); |
_set_lookup( $lookup_hash2 ); |
353 |
|
|
354 |
is_deeply( \[ lookup( prefix( '00', rec('902') ) ) ], \[ 'lookup' ], 'lookup prefix' ); |
throws_ok { lookup() } qr/need/, 'empty lookup'; |
355 |
|
|
356 |
ok(! lookup('non-existent'), 'lookup non-existant' ); |
#is_deeply( \[ lookup( prefix( '00', rec('902') ) ) ], \[ 'lookup' ], 'lookup prefix' ); |
357 |
|
|
358 |
|
#ok(! lookup('non-existent'), 'lookup non-existant' ); |
359 |
|
|
360 |
_set_rec( $rec2 ); |
_set_rec( $rec2 ); |
361 |
|
|
476 |
# |
# |
477 |
# MARC |
# MARC |
478 |
# |
# |
479 |
_debug( 4 ); |
#_debug( 4 ); |
480 |
|
|
481 |
test_s(qq{ marc_indicators('900',1,2) }); |
test_s(qq{ marc_indicators('900',1,2) }); |
482 |
test_s(qq{ marc('900','a', rec('200') ) }); |
test_s(qq{ marc('900','a', rec('200') ) }); |
725 |
[ '901', ' ', ' ', 'b', 'bar', 'c', 'baz' ], |
[ '901', ' ', ' ', 'b', 'bar', 'c', 'baz' ], |
726 |
], |
], |
727 |
); |
); |
728 |
|
|
729 |
|
test_s(qq{ marc_remove('*'); }); |
730 |
|
ok(! WebPAC::Normalize::_get_marc_fields(), 'marc_remove(*)'); |
731 |
|
|
732 |
test_rec_rules( |
test_rec_rules( |
733 |
'marc_duplicate', |
'marc_duplicate', |
734 |
{ '200' => [{ a => 42, b => 'bar', c => 'baz', d => 'bing', e => 'bong' }] }, |
{ '200' => [{ a => 42, b => 'bar', c => 'baz', d => 'bing', e => 'bong' }] }, |
811 |
'_pack_subfields_hash( $h )' |
'_pack_subfields_hash( $h )' |
812 |
); |
); |
813 |
|
|
814 |
is_deeply( |
cmp_ok( |
815 |
[ _pack_subfields_hash({ |
_pack_subfields_hash({ |
816 |
a => [ 'a1', 'a2' ], b => [ 'b1', 'b2' ], c => [ 'c1', 'c2' ], |
a => [ 'a1', 'a2' ], b => [ 'b1', 'b2' ], c => [ 'c1', 'c2' ], |
817 |
subfields => [ qw/a 0 b 0 a 1 b 1 c 0 c 1/ ], |
subfields => [ qw/a 0 b 0 a 1 b 1 c 0 c 1/ ], |
818 |
}, 1) ], |
}, 1), |
819 |
['^a','a1', '^b','b1', '^a','a2', '^b','b2', '^c','c1', '^c','c2'], |
'eq', |
820 |
|
'^aa1^bb1^aa2^bb2^cc1^cc2', |
821 |
'_pack_subfields_hash( $h, 1 )' |
'_pack_subfields_hash( $h, 1 )' |
822 |
); |
); |
823 |
} |
} |