2 |
|
|
3 |
use strict; |
use strict; |
4 |
|
|
5 |
use Test::More tests => 25; |
use Test::More tests => 43; |
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; |
my $debug = shift @ARGV; |
13 |
|
|
14 |
BEGIN { |
BEGIN { |
15 |
use_ok( 'WebPAC::Normalize::Set' ); |
use_ok( 'WebPAC::Normalize::Set' ); |
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(! $@, $@ ? "error: $@" : "no 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 |
|
ok(! set_lookup( undef ), "set_lookup(undef)"); |
148 |
|
|
149 |
set_rec( $rec1 ); |
set_rec( $rec1 ); |
150 |
|
|
151 |
cmp_ok( join(",", rec2('200','a') ), 'eq', '200a,200a*2' ); |
cmp_ok( join(",", rec2('200','a') ), 'eq', '200a,200a*2', 'join rec2' ); |
152 |
cmp_ok( join(",", rec2('200','a'), rec2('200','b') ), 'eq', '200a,200a*2,200b' ); |
cmp_ok( join(",", rec2('200','a'), rec2('200','b') ), 'eq', '200a,200a*2,200b', 'join rec2 rec2' ); |
153 |
cmp_ok( join(" * ", sort(rec1('200'), rec1('201') )), 'eq', '200a * 200a*2 * 200b * 200c * 200d * 200d*2 * 201x * 201y' ); |
cmp_ok( join(" * ", sort(rec1('200'), rec1('201') )), 'eq', '200a * 200a*2 * 200b * 200c * 200d * 200d*2 * 201x * 201y', 'join sort rec1 rec1' ); |
154 |
|
diag "is_deeply checks\n"; |
155 |
is_deeply( \[ rec1('200') ], \[ qw/200a 200b 200c 200d 200a*2 200d*2/ ] ); |
is_deeply( \[ rec1('200') ], \[ qw/200a 200b 200c 200d 200a*2 200d*2/ ] ); |
156 |
is_deeply( \[ regex( 's/0/o/g', rec1('200') ) ], \[ qw/2ooa 2oob 2ooc 2ood 2ooa*2 2ood*2/ ]); |
is_deeply( \[ regex( 's/0/o/g', rec1('200') ) ], \[ qw/2ooa 2oob 2ooc 2ood 2ooa*2 2ood*2/ ]); |
157 |
is_deeply( \[ grep { /\*/ } regex( 's/0/o/g', rec1('200') ) ], \[ qw/2ooa*2 2ood*2/ ]); |
is_deeply( \[ grep { /\*/ } regex( 's/0/o/g', rec1('200') ) ], \[ qw/2ooa*2 2ood*2/ ]); |
158 |
is_deeply( \[ rec('902') ], \[ '900' ] ); |
is_deeply( \[ rec('902') ], \[ '900' ] ); |
159 |
cmp_ok( rec('902'), 'eq', rec('902','z') ); |
|
160 |
|
cmp_ok( rec('902'), 'eq', rec('902','z'), 'rec sf' ); |
161 |
|
|
162 |
set_lookup( $lookup1 ); |
set_lookup( $lookup1 ); |
163 |
|
|
169 |
) |
) |
170 |
) |
) |
171 |
), |
), |
172 |
'eq', 'lookup 1 i lookup 2'); |
'eq', 'lookup 1 i lookup 2', 'join lookup regex rec2'); |
173 |
|
|
174 |
set_lookup( $lookup2 ); |
set_lookup( $lookup2 ); |
175 |
|
|
176 |
is_deeply( \[ lookup( prefix( '00', rec('902') ) ) ], \[ 'lookup' ] ); |
is_deeply( \[ lookup( prefix( '00', rec('902') ) ) ], \[ 'lookup' ], 'lookup prefix' ); |
177 |
|
|
178 |
ok(! lookup('non-existent') ); |
ok(! lookup('non-existent'), 'lookup non-existant' ); |
179 |
|
|
180 |
set_rec( $rec2 ); |
set_rec( $rec2 ); |
181 |
|
|
210 |
ok(my $ds = get_ds(), "get_ds"); |
ok(my $ds = get_ds(), "get_ds"); |
211 |
diag "ds = ", Dumper($ds) if ($debug); |
diag "ds = ", Dumper($ds) if ($debug); |
212 |
|
|
213 |
|
|
214 |
|
sub test_check_ds { |
215 |
|
|
216 |
|
my $t = shift; |
217 |
|
|
218 |
|
ok($ds = get_ds(), 'get_ds'); |
219 |
|
diag Dumper( $ds ) if ($debug); |
220 |
|
|
221 |
|
ok( $ds && $ds->{something}, 'get_ds->something exists' ); |
222 |
|
ok( $ds && $ds->{something}->{$t}, 'get_ds->something->'.$t.' exists') if ($t); |
223 |
|
ok( $ds && !$ds->{empty}, 'get_ds->empty doesn\'t' ); |
224 |
|
|
225 |
|
return $ds; |
226 |
|
} |
227 |
|
|
228 |
clean_ds(); |
clean_ds(); |
229 |
|
test_s(qq{ search('something', '42'); }); |
230 |
|
test_s(qq{ search('empty', ''); }); |
231 |
|
test_check_ds('search'); |
232 |
|
|
233 |
|
clean_ds(); |
234 |
|
test_s(qq{ display('something', '42'); }); |
235 |
|
test_s(qq{ display('empty', ''); }); |
236 |
|
test_check_ds('display'); |
237 |
|
|
238 |
|
clean_ds(); |
239 |
|
test_s(qq{ tag('something', '42'); }); |
240 |
|
test_s(qq{ tag('empty', ''); }); |
241 |
|
test_check_ds('search'); |
242 |
|
test_check_ds('display'); |
243 |
|
|
244 |
|
clean_ds(); |
245 |
my $n = read_file( "$abs_path/data/normalize.pl" ); |
my $n = read_file( "$abs_path/data/normalize.pl" ); |
246 |
$n .= "\n1;\n"; |
$n .= "\n1;\n"; |
247 |
#diag "normalize code:\n$n\n"; |
#diag "normalize code:\n$n\n"; |