push version to 0.24
[Biblio-Isis] / t / 2_isis.t
index 24f3b42..6ed4e85 100755 (executable)
@@ -3,7 +3,7 @@
 use strict;
 use blib;
 
-use Test::More tests => 112;
+use Test::More tests => 181;
 use File::Spec;
 
 BEGIN {
@@ -18,7 +18,7 @@ BEGIN {
 }
 
 
-my $debug = shift @ARGV;
+my $debug = length( shift(@ARGV) || '' );
 my $isis;
 
 my $path_winisis = File::Spec->catfile('data', 'winisis', 'BIBL');
@@ -111,8 +111,7 @@ sub test_data {
                my $rec;
                ok($rec = $isis->fetch($mfn), "fetch $mfn");
 
-
-               diag "<<<<< rec: ",Dumper( $rec ), "\n>>>>> row:", Dumper( $data->[$mfn-1] ) if ($debug);
+               diag "<<<<< rec = ",Dumper( $rec ), "\n>>>>> data = ", Dumper( $data->[$mfn-1] ) if ($debug);
 
                foreach my $f (keys %{$data->[$mfn-1]}) {
                        my $i = 0;
@@ -123,6 +122,9 @@ sub test_data {
                                $i++;
                        }
                }
+
+               cmp_ok($isis->mfn, '==', $mfn, 'mfn');
+
        }
 
        # test to_ascii
@@ -143,7 +145,7 @@ sub test_data {
 $isis = Biblio::Isis->new (
        isisdb => $path_winisis,
        include_deleted => 1,
-       debug => $debug,
+       debug => $debug > 1 ? ($debug - 1) : 0,
 );
 
 diag "new Biblio::Isis = ", Dumper($isis) if ($debug);
@@ -183,12 +185,143 @@ $isis = Biblio::Isis->new (
 
 ok($isis->fetch(3), "deleted found");
 cmp_ok($isis->{deleted}, '==', 3, "MFN 3 is deleted");
+ok($isis->{record}, "record exists");
+
+diag "record = ",Dumper($isis->{record}) if ($debug);
 
 $isis = Biblio::Isis->new (
        isisdb => $path_winisis,
        debug => $debug,
+       hash_filter => sub {
+               my ($l,$nr) = @_;
+               ok(grep(/$nr/, keys %{ $isis->{record} }), "hash_filter $nr in record");
+               ok(grep(/\Q$l\E/, @{ $isis->{record}->{$nr} }), "hash_filter line $l found");
+               return($l);
+       },
 );
 
 ok(! $isis->fetch(3), "deleted not found");
 cmp_ok($isis->{deleted}, '==', 3, "MFN 3 is deleted");
+ok(! $isis->{record}, 'no record');
+
+$isis->{record} = {
+       900 => [ '^a900a^b900b^c900c' ],
+       901 => [
+               '^a901a-1^b901b-1^c901c-1',
+               '^a901a-2^b901b-2',
+               '^a901a-3',
+       ],
+       902 => [
+               '^aa1^aa2^aa3^bb1^aa4^bb2^cc1^aa5',
+       ],
+};
+$isis->{current_mfn} = 42;
+
+ok(my $hash = $isis->to_hash( $isis->mfn ), 'to_hash');
+diag "to_hash = ",Dumper( $hash ) if ($debug);
+is_deeply( $hash, {
+       "000" => [42],
+       900   => [{ a => "900a", b => "900b", c => "900c" }],
+       901   => [
+               { a => "901a-1", b => "901b-1", c => "901c-1" },
+               { a => "901a-2", b => "901b-2" },
+               { a => "901a-3" },
+       ],
+       902   => [
+               { a => ["a1", "a2", "a3", "a4", "a5"], b => ["b1", "b2"], c => "c1" },
+       ],
+}, 'hash is_deeply');
+
+ok(my $ascii = $isis->to_ascii( $isis->mfn ), 'to_ascii');
+diag "to_ascii = \n", $ascii if ($debug);
+cmp_ok($ascii, 'eq', <<'__END_OF_ASCII__', 'to_ascii output');
+0      42
+900    ^a900a^b900b^c900c
+901    ^a901a-1^b901b-1^c901c-1
+901    ^a901a-2^b901b-2
+901    ^a901a-3
+902    ^aa1^aa2^aa3^bb1^aa4^bb2^cc1^aa5
+__END_OF_ASCII__
+
+ok(my $hash2 = $isis->to_hash({ mfn => $isis->mfn }), 'to_hash(mfn)');
+is_deeply( $hash2, $hash, 'same hash' );
+
+# test to_hash( include_subfields )
+ok($hash = $isis->to_hash({ mfn => $isis->mfn, include_subfields => 1 }), 'to_hash(mfn,include_subfields)');
+diag "to_hash = ",Dumper( $hash ) if ($debug);
+is_deeply( $hash, {
+  "000" => [42],
+  900   => [
+       { a => "900a", b => "900b", c => "900c", subfields => ["a", 0, "b", 0, "c", 0] },
+  ],
+  901   => [
+       { a => "901a-1", b => "901b-1", c => "901c-1", subfields => ["a", 0, "b", 0, "c", 0] },
+       { a => "901a-2", b => "901b-2", subfields => ["a", 0, "b", 0] },
+       { a => "901a-3", subfields => ["a", 0] },
+  ],
+  902   => [
+       { a => ["a1", "a2", "a3", "a4", "a5"], b => ["b1", "b2"], c => "c1",
+         subfields => ["a", 0, "a", 1, "a", 2, "b", 0, "a", 3, "b", 1, "c", 0, "a", 4],
+       },
+  ],
+}, 'hash is_deeply');
+
+# test to_hash( join_subfields_with )
+ok($hash = $isis->to_hash({ mfn => $isis->mfn, join_subfields_with => ' ; ' }), 'to_hash(mfn,join_subfields_with)');
+diag "to_hash = ",Dumper( $hash ) if ($debug);
+is_deeply( $hash, {
+   "000" => [42],
+   900   => [{ a => "900a", b => "900b", c => "900c" }],
+   901   => [
+              { a => "901a-1", b => "901b-1", c => "901c-1" },
+              { a => "901a-2", b => "901b-2" },
+              { a => "901a-3" },
+            ],
+   902   => [{ a => "a1 ; a2 ; a3 ; a4 ; a5", b => "b1 ; b2", c => "c1" }],
+}, 'hash is_deeply');
+
+my $isis2;
+ok($isis2 = Biblio::Isis->new (
+       isisdb => $path_winisis,
+       join_subfields_with => ' ; ',
+),"new( join_subfields_with )");
+ok($isis2->{record} = $isis->{record}, "copy record");
+ok($isis2->{current_mfn} = $isis->{current_mfn}, "copy current_mfn");
+
+ok($hash = $isis2->to_hash( $isis->mfn ), 'to_hash(mfn)');
+diag "to_hash = ",Dumper( $hash ) if ($debug);
+is_deeply( $hash, {
+   "000" => [42],
+   900   => [{ a => "900a", b => "900b", c => "900c" }],
+   901   => [
+              { a => "901a-1", b => "901b-1", c => "901c-1" },
+              { a => "901a-2", b => "901b-2" },
+              { a => "901a-3" },
+            ],
+   902   => [{ a => "a1 ; a2 ; a3 ; a4 ; a5", b => "b1 ; b2", c => "c1" }],
+}, 'hash is_deeply');
+
+# test to_hash( hash_filter )
+ok($hash = $isis->to_hash({ mfn => $isis->mfn, hash_filter => sub {
+       my ($l,$f) = @_;
+       if ($f == 900) {
+               $l =~ s/0/o/g;
+       } elsif ($f == 901) {
+               $l =~ s/1/i/g;
+       } elsif ($f == 902) {
+               $l =~ s/2/s/g;
+       }
+       return $l;
+}}), 'to_hash(mfn,hash_filter)');
+diag "to_hash = ",Dumper( $hash ) if ($debug);
+is_deeply( $hash, {
+   "000" => [42],
+   900   => [{ a => "9ooa", b => "9oob", c => "9ooc" }],
+   901   => [
+              { a => "90ia-i", b => "90ib-i", c => "90ic-i" },
+              { a => "90ia-2", b => "90ib-2" },
+              { a => "90ia-3" },
+            ],
+   902   => [{ a => ["a1", "as", "a3", "a4", "a5"], b => ["b1", "bs"], c => "c1" }],
+}, 'hash is_deeply');