r1650@llin: dpavlin | 2007-11-20 11:07:57 +0100
[webpac2] / t / 6-unit.t
index 27d627c..ab27783 100755 (executable)
@@ -2,23 +2,25 @@
 
 use strict;
 
-use Test::More tests => 41;
+use Test::More tests => 31;
 use Test::Exception;
 use Cwd qw/abs_path/;
 use File::Temp qw/tempdir/;
 use File::Slurp;
-use Data::Dumper;
+use Data::Dump qw/dump/;
 use Time::HiRes qw/time/;
 use blib;
 
 my $debug = shift @ARGV;
 
+#
+# FIXME add lookup testing!
+#
+
 BEGIN {
-use_ok( 'WebPAC::Lookup' );
 use_ok( 'WebPAC::Input' );
 use_ok( 'WebPAC::Store' );
-use_ok( 'WebPAC::Normalize::XML' );
-use_ok( 'WebPAC::Normalize::Set' );
+use_ok( 'WebPAC::Normalize' );
 use_ok( 'WebPAC::Output::TT' );
 }
 
@@ -28,19 +30,13 @@ diag "abs_path: $abs_path" if ($debug);
 
 my $isis_file = "$abs_path../t/winisis/BIBL";
 #$isis_file = '/data/hidra/THS/THS';
-$isis_file = '/data/isis_data/ffkk/';
+#$isis_file = '/data/isis_data/ffkk/';
 
 diag "isis_file: $isis_file" if ($debug);
 
 my $normalize_set_pl = "$abs_path/data/normalize.pl";
 my $lookup_file = "$abs_path../conf/lookup/isis.pm";
 
-my ($t1,$t2) = (0,0);
-
-ok(my $lookup = new WebPAC::Lookup(
-       lookup_file => $lookup_file,
-), "new Lookup");
-
 ok(my $isis = new WebPAC::Input(
        module => 'WebPAC::Input::ISIS',
        code_page => 'ISO-8859-2',      # application encoding
@@ -50,29 +46,19 @@ ok(my $isis = new WebPAC::Input(
 
 ok(my $maxmfn = $isis->open(
        path => $isis_file,
-       code_page => '852',             # database encoding
-       lookup => $lookup,
+       code_page => 'cp852',           # database encoding
+       lookup_coderef => sub {
+               my $rec = shift || return;
+               ok($rec, 'lookup_coderef has rec');
+               ok(defined($rec->{'000'}->[0]), 'have mfn');
+       },
 ), "Input::ISIS->open");
 
 ok(my $path = tempdir( CLEANUP => 1 ), "path");
 
-ok(my $db = new WebPAC::Store(
-       path => $path,
+ok(my $db = new WebPAC::Store({
        database => '.',
-), "new Store");
-
-ok(my $n = new WebPAC::Normalize::XML(
-#      filter => { 'foo' => sub { shift } },
-       db => $db,
-       lookup_regex => $lookup->regex,
-       lookup => $lookup,
-       no_progress_bar => 1,
-), "new Normalize::XML");
-
-ok($n->open(
-       tag => 'isis',
-       xml_file => "$abs_path/data/normalize.xml",
-), "Normalize::XML->open");
+}), "new Store");
 
 ok(my $norm_pl = read_file( $normalize_set_pl ), "set definitions: $normalize_set_pl" );
 
@@ -81,42 +67,22 @@ ok(my $out = new WebPAC::Output::TT(
        filters => { foo => sub { shift } },
 ), "new Output::TT");
 
-diag " lookup => ",Dumper($lookup->lookup_hash) if ($debug);
+my $t_norm = 0;
 
 foreach my $pos ( 0 ... $isis->size ) {
 
        my $row = $isis->fetch || next;
 
-       diag " row $pos => ",Dumper($row) if ($debug);
+       diag " row $pos => ",dump($row) if ($debug);
 
        my $t = time();
+       ok( my $ds = WebPAC::Normalize::data_structure(
+               row => $row,
+               rules => $norm_pl,
+       ), "Set data_structure");
+       $t_norm += time() - $t;
 
-       ok(my $ds = $n->data_structure($row), "data_structure");
-
-       $t1 += time() - $t;
-
-       diag " ds $pos => ",Dumper($ds) if ($debug);
-
-       $t = time();
-       my $ds2;
-
-       # TODO move somewhere
-       {
-               no strict 'subs';
-               use WebPAC::Normalize::Set;
-               set_lookup( $lookup->lookup_hash );
-               set_rec( $row );
-               clean_ds();
-               eval "$norm_pl";
-               ok(! $@, $@ ? "error: $@" : "no error");
-               ok($ds2 = get_ds(), "get_ds");
-       
-       }
-
-       $t2 += time() - $t;
-
-       diag " ds2 $pos => ",Dumper($ds2) if ($debug);
-       is_deeply( $ds, $ds2, 'ds same for xml and sets');
+       diag " ds $pos => ",dump($ds) if ($debug);
 
        ok(my $html = $out->apply(
                template => 'html.tt',
@@ -129,4 +95,4 @@ foreach my $pos ( 0 ... $isis->size ) {
 
 };
 
-diag sprintf("timings: %.2fs vs %.2fs [%1.2f%%]\n", $t1, $t2, ($t1 / $t2) * 100);
+diag sprintf("timings: %.2fs\n", $t_norm);