/[webpac2]/trunk/t/6-unit.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/6-unit.t

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

revision 70 by dpavlin, Sat Nov 19 23:48:24 2005 UTC revision 491 by dpavlin, Sun May 14 12:39:39 2006 UTC
# Line 2  Line 2 
2    
3  use strict;  use strict;
4    
5  use Test::More tests => 34;  use Test::More tests => 41;
6  use Test::Exception;  use Test::Exception;
7  use Cwd qw/abs_path/;  use Cwd qw/abs_path/;
8  use File::Temp qw/tempdir/;  use File::Temp qw/tempdir/;
9    use File::Slurp;
10  use Data::Dumper;  use Data::Dumper;
11    use Time::HiRes qw/time/;
12  use blib;  use blib;
13    
14    my $debug = shift @ARGV;
15    
16  BEGIN {  BEGIN {
17  use_ok( 'WebPAC::Lookup' );  use_ok( 'WebPAC::Lookup' );
18  use_ok( 'WebPAC::Input::ISIS' );  use_ok( 'WebPAC::Input' );
19  use_ok( 'WebPAC::DB' );  use_ok( 'WebPAC::Store' );
20  use_ok( 'WebPAC::Normalize::XML' );  use_ok( 'WebPAC::Normalize::XML' );
21    use_ok( 'WebPAC::Normalize::Set' );
22  use_ok( 'WebPAC::Output::TT' );  use_ok( 'WebPAC::Output::TT' );
23  }  }
24    
25  ok(my $abs_path = abs_path($0), "abs_path");  ok(my $abs_path = abs_path($0), "abs_path");
26  $abs_path =~ s#/[^/]*$#/#;  $abs_path =~ s#/[^/]*$#/#;
27  diag "abs_path: $abs_path";  diag "abs_path: $abs_path" if ($debug);
28    
29  my $isis_file = "$abs_path../t/winisis/BIBL";  my $isis_file = "$abs_path../t/winisis/BIBL";
30  $isis_file = '/data/hidra/THS/THS';  #$isis_file = '/data/hidra/THS/THS';
31    $isis_file = '/data/isis_data/ffkk/';
32    
33    diag "isis_file: $isis_file" if ($debug);
34    
35    my $normalize_set_pl = "$abs_path/data/normalize.pl";
36    my $lookup_file = "$abs_path../conf/lookup/isis.pm";
37    
38  diag "isis_file: $isis_file";  my ($t1,$t2) = (0,0);
39    
40  ok(my $lookup = new WebPAC::Lookup(  ok(my $lookup = new WebPAC::Lookup(
41          lookup_file => "$abs_path../conf/lookup/isis.pm",          lookup_file => $lookup_file,
42  ), "new Lookup");  ), "new Lookup");
43    
44  ok(my $isis = new WebPAC::Input::ISIS(  ok(my $isis = new WebPAC::Input(
45            module => 'WebPAC::Input::ISIS',
46          code_page => 'ISO-8859-2',      # application encoding          code_page => 'ISO-8859-2',      # application encoding
47          limit_mfn => 10,          limit => 100,
48            no_progress_bar => 1,
49  ), "new Input::ISIS");  ), "new Input::ISIS");
50    
51  ok(my $maxmfn = $isis->open(  ok(my $maxmfn = $isis->open(
52          filename => $isis_file,          path => $isis_file,
53          code_page => '852',             # database encoding          code_page => '852',             # database encoding
54            lookup => $lookup,
55  ), "Input::ISIS->open");  ), "Input::ISIS->open");
56    
57  ok(my $path = tempdir( CLEANUP => 1 ), "path");  ok(my $path = tempdir( CLEANUP => 1 ), "path");
58    
59  ok(my $db = new WebPAC::DB(  ok(my $db = new WebPAC::Store(
60          path => $path,          path => $path,
61  ), "new DB");          database => '.',
62    ), "new Store");
63    
64  ok(my $n = new WebPAC::Normalize::XML(  ok(my $n = new WebPAC::Normalize::XML(
65  #       filter => { 'foo' => sub { shift } },  #       filter => { 'foo' => sub { shift } },
66          db => $db,          db => $db,
67          lookup_regex => $lookup->regex,          lookup_regex => $lookup->regex,
68          lookup => $lookup,          lookup => $lookup,
69            no_progress_bar => 1,
70  ), "new Normalize::XML");  ), "new Normalize::XML");
71    
72  ok($n->open(  ok($n->open(
73          tag => 'isis',          tag => 'isis',
74          xml_file => "$abs_path../conf/normalize/isis.xml",          xml_file => "$abs_path/data/normalize.xml",
75  ), "Normalize::XML->open");  ), "Normalize::XML->open");
76    
77    ok(my $norm_pl = read_file( $normalize_set_pl ), "set definitions: $normalize_set_pl" );
78    
79  ok(my $out = new WebPAC::Output::TT(  ok(my $out = new WebPAC::Output::TT(
80          include_path => "$abs_path../conf/output/tt",          include_path => "$abs_path../conf/output/tt",
81          filters => { foo => sub { shift } },          filters => { foo => sub { shift } },
82  ), "new Output::TT");  ), "new Output::TT");
83    
84  while (my $row = $isis->fetch) {  diag " lookup => ",Dumper($lookup->lookup_hash) if ($debug);
85            
86          ok(my $ds = $n->data_structure($row), "data_structure");  foreach my $pos ( 0 ... $isis->size ) {
87    
88  #       diag Dumper($ds);          my $row = $isis->fetch || next;
89    
90            diag " row $pos => ",Dumper($row) if ($debug);
91    
92            my $t = time();
93            ok(my $ds = $n->data_structure($row), "XML data_structure");
94            $t1 += time() - $t;
95    
96            diag " ds $pos => ",Dumper($ds) if ($debug);
97    
98            $t = time();
99            ok( my $ds2 = WebPAC::Normalize::Set::data_structure(
100                    lookup => $lookup->lookup_hash,
101                    row => $row,
102                    rules => $norm_pl,
103            ), "Set data_structure");
104            $t2 += time() - $t;
105    
106            diag " ds2 $pos => ",Dumper($ds2) if ($debug);
107            is_deeply( $ds, $ds2, 'ds same for xml and sets');
108    
109          ok(my $html = $out->apply(          ok(my $html = $out->apply(
110                  template => 'html.tt',                  template => 'html.tt',
# Line 76  while (my $row = $isis->fetch) { Line 113  while (my $row = $isis->fetch) {
113    
114          $html =~ s#\s*[\n\r]+\s*##gs;          $html =~ s#\s*[\n\r]+\s*##gs;
115    
116          diag $html;          #diag $html;
117    
118  };  };
119    
120    diag sprintf("timings: %.2fs vs %.2fs [%1.2f%%]\n", $t1, $t2, ($t1 / $t2) * 100);

Legend:
Removed from v.70  
changed lines
  Added in v.491

  ViewVC Help
Powered by ViewVC 1.1.26