#!/usr/bin/perl -w
-# $Id: irspy.pl,v 1.9 2006-09-27 13:29:31 mike Exp $
+# $Id: irspy.pl,v 1.17 2006-11-28 12:01:54 mike Exp $
#
# Run like this:
-# YAZ_LOG=irspy,irspy_test,irspy_debug perl -I ../lib irspy.pl localhost:3313/IR-Explain---1 bagel.indexdata.dk/gils z3950.loc.gov:7090/Voyager "edcsns17.cr.usgs.gov:6675/CORONA SATELLITE PHOTOGRAPHY"
+# YAZ_LOG=irspy,irspy_test perl -I ../lib irspy.pl -t Quick localhost:3313/IR-Explain---1 bagel.indexdata.dk/gils z3950.loc.gov:7090/Voyager bagel.indexdata.dk:210/marc
+# 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
use strict;
use warnings;
use Getopt::Std;
-use ZOOM::IRSpy;
+use ZOOM::IRSpy::Web;
my %opts;
-if (!getopts('t:', \%opts) || @ARGV < 1) {
+if (!getopts('wt:', \%opts) || @ARGV < 1) {
print STDERR "\
Usage $0: [options] <IRSpy-database> [<target> ...]
If no targets are specified, all targets in DB are tested.
+ -w Use ZOOM::IRSpy::Web subclass
-t <test> Run the specified <test> [default: all tests]
";
exit 1;
}
my($dbname, @targets) = @ARGV;
-my $spy = new ZOOM::IRSpy($dbname, "admin", "fruitbat");
+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 ($res == 0) {
print "All tests were run\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 }