#!/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;
-
sub dump_hash {
my $href = shift;
my $key;
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 {
{ TERM => 'Number 10',
OCCURRENCE => 4 },
];
-
-
$args->{NUMBER} = 10;
$args->{ENTRIES} = $entries;
$args->{STATUS} = Net::Z3950::SimpleServer::ScanPartial;
}
+my $_fail_frequency = 0;
+my $_counter = 0;
+
sub my_search_handler {
my $args = shift;
+
my $data = [{
name => "Peter Dornan",
title => "Spokesman",
$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);
+ }
}
}
}
+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.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
-##
-