2 |
|
|
3 |
use strict; |
use strict; |
4 |
|
|
5 |
use Test::More tests => 41; |
use Test::More tests => 24; |
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/; |
17 |
use_ok( 'WebPAC::Lookup' ); |
use_ok( 'WebPAC::Lookup' ); |
18 |
use_ok( 'WebPAC::Input' ); |
use_ok( 'WebPAC::Input' ); |
19 |
use_ok( 'WebPAC::Store' ); |
use_ok( 'WebPAC::Store' ); |
20 |
use_ok( 'WebPAC::Normalize::XML' ); |
use_ok( 'WebPAC::Lookup::Normalize' ); |
21 |
use_ok( 'WebPAC::Normalize::Set' ); |
use_ok( 'WebPAC::Normalize' ); |
22 |
use_ok( 'WebPAC::Output::TT' ); |
use_ok( 'WebPAC::Output::TT' ); |
23 |
} |
} |
24 |
|
|
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/'; |
#$isis_file = '/data/isis_data/ffkk/'; |
32 |
|
|
33 |
diag "isis_file: $isis_file" if ($debug); |
diag "isis_file: $isis_file" if ($debug); |
34 |
|
|
35 |
my $normalize_set_pl = "$abs_path/data/normalize.pl"; |
my $normalize_set_pl = "$abs_path/data/normalize.pl"; |
36 |
my $lookup_file = "$abs_path../conf/lookup/isis.pm"; |
my $lookup_file = "$abs_path../conf/lookup/isis.pm"; |
37 |
|
|
|
my ($t1,$t2) = (0,0); |
|
|
|
|
38 |
ok(my $lookup = new WebPAC::Lookup( |
ok(my $lookup = new WebPAC::Lookup( |
39 |
lookup_file => $lookup_file, |
lookup_file => $lookup_file, |
40 |
), "new Lookup"); |
), "new Lookup"); |
48 |
|
|
49 |
ok(my $maxmfn = $isis->open( |
ok(my $maxmfn = $isis->open( |
50 |
path => $isis_file, |
path => $isis_file, |
51 |
code_page => '852', # database encoding |
code_page => 'cp852', # database encoding |
52 |
lookup => $lookup, |
lookup_coderef => sub { |
53 |
|
my $rec = shift || return; |
54 |
|
$lookup->add( $rec ); |
55 |
|
}, |
56 |
), "Input::ISIS->open"); |
), "Input::ISIS->open"); |
57 |
|
|
58 |
ok(my $path = tempdir( CLEANUP => 1 ), "path"); |
ok(my $path = tempdir( CLEANUP => 1 ), "path"); |
62 |
database => '.', |
database => '.', |
63 |
), "new Store"); |
), "new Store"); |
64 |
|
|
|
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"); |
|
|
|
|
65 |
ok(my $norm_pl = read_file( $normalize_set_pl ), "set definitions: $normalize_set_pl" ); |
ok(my $norm_pl = read_file( $normalize_set_pl ), "set definitions: $normalize_set_pl" ); |
66 |
|
|
67 |
ok(my $out = new WebPAC::Output::TT( |
ok(my $out = new WebPAC::Output::TT( |
71 |
|
|
72 |
diag " lookup => ",Dumper($lookup->lookup_hash) if ($debug); |
diag " lookup => ",Dumper($lookup->lookup_hash) if ($debug); |
73 |
|
|
74 |
|
my $t_norm = 0; |
75 |
|
|
76 |
foreach my $pos ( 0 ... $isis->size ) { |
foreach my $pos ( 0 ... $isis->size ) { |
77 |
|
|
78 |
my $row = $isis->fetch || next; |
my $row = $isis->fetch || next; |
80 |
diag " row $pos => ",Dumper($row) if ($debug); |
diag " row $pos => ",Dumper($row) if ($debug); |
81 |
|
|
82 |
my $t = time(); |
my $t = time(); |
83 |
ok(my $ds = $n->data_structure($row), "XML data_structure"); |
ok( my $ds = WebPAC::Normalize::data_structure( |
|
$t1 += time() - $t; |
|
|
|
|
|
diag " ds $pos => ",Dumper($ds) if ($debug); |
|
|
|
|
|
$t = time(); |
|
|
ok( my $ds2 = WebPAC::Normalize::Set::data_structure( |
|
84 |
lookup => $lookup->lookup_hash, |
lookup => $lookup->lookup_hash, |
85 |
row => $row, |
row => $row, |
86 |
rules => $norm_pl, |
rules => $norm_pl, |
87 |
), "Set data_structure"); |
), "Set data_structure"); |
88 |
$t2 += time() - $t; |
$t_norm += time() - $t; |
89 |
|
|
90 |
diag " ds2 $pos => ",Dumper($ds2) if ($debug); |
diag " ds $pos => ",Dumper($ds) if ($debug); |
|
is_deeply( $ds, $ds2, 'ds same for xml and sets'); |
|
91 |
|
|
92 |
ok(my $html = $out->apply( |
ok(my $html = $out->apply( |
93 |
template => 'html.tt', |
template => 'html.tt', |
100 |
|
|
101 |
}; |
}; |
102 |
|
|
103 |
diag sprintf("timings: %.2fs vs %.2fs [%1.2f%%]\n", $t1, $t2, ($t1 / $t2) * 100); |
diag sprintf("timings: %.2fs\n", $t_norm); |