X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=t%2F25-scan.t;h=01aba9e01d83536e44b77d1f9f4b5cf5e5eb7ea8;hb=87c72eaf97a3dbf51a93dab782c2909539addc48;hp=8c5bf6ec584779b1d923b6d803c07e5c7a01b00c;hpb=9062d7da896821e46a940d908494ac42b1f3ec74;p=ZOOM-Perl-moved-to-github.git diff --git a/t/25-scan.t b/t/25-scan.t index 8c5bf6e..01aba9e 100644 --- a/t/25-scan.t +++ b/t/25-scan.t @@ -1,5 +1,3 @@ -# $Id: 25-scan.t,v 1.6 2005-12-21 00:16:50 mike Exp $ - # Before `make install' is performed this script should be runnable with # `make test'. After `make install' it should work as `perl 25-scan.t' @@ -9,12 +7,12 @@ use Test::More tests => 81; BEGIN { use_ok('ZOOM') }; -#my $host = "indexdata.com/gils"; -my $host = "localhost:9999/default"; +my $host = "z3950.indexdata.com/gils"; my $conn; eval { $conn = new ZOOM::Connection($host, 0) }; ok(!$@, "connection to '$host'"); +$conn->option(number => 10); my($ss, $n) = scan($conn, 0, "w", 10); my @terms = (); @@ -30,7 +28,8 @@ foreach my $i (1 .. $n) { (my $disp, $occ) = $ss->display_term($i-1); ok(defined $disp, "display term $i of $n: '$disp' ($occ occurences)"); - ok($disp eq $term, "display term $i identical to term"); + ok(lc($disp) eq lc($term), + "display term $i ($disp) equivalent to term ($term)"); } $ss->destroy(); @@ -50,7 +49,14 @@ foreach my $i (1 .. $n) { "got title term $i of $n: '$term' ($occ occurences)"); ok($term ge $previous, "title term '$term' ge previous '$previous'"); $previous = $term; - ok((grep { $term eq $_ } @terms), "title term was in term list"); + + # Previously we used to assert that the each title-term was + # included in the initial term-list that we got by scanning across + # all indexes. Of course this will not in general be true, + # because not all terms are title terms, which means that the $n + # title terms will include some that are past the end of $n + # general terms. So remove that test. + #ok((grep { $term eq $_ } @terms), "title term ($term) was in term list (@terms)"); } $ss->destroy(); @@ -61,7 +67,7 @@ ok(1, "destroyed second scanset"); $conn->option(number => 4); $conn->option(cqlfile => "samples/cql/pqf.properties"); -($ss, $n) = scan($conn, 1, new ZOOM::Query::CQL('title=w'), 4); +($ss, $n) = scan($conn, 1, new ZOOM::Query::CQL2RPN('title=w', $conn), 4); # Get last term and use it as seed for next scan my($term, $occ) = $ss->term($n-1); ok($ss->option("position") == 1, @@ -72,6 +78,18 @@ ok(defined $term, $ss->destroy(); ok(1, "destroyed third scanset"); +$conn->option(cclfile => "samples/ccl/default.bib"); +($ss, $n) = scan($conn, 1, new ZOOM::Query::CCL2RPN('ti=w', $conn), 4); +# Get last term and use it as seed for next scan +($term, $occ) = $ss->term($n-1); +ok($ss->option("position") == 1, + "seed-term is start of returned list"); +ok(defined $term, + "got last title term '$term' to use as seed"); + +$ss->destroy(); +ok(1, "destroyed fourth scanset"); + # We want the seed-term to be in "position zero", i.e. just before the start $conn->option(position => 0); ($ss, $n) = scan($conn, 0, "\@attr 1=4 $term", 2); @@ -84,7 +102,7 @@ ok($ss->option("position") eq "fruit", "option setting/getting works"); $ss->destroy(); -ok(1, "destroyed fourth scanset"); +ok(1, "destroyed fifth scanset"); # Some more testing still to do: see comment in "15-scan.t" @@ -104,6 +122,6 @@ sub scan { my $n = $ss->size(); ok(defined $n, "got size"); - ok($n == $nexpected, "got $n terms (expected $nexpected)"); + ok($n == $nexpected, "got $n terms for '$startterm' (expected $nexpected)"); return ($ss, $n); }