X-Git-Url: http://git.rot13.org/?p=Biblio-Isis;a=blobdiff_plain;f=t%2F2_isis.t;h=dd467711e68e3eff4edf23575af4b2cbdac95c16;hp=83508d1b61a062a9be3f62e69387f7267ee6976c;hb=1d7ffb42f40b3837c71123f616cc8ba7349ffd5e;hpb=8a285525531c2188987bd86c250ffdab75115f5f diff --git a/t/2_isis.t b/t/2_isis.t index 83508d1..dd46771 100755 --- a/t/2_isis.t +++ b/t/2_isis.t @@ -3,7 +3,7 @@ use strict; use blib; -use Test::More tests => 134; +use Test::More tests => 136; use File::Spec; BEGIN { @@ -271,3 +271,59 @@ is_deeply( $hash, { ], 902 => [{ a => "a1 ; a2 ; a3 ; a4 ; a5", b => "b1 ; b2", c => "c1" }], }, 'hash is_deeply'); + +# split_on_delimiters + +$isis->{record} = { + 900 => [ '^a900a : 900b ; 900c' ], + 901 => [ + '^a901a-1 x 901b-1 y 901c-1', + '^b901b-2 x 901b-2', + '^c901c-3 y 901c-3', + ], +}; + +my $split_on_delimiters = { + 900 => { a => { ' : ' => 'b', ' ; ' => 'c' } }, + 901 => { + a => { ' x ' => 'b', ' y ' => 'c' }, + b => { ' x ' => 'b' }, + c => { ' y ' => 'c' } + }, +}; + +diag "split_on_delimiters = ", Dumper($split_on_delimiters); + +my $regexpes; + +foreach my $f (keys %$split_on_delimiters) { +warn "--- f: $f\n"; + foreach my $sf (keys %{ $split_on_delimiters->{$f} }) { +warn "---- sf: $sf\n"; + foreach my $patt (keys %{ $split_on_delimiters->{$f}->{$sf} }) { + my $new_sf = $split_on_delimiters->{$f}->{$sf}->{$patt} || die "no field?"; +warn "----- patt: $patt -> $new_sf\n"; + + # fool-proof spaces in pattern + $patt =~ s/\s+/\\s\+/g; + + push @{ $regexpes->{$f} }, + 's/\^' . $sf . '([^\^]+)' . $patt . '([^\^]+)/^' . $sf . '$1^' . $new_sf . '$2/g'; + } + } +} + +diag "generated regexpes = ", Dumper( $regexpes ); + + +ok($hash = $isis->to_hash({ mfn => $isis->mfn, regexps => $regexpes, }), 'to_hash(mfn,regexpes)'); +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" }, + { b => ["901b-2", "901b-2"] }, + { c => ["901c-3", "901c-3"] }, + ], +}, 'hash is_deeply');