X-Git-Url: http://git.indexdata.com/?p=simpleserver-moved-to-github.git;a=blobdiff_plain;f=ztest.pl;h=ea330b0b2e1449eb9bf82980f915fb9299a93bd4;hp=7ed6b682767084f9301d63a2472158c878b3bdd7;hb=91eca62980c3a849143dbcce16d60c8316a52b01;hpb=382b672ba466b8a986b8ffe4d9984df610763035 diff --git a/ztest.pl b/ztest.pl index 7ed6b68..ea330b0 100755 --- a/ztest.pl +++ b/ztest.pl @@ -1,6 +1,35 @@ #!/usr/bin/perl -w +## $Id: ztest.pl,v 1.17 2007-03-08 14:51:32 mike Exp $ +## ------------------------------------------------------------------ +## +## Copyright (c) 2000-2004, Index Data. +## +## Permission to use, copy, modify, distribute, and sell this software and +## its documentation, in whole or in part, for any purpose, is hereby granted, +## provided that: +## +## 1. This copyright and permission notice appear in all copies of the +## software and its documentation. Notices of copyright or attribution +## which appear at the beginning of any file must remain unchanged. +## +## 2. The name of Index Data or the individual authors may not be used to +## endorse or promote products derived from this software without specific +## prior written permission. +## +## THIS SOFTWARE IS PROVIDED "AS IS" AND WITHOUT WARRANTY OF ANY KIND, +## EXPRESS, IMPLIED, OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY +## WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. +## IN NO EVENT SHALL INDEX DATA BE LIABLE FOR ANY SPECIAL, INCIDENTAL, +## INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, OR ANY DAMAGES +## WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER OR +## NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF +## LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE +## OF THIS SOFTWARE. +## + use ExtUtils::testlib; +use Data::Dumper; use Net::Z3950::SimpleServer; use Net::Z3950::OID; use strict; @@ -20,9 +49,22 @@ sub my_init_handler { my $session = {}; $args->{IMP_NAME} = "DemoServer"; + $args->{IMP_ID} = "81"; $args->{IMP_VER} = "3.14159"; $args->{ERR_CODE} = 0; $args->{HANDLE} = $session; + 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 { @@ -58,8 +100,12 @@ sub my_scan_handler { } +my $_fail_frequency = 0; +my $_counter = 0; + sub my_search_handler { my $args = shift; + my $data = [{ name => "Peter Dornan", title => "Spokesman", @@ -89,6 +135,10 @@ sub my_search_handler { $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); + } } @@ -115,32 +165,18 @@ sub my_fetch_handler { } } +Net::Z3950::SimpleServer::yazlog("hello"); my $handler = new Net::Z3950::SimpleServer( - INIT => \&my_init_handler, - SEARCH => \&my_search_handler, - SCAN => \&my_scan_handler, - FETCH => \&my_fetch_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.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 -## -