X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=bin%2Firspy.pl;h=bd6e0f7a6cfb7d7d25c5ea1db558b3d76b875573;hp=8b845c5bad3917e4fc29c671e0c6c192eeaddb9c;hb=7cfd357a4adad76aa368d2198f3756c83e86a708;hpb=2ce1e9134c46d7198b79561de0e6b1448587cf00 diff --git a/bin/irspy.pl b/bin/irspy.pl index 8b845c5..bd6e0f7 100755 --- a/bin/irspy.pl +++ b/bin/irspy.pl @@ -1,9 +1,11 @@ -#!/usr/bin/perl -w +#!/usr/bin/perl -# $Id: irspy.pl,v 1.20 2007-02-06 13:22:16 mike Exp $ -# # Run like this: -# YAZ_LOG=irspy,irspy_test 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 IRSPY_SAVE_XML=1 perl -I../lib irspy.pl -t Quick -r ../etc/dallas.rules localhost:8018/IR-Explain---1 Z39.50:catalog.dallaslibrary.org:210/PAC +# 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,18 +14,37 @@ # irspy_test -- adding, queueing and running tests # irspy_task -- adding, queueing and running tasks -use strict; -use warnings; +# 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 Getopt::Std; use ZOOM::IRSpy::Web; +use Carp; + +use strict; +use warnings; + +$SIG{__DIE__} = sub { + my($msg) = @_; + confess($msg); +}; my %opts; -if (!getopts('wt:', \%opts) || @ARGV < 1) { +if (!getopts('dwt:af:n:m:r:M:', \%opts) || @ARGV < 1) { print STDERR "\ Usage $0: [options] [ ...] -If no targets are specified, all targets in DB are tested. + -d debug -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 + -m , Only test targets whose hash mod is + -r Apply rules found in named file + -M max_depth maximum number of nested template calls and variables/params "; exit 1; } @@ -32,10 +53,40 @@ my($dbname, @targets) = @ARGV; my $class = "ZOOM::IRSpy"; $class .= "::Web" if $opts{w}; -my $spy = $class->new($dbname, "admin", "fruitbat"); -$spy->targets(@targets) if @targets; -$spy->initialise(); -my $res = $spy->check($opts{t}); +if ($opts{M} && $opts{M} > 0) { + no warnings; + $ZOOM::IRSpy::xslt_max_depth = $opts{M}; +} +if ($opts{d}) { + no warnings; + $ZOOM::IRSpy::debug = $opts{d}; +} + +my $spy = $class->new($dbname, "admin", "fruitbat", $opts{n}); +if (@targets) { + $spy->targets(@targets); +} elsif ($opts{f}) { + $spy->find_targets($opts{f}); +} elsif (!$opts{a}) { + print STDERR "$0: specify -a, -f or list of targets\n"; + exit 2; +} + +if (defined $opts{m}) { + my($n, $i) = ($opts{m} =~ /^(\d+),(\d+)$/); + if (!defined $n) { + print STDERR "$0: argument to -m must be of the form ,\n"; + exit 3; + } + $spy->restrict_modulo($n, $i); +} + +if (defined $opts{r}) { + $spy->apply_rules($opts{r}) +} + +$spy->initialise($opts{t}); +my $res = $spy->check(); if ($res == 0) { print "All tests were attempted\n"; } else {