X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=t%2F001_marc.t;h=c05fcd611e101b63fd9aecc7c795804053206a39;hb=3d844dfbf091bc62a45aff80189d402d1f9cba1f;hp=3553dc346bc07a76873dab1e27d7d9d3caa62655;hpb=32a687e3527bec06b7a15ccceb53e6ba9f5d272a;p=MARC-Fast diff --git a/t/001_marc.t b/t/001_marc.t index 3553dc3..c05fcd6 100755 --- a/t/001_marc.t +++ b/t/001_marc.t @@ -3,7 +3,7 @@ use strict; use blib; -use Test::More tests => 40; +use Test::More tests => 63; use Test::Exception; BEGIN { @@ -11,6 +11,9 @@ BEGIN { } my $debug = shift @ARGV; + +my $marc_file = 't/camel.usmarc'; + if ( $debug ) { eval { require Data::Dump; }; $debug = 0 if ($@); @@ -25,30 +28,42 @@ $param{marcdb} = '/foo/bar/file'; throws_ok { $marc = MARC::Fast->new(%param); } qr/foo.bar/, "marcdb exist"; -$param{marcdb} = 'data/unimarc.iso'; +$param{marcdb} = $marc_file if -e $marc_file; SKIP: { skip "no $param{marcdb} test file ", 37 unless (-e $param{marcdb}); + diag "marc file: $marc_file"; + ok($marc = MARC::Fast->new(%param), "new"); isa_ok ($marc, 'MARC::Fast'); #diag Dumper($marc); - cmp_ok($marc->count, '==', scalar @{$marc->{leaders}}, "count == leaders"); + cmp_ok($marc->count, '==', scalar @{$marc->{leader}}, "count == leader"); cmp_ok($marc->count, '==', scalar @{$marc->{fh_offset}}, "count == fh_offset"); ok(! $marc->fetch(0), "fetch 0"); + ok(! $marc->last_leader, "no last_leader"); ok($marc->fetch($marc->count), "fetch max:".$marc->count); ok(! $marc->fetch($marc->count + 1), "fetch max+1:".($marc->count+1)); foreach (1 .. 10) { - ok($marc->fetch($_), "fetch $_"); + ok($marc->fetch($_), "fetch($_)"); + + ok($marc->last_leader, "last_leader $_"); - ok(my $hash = $marc->to_hash($_), "to_hash $_"); + ok(my $hash = $marc->to_hash($_), "to_hash($_)"); diag "to_hash($_) = ",Data::Dump::dump($hash) if ($debug); - ok(my $ascii = $marc->to_ascii($_), "to_ascii $_"); + + ok(my $hash_sf = $marc->to_hash($_, include_subfields => 1), "to_hash($_,include_subfields)"); + diag "to_hash($_, include_subfields => 1) = ",Data::Dump::dump($hash_sf) if ($debug); + + ok(my $ascii = $marc->to_ascii($_), "to_ascii($_)"); diag "to_ascii($_) ::\n$ascii" if ($debug); } + + ok(! $marc->fetch(0), "fetch(0) again"); + ok(! $marc->last_leader, "no last_leader"); }