X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=bin%2Firspy.pl;h=3a8918fbb2fd13e0e3833d3e726b7e0c8a8a55ea;hp=e6c2cc34f2fe3aa341578ce96176a9c7d41abe86;hb=03aabcf071b8cfc5ace823f7f672f28496054211;hpb=9ba276aad41eedd554c87cb6518a88edb8e2f6dc diff --git a/bin/irspy.pl b/bin/irspy.pl index e6c2cc3..3a8918f 100755 --- a/bin/irspy.pl +++ b/bin/irspy.pl @@ -1,38 +1,85 @@ #!/usr/bin/perl -w -# $Id: irspy.pl,v 1.2 2006-07-19 11:52:24 mike Exp $ +# $Id: irspy.pl,v 1.29 2007-09-18 16:58:18 mike Exp $ # # Run like this: -# YAZ_LOG=irspy,irspy_test,irspy_debug perl -I ../lib irspy.pl -t "bagel.indexdata.dk/gils z3950.loc.gov:7090/Voyager" localhost:1313/IR-Explain---1 +# 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) +# irspy_event -- invocations of ZOOM_event() and individual events +# irspy_unhandled -- unhandled events (not very interesting) +# 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; +use ZOOM::IRSpy::Web; +use Carp; + +$SIG{__DIE__} = sub { + my($msg) = @_; + confess($msg); +}; my %opts; -if (!getopts('t:au', \%opts) || @ARGV != 1) { - print STDERR qq[Usage: $0 [options] - -t Space-separated list of targets to check - -a Check all targets registered in database - -u Update information in database -]; +if (!getopts('wt:af:n:m:', \%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 + -m , Only test targets whose hash mod is +"; exit 1; } -my $dbname = $ARGV[0]; -my $targetList = $opts{t}; -if (!defined $targetList && !$opts{a}) { - print STDERR "$0: neither -t nor -a specified\n"; +my($dbname, @targets) = @ARGV; +my $class = "ZOOM::IRSpy"; +$class .= "::Web" if $opts{w}; + +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; } -my $spy = new ZOOM::IRSpy($dbname); -$spy->targets($targetList) if defined $targetList; -$spy->initialise(); +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); +} + +$spy->initialise($opts{t}); my $res = $spy->check(); if ($res == 0) { - print "All tests were run\n"; + print "All tests were attempted\n"; } else { - print "Some tests were skipped\n"; + print "$res tests were skipped\n"; } + + +# Fake the HTML::Mason class that ZOOM::IRSpy::Web uses +package HTML::Mason::Commands; +BEGIN { our $m = bless {}, "HTML::Mason::Commands" } +sub flush_buffer { print shift(), " flushing\n" if 0 }