/[webpac2]/trunk/t/3-normalize-set.t
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/t/3-normalize-set.t

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 461 by dpavlin, Fri May 12 14:54:25 2006 UTC revision 471 by dpavlin, Sat May 13 12:07:37 2006 UTC
# Line 2  Line 2 
2    
3  use strict;  use strict;
4    
5  use Test::More tests => 23;  use Test::More tests => 25;
6  use Test::Exception;  use Test::Exception;
7  use Cwd qw/abs_path/;  use Cwd qw/abs_path/;
8  use blib;  use blib;
9  use File::Slurp;  use File::Slurp;
10    
11  use Data::Dumper;  use Data::Dumper;
12    my $debug = 0;
13    
14  BEGIN {  BEGIN {
15          use_ok( 'WebPAC::Normalize::Set' );          use_ok( 'WebPAC::Normalize::Set' );
16  }  }
17    
18  ok(my $abs_path = abs_path($0), "abs_path");  ok(my $abs_path = abs_path($0), "abs_path");
19  $abs_path =~ s#/[^/]*$#/../#;  $abs_path =~ s#/[^/]*$#/#;
20  #diag "abs_path: $abs_path";  diag "abs_path: $abs_path" if ($debug);
21    
22  #throws_ok { new WebPAC::Normalize::XML( lookup_regex => 'foo' ) } qr/pair/, "lookup_regex without lookup";  #throws_ok { new WebPAC::Normalize::XML( lookup_regex => 'foo' ) } qr/pair/, "lookup_regex without lookup";
23    
24  my $rec = {  my $rec1 = {
25            '200' => [{
26                    'a' => '200a',
27                    'b' => '200b',
28                    },{
29                    'c' => '200c',
30                    'd' => '200d',
31                    },{
32                    'a' => '200a*2',
33                    'd' => '200d*2',
34                    }],
35            '201' => [{
36                    'x' => '201x',
37                    'y' => '201y',
38                    }],
39            '900' => [
40                    '900-no_subfield'
41                    ],
42            '901' => [{
43                    'a' => '900a',
44                    }],
45            '902' => [{
46                    'z' => '900',
47                    }],
48    };
49    
50    my $rec2 = {
51   '675' => [ {   '675' => [ {
52                'a' => '159.9'                'a' => '159.9'
53              } ],              } ],
# Line 66  my $rec = { Line 93  my $rec = {
93   '101' => [ 'ENG' ],   '101' => [ 'ENG' ],
94   '686' => [ '2140' ],   '686' => [ '2140' ],
95   '300' => [ 'Prijevod djela: ' ],   '300' => [ 'Prijevod djela: ' ],
  '999' => [ { 'z' => '900' } ],  
96  };  };
97    
98    
99  my $lookup = {  my $lookup1 = {
100          '00900' => [          '00900' => [
101                  'lookup vrijednost 1',                  'lookup 1',
102                  'lookup vrijednost 2',                  'lookup 2',
103          ],          ],
104  };  };
105    
106  print Dumper($rec);  my $lookup2 = {
107            '00900' => 'lookup',
108    };
109    
110    
111  sub test {  sub test {
112          print Dumper( @_ ), ("-" x 78), "\n";          print Dumper( @_ ), ("-" x 78), "\n";
113          ok( defined(@_) );          ok( defined(@_) );
114  }  }
115    
116    # how much of string evaled to display?
117    my $max_eval_output = 170;
118    
119    sub dump_error {
120            my ($msg,$code) = @_;
121    
122            my @l = split(/[\n\r]/, $code);
123            my $out = "$msg\n";
124    
125            foreach my $i ( 0 .. $#l ) {
126                    $out .= sprintf("%2d: %s\n", $i, $l[$i]);
127            }
128    
129            return $out;
130    }
131    
132  sub test_s {  sub test_s {
133          my $t = shift || die;          my $t = shift || die;
134          $t =~ s/[\n\r\s]+/ /gs;  
135          ok(my $v = eval "$t", "eval: $t");          my $eval_t = $t;
136          ok(! $@, "eval error: $@");          $eval_t =~ s/[\n\r\s]+/ /gs;
137            $eval_t = substr($eval_t,0,$max_eval_output) . '...' if (length($eval_t) > $max_eval_output);
138    
139            eval "$t";
140            ok(! $@, $@ ? dump_error($@, $t) : "eval: $eval_t");
141  }  }
142    
143  {  {
144          no strict 'subs';          no strict 'subs';
145          use WebPAC::Normalize::Set;          use WebPAC::Normalize::Set;
146    
147          set_rec( $rec );          set_rec( $rec1 );
148    
149            cmp_ok( join(",", rec2('200','a') ), 'eq', '200a,200a*2', 'join rec2' );
150            cmp_ok( join(",", rec2('200','a'), rec2('200','b') ), 'eq', '200a,200a*2,200b', 'join rec2 rec2' );
151            cmp_ok( join(" * ", sort(rec1('200'), rec1('201') )), 'eq', '200a * 200a*2 * 200b * 200c * 200d * 200d*2 * 201x * 201y', 'join sort rec1 rec1' );
152            diag "is_deeply checks\n";
153            is_deeply( \[ rec1('200') ], \[ qw/200a 200b 200c 200d 200a*2 200d*2/ ] );
154            is_deeply( \[ regex( 's/0/o/g', rec1('200') ) ],  \[ qw/2ooa 2oob 2ooc 2ood 2ooa*2 2ood*2/ ]);
155            is_deeply( \[ grep { /\*/ } regex( 's/0/o/g', rec1('200') ) ], \[ qw/2ooa*2 2ood*2/ ]);
156            is_deeply( \[ rec('902') ], \[ '900' ] );
157    
158          test( join(",", rec2('200','a') ) );          cmp_ok( rec('902'), 'eq', rec('902','z'), 'rec sf' );
159          test( join(",", rec2('200','a'), rec2('200','b') ) );  
160          test( join(" * ",rec1('200'), rec1('201') ) );          set_lookup( $lookup1 );
161          test( rec1('200') );          
162          test( regex( 's/0/o/g', rec1('200') ) );          cmp_ok(
         test( grep { /\*/ } regex( 's/0/o/g', rec1('200') ) );  
         test( rec('999') );  
         test( rec('999','z') );  
         test(  
163                  join_with(" i ",                  join_with(" i ",
164                          lookup(                          lookup(
165                                  regex( 's/^/00/',                                  regex( 's/^/00/',
166                                          rec2('999','z')                                          rec2('902','z')
167                                  )                                  )
168                          )                          )
169                  )                  ),
170          );          'eq', 'lookup 1 i lookup 2', 'join lookup regex rec2');
171    
172            set_lookup( $lookup2 );
173    
174            is_deeply( \[ lookup( prefix( '00', rec('902') ) ) ], \[ 'lookup' ], 'lookup prefix' );
175    
176            ok(! lookup('non-existent'), 'lookup non-existant' );
177    
178            set_rec( $rec2 );
179    
180          test_s(qq{          test_s(qq{
181                  tag('Title',                  tag('Title',
# Line 144  sub test_s { Line 206  sub test_s {
206          });          });
207    
208          ok(my $ds = get_ds(), "get_ds");          ok(my $ds = get_ds(), "get_ds");
209          diag "ds = ", Dumper($ds);          diag "ds = ", Dumper($ds) if ($debug);
210    
211            clean_ds();
212    
213            test_s(qq{ search('something', '42'); });
214            test_s(qq{ search('empty', ''); });
215    
216            ok($ds = get_ds(), 'get_ds');
217            diag Dumper( $ds ) if ($debug);
218    
219            ok( $ds && $ds->{something}, 'get_ds->something' );
220            ok( $ds && !$ds->{empty}, 'get_ds->empty' );
221    
222          clean_ds();          clean_ds();
223    
224          my $n = read_file( "$abs_path/conf/normalize/isis_ffzg.pl" );          my $n = read_file( "$abs_path/data/normalize.pl" );
225          $n .= "\n1;\n";          $n .= "\n1;\n";
226          #diag "normalize code:\n$n\n";          #diag "normalize code:\n$n\n";
227          test_s( $n );          test_s( $n );
228    
229          ok($ds = get_ds(), "get_ds");          ok($ds = get_ds(), "get_ds");
230          diag "ds = ", Dumper($ds);          diag "ds = ", Dumper($ds) if ($debug);
231  }  }
232    

Legend:
Removed from v.461  
changed lines
  Added in v.471

  ViewVC Help
Powered by ViewVC 1.1.26