#!/usr/bin/perl -w
+## This file is part of simpleserver
+## Copyright (C) 2000-2011 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;
-
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",
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 "------------------------------------------------------------\n";
+ $args->{OUTPUTFACETS} = $facets;
+
$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
-##
-