X-Git-Url: http://git.indexdata.com/?p=simpleserver-moved-to-github.git;a=blobdiff_plain;f=ztest.pl;h=86ac5c00447415ed6bd323babab7d16d59c59ea2;hp=28c21685dc37016d90eff9ec9a7ae9e6abeaa6b8;hb=f13938aaeb456dc63ceb50a4f41e32e02d62459f;hpb=b18ec135ab08c3234a8f8d5e69e17e8b632b7fcc diff --git a/ztest.pl b/ztest.pl index 28c2168..86ac5c0 100755 --- a/ztest.pl +++ b/ztest.pl @@ -1,6 +1,33 @@ #!/usr/bin/perl -w +## This file is part of simpleserver +## Copyright (C) 2000-2014 Index Data. +## All rights reserved. +## Redistribution and use in source and binary forms, with or without +## modification, are permitted provided that the following conditions are met: +## +## * Redistributions of source code must retain the above copyright +## notice, this list of conditions and the following disclaimer. +## * Redistributions in binary form must reproduce the above copyright +## notice, this list of conditions and the following disclaimer in the +## documentation and/or other materials provided with the distribution. +## * Neither the name of Index Data nor the names of its contributors +## may be used to endorse or promote products derived from this +## software without specific prior written permission. +## +## THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND ANY +## EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +## WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +## DISCLAIMED. IN NO EVENT SHALL THE REGENTS AND CONTRIBUTORS BE LIABLE FOR ANY +## DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES +## (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +## LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND +## ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +## (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF +## THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + use ExtUtils::testlib; +use Data::Dumper; use Net::Z3950::SimpleServer; use Net::Z3950::OID; use strict; @@ -27,7 +54,15 @@ sub my_init_handler { if (defined($args->{PASS}) && defined($args->{USER})) { printf("Received USER/PASS=%s/%s\n", $args->{USER},$args->{PASS}); } - + +} + + +sub my_sort_handler { + my ($args) = @_; + + print "Sort handler called\n"; + print Dumper( $args ); } sub my_scan_handler { @@ -35,6 +70,7 @@ sub my_scan_handler { my $term = $args->{TERM}; my $entries = [ { TERM => 'Number 1', + DISPLAY_TERM => 'Number .1', OCCURRENCE => 10 }, { TERM => 'Number 2', OCCURRENCE => 8 }, @@ -59,12 +95,17 @@ sub my_scan_handler { $args->{ENTRIES} = $entries; $args->{STATUS} = Net::Z3950::SimpleServer::ScanPartial; print "Welcome to scan....\n"; + $args->{EXTRA_RESPONSE_DATA} = 'b'; print "You scanned for term '$term'\n"; } -sub my_search_handler { +my $_fail_frequency = 0; +my $_counter = 0; + +sub my_search_handler { my $args = shift; + my $data = [{ name => "Peter Dornan", title => "Spokesman", @@ -81,19 +122,32 @@ sub my_search_handler { my $session = $args->{HANDLE}; my $set_id = $args->{SETNAME}; + my $rpn = $args->{RPN}; my @database_list = @{ $args->{DATABASES} }; my $query = $args->{QUERY}; + my $facets = $args->{INPUTFACETS}; my $hits = 3; print "------------------------------------------------------------\n"; print "Processing query : $query\n"; printf("Database set : %s\n", join(" ", @database_list)); print "Setname : $set_id\n"; + print " inputfacets:\n"; + print Dumper($facets); + print " extra args:\n"; + print Dumper($args->{EXTRA_ARGS}); print "------------------------------------------------------------\n"; + $args->{OUTPUTFACETS} = $facets; + + $args->{EXTRA_RESPONSE_DATA} = 'b'; $args->{HITS} = $hits; $session->{$set_id} = $data; $session->{__HITS} = $hits; + if ($_fail_frequency != 0 && ++$_counter % $_fail_frequency == 0) { + print "Exiting to be nasty to client\n"; + exit(1); + } } @@ -120,38 +174,24 @@ sub my_fetch_handler { } } +sub my_start_handler { + my $args = shift; + my $config = $args->{CONFIG}; +} + +Net::Z3950::SimpleServer::yazlog("hello"); -my $handler = new Net::Z3950::SimpleServer( +my $handler = new Net::Z3950::SimpleServer( + START => "main::my_start_handler", INIT => "main::my_init_handler", SEARCH => "main::my_search_handler", SCAN => "main::my_scan_handler", + SORT => "main::my_sort_handler", FETCH => "main::my_fetch_handler" ); +if (@ARGV >= 2 && $ARGV[0] eq "-n") { + $_fail_frequency = $ARGV[1]; + shift; + shift; +} $handler->launch_server("ztest.pl", @ARGV); - - -## $Log: ztest.pl,v $ -## Revision 1.12 2004-05-11 12:15:16 sondberg -## Simpleserver is now thread proof. -## -## Revision 1.11 2002/09/16 13:55:53 sondberg -## Added support for authentication into SimpleServer. -## -## Revision 1.10 2001/08/30 13:15:11 sondberg -## Corrected a memory leak, one more to go. -## -## Revision 1.9 2001/08/29 11:48:36 sondberg -## Added routines -## -## Net::Z3950::SimpleServer::ScanSuccess -## Net::Z3950::SimpleServer::ScanPartial -## -## and a bit of documentation. -## -## Revision 1.8 2001/08/24 14:00:20 sondberg -## Added support for scan. -## -## Revision 1.7 2001/03/13 14:20:21 sondberg -## Added CVS logging -## -