X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=bin%2Firspy.pl;h=3da9d3d21e4f5020deb3df315ad9c0dee50c097c;hp=d7fda0679fb0847f537fcdaf31085f6dff47dd8c;hb=42230aa27465503450d2f461cf7d96fb5410beb8;hpb=32552630322fe65ac28b910303ec6d00d16bd2a1 diff --git a/bin/irspy.pl b/bin/irspy.pl index d7fda06..3da9d3d 100755 --- a/bin/irspy.pl +++ b/bin/irspy.pl @@ -1,9 +1,12 @@ #!/usr/bin/perl -w -# $Id: irspy.pl,v 1.22 2007-02-23 16:44:50 mike Exp $ +# $Id: irspy.pl,v 1.28 2007-05-09 11:07:03 mike Exp $ # # Run like this: -# YAZ_LOG=irspy,irspy_test IRSPY_SAVE_XML=1 perl -I../lib irspy.pl -t Quick localhost:8018/IR-Explain---1 z3950.loc.gov:7090/Voyager bagel.indexdata.dk/gils bagel.indexdata.dk:210/marc +# YAZ_LOG=irspy,irspy_test IRSPY_SAVE_XML=1 perl -I../lib irspy.pl -t Quick localhost:8018/IR-Explain---1 Z39.50:amicus.oszk.hu:1616/ANY +# YAZ_LOG=irspy,irspy_test sudo ./setrlimit -n 3000 -u mike -- perl -I../lib irspy.pl -t Main -a localhost:8018/IR-Explain---1 +# YAZ_LOG=irspy,irspy_test perl -I../lib irspy.pl -t Main -a -n 100 localhost:8018/IR-Explain---1 +# # Available log-levels are as follows: # irspy -- high-level application logging # irspy_debug -- low-level debugging (not very interesting) @@ -12,19 +15,33 @@ # irspy_test -- adding, queueing and running tests # irspy_task -- adding, queueing and running tasks +# I have no idea why this directory is not in Ubuntu's default Perl +# path, but we need it because just occasionally overload.pm:88 +# requires Scalar::Util, which is in this directory. + +use lib '/usr/share/perl/5.8.7'; +use Scalar::Util; + use strict; use warnings; use Getopt::Std; use ZOOM::IRSpy::Web; +use Carp; + +$SIG{__DIE__} = sub { + my($msg) = @_; + confess($msg); +}; my %opts; -if (!getopts('wt:af:', \%opts) || @ARGV < 1) { +if (!getopts('wt:af:n:', \%opts) || @ARGV < 1) { print STDERR "\ Usage $0: [options] [ ...] -w Use ZOOM::IRSpy::Web subclass -t Run the specified [default: all tests] -a Test all targets (slow!) -f Test targets found by the specified query + -n Number of connection to keep in active set "; exit 1; } @@ -33,7 +50,7 @@ my($dbname, @targets) = @ARGV; my $class = "ZOOM::IRSpy"; $class .= "::Web" if $opts{w}; -my $spy = $class->new($dbname, "admin", "fruitbat"); +my $spy = $class->new($dbname, "admin", "fruitbat", $opts{n}); if (@targets) { $spy->targets(@targets); } elsif ($opts{f}) { @@ -43,8 +60,8 @@ if (@targets) { exit 1; } -$spy->initialise(); -my $res = $spy->check($opts{t}); +$spy->initialise($opts{t}); +my $res = $spy->check(); if ($res == 0) { print "All tests were attempted\n"; } else {