added test to manifest
[MARC-Fast] / t / 001_marc.t
index 547d5cb..ddb9070 100755 (executable)
@@ -3,35 +3,64 @@
 use strict;
 use blib;
 
-use Test::More tests => 20;
-use Test::Exception;
-use Data::Dumper;
+use Test::More tests => 63;
+use Data::Dump qw/dump/;
 
-BEGIN { use_ok( 'MARC::Fast' ); }
+BEGIN {
+       use_ok( 'MARC::Fast' );
+}
+
+my $debug = shift @ARGV;
+
+my $marc_file = 't/camel.usmarc';
 
 my $marc;
 my %param;
 
-throws_ok { $marc = MARC::Fast->new(%param); } qr/marcdb/, "marcdb parametar";
+eval { $marc = MARC::Fast->new(%param) };
+ok( $@ =~ /marcdb/, "marcdb parametar" );
 
 $param{marcdb} = '/foo/bar/file';
 
-throws_ok { $marc = MARC::Fast->new(%param); } qr/foo.bar/, "marcdb exist";
+eval { $marc = MARC::Fast->new(%param) };
+ok( $@ =~ /foo.bar/, "marcdb exist" );
 
-$param{marcdb} = '../unimarc.iso';
+$param{marcdb} = $marc_file if -e $marc_file;
 
-ok($marc = MARC::Fast->new(%param), "new");
+SKIP: {
+       skip "no $param{marcdb} test file ", 37 unless (-e $param{marcdb});
 
-isa_ok ($marc, 'MARC::Fast');
+       diag "marc file: $marc_file";
 
-cmp_ok($marc->count, '==', scalar @{$marc->{leaders}}, "count == leaders");
-cmp_ok($marc->count, '==', scalar @{$marc->{fh_offset}}, "count == fh_offset");
+       ok($marc = MARC::Fast->new(%param), "new");
 
-ok(! $marc->fetch(0), "fetch 0");
-ok($marc->fetch($marc->count), "fetch max:".$marc->count);
-ok(! $marc->fetch($marc->count + 1), "fetch max+1:".($marc->count+1));
+       isa_ok ($marc, 'MARC::Fast');
 
-foreach (1 .. 10) {
-       ok($marc->fetch($_), "fetch $_");
-}
+       #diag Dumper($marc);
+
+       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->last_leader, "last_leader $_");
+
+               ok(my $hash = $marc->to_hash($_), "to_hash($_)");
+               diag "to_hash($_) = ",Data::Dump::dump($hash) if ($debug);
+
+               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");
+}