/[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

Annotation of /trunk/t/6-unit.t

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1256 - (hide annotations)
Tue Jul 28 12:40:46 2009 UTC (14 years, 9 months ago) by dpavlin
File MIME type: application/x-troff
File size: 2056 byte(s)
use code from lib insted of blib

1 dpavlin 22 #!/usr/bin/perl -w
2    
3     use strict;
4    
5 dpavlin 767 use Test::More tests => 31;
6 dpavlin 22 use Test::Exception;
7     use Cwd qw/abs_path/;
8     use File::Temp qw/tempdir/;
9 dpavlin 470 use File::Slurp;
10 dpavlin 887 use Data::Dump qw/dump/;
11 dpavlin 489 use Time::HiRes qw/time/;
12 dpavlin 1256 use lib 'lib';
13 dpavlin 22
14 dpavlin 474 my $debug = shift @ARGV;
15 dpavlin 470
16 dpavlin 767 #
17     # FIXME add lookup testing!
18     #
19    
20 dpavlin 22 BEGIN {
21 dpavlin 300 use_ok( 'WebPAC::Input' );
22 dpavlin 209 use_ok( 'WebPAC::Store' );
23 dpavlin 536 use_ok( 'WebPAC::Normalize' );
24 dpavlin 22 use_ok( 'WebPAC::Output::TT' );
25     }
26    
27     ok(my $abs_path = abs_path($0), "abs_path");
28     $abs_path =~ s#/[^/]*$#/#;
29 dpavlin 470 diag "abs_path: $abs_path" if ($debug);
30 dpavlin 22
31     my $isis_file = "$abs_path../t/winisis/BIBL";
32 dpavlin 479 #$isis_file = '/data/hidra/THS/THS';
33 dpavlin 536 #$isis_file = '/data/isis_data/ffkk/';
34 dpavlin 22
35 dpavlin 470 diag "isis_file: $isis_file" if ($debug);
36 dpavlin 22
37 dpavlin 470 my $normalize_set_pl = "$abs_path/data/normalize.pl";
38     my $lookup_file = "$abs_path../conf/lookup/isis.pm";
39    
40 dpavlin 300 ok(my $isis = new WebPAC::Input(
41     module => 'WebPAC::Input::ISIS',
42 dpavlin 489 limit => 100,
43     no_progress_bar => 1,
44 dpavlin 22 ), "new Input::ISIS");
45    
46     ok(my $maxmfn = $isis->open(
47 dpavlin 300 path => $isis_file,
48 dpavlin 1100 input_encoding => 'cp852', # database encoding
49 dpavlin 585 lookup_coderef => sub {
50     my $rec = shift || return;
51 dpavlin 767 ok($rec, 'lookup_coderef has rec');
52     ok(defined($rec->{'000'}->[0]), 'have mfn');
53 dpavlin 585 },
54 dpavlin 22 ), "Input::ISIS->open");
55    
56     ok(my $path = tempdir( CLEANUP => 1 ), "path");
57    
58 dpavlin 887 ok(my $db = new WebPAC::Store({
59 dpavlin 217 database => '.',
60 dpavlin 887 }), "new Store");
61 dpavlin 22
62 dpavlin 470 ok(my $norm_pl = read_file( $normalize_set_pl ), "set definitions: $normalize_set_pl" );
63    
64 dpavlin 22 ok(my $out = new WebPAC::Output::TT(
65     include_path => "$abs_path../conf/output/tt",
66     filters => { foo => sub { shift } },
67     ), "new Output::TT");
68    
69 dpavlin 536 my $t_norm = 0;
70    
71 dpavlin 482 foreach my $pos ( 0 ... $isis->size ) {
72 dpavlin 470
73 dpavlin 482 my $row = $isis->fetch || next;
74    
75 dpavlin 887 diag " row $pos => ",dump($row) if ($debug);
76 dpavlin 474
77 dpavlin 489 my $t = time();
78 dpavlin 536 ok( my $ds = WebPAC::Normalize::data_structure(
79 dpavlin 491 row => $row,
80     rules => $norm_pl,
81     ), "Set data_structure");
82 dpavlin 536 $t_norm += time() - $t;
83 dpavlin 489
84 dpavlin 887 diag " ds $pos => ",dump($ds) if ($debug);
85 dpavlin 489
86 dpavlin 33 ok(my $html = $out->apply(
87 dpavlin 22 template => 'html.tt',
88 dpavlin 70 data => $ds,
89 dpavlin 22 ), "apply");
90    
91 dpavlin 33 $html =~ s#\s*[\n\r]+\s*##gs;
92    
93 dpavlin 352 #diag $html;
94 dpavlin 33
95 dpavlin 22 };
96 dpavlin 489
97 dpavlin 536 diag sprintf("timings: %.2fs\n", $t_norm);

Properties

Name Value
svn:executable *

  ViewVC Help
Powered by ViewVC 1.1.26