+ Net::Z3950::ZOOM::package_destroy($p);
+ ok(1, "destroyed createdb package");
+}
+
+
+sub dropdb {
+ my($conn, $dbname, $expected_error) = @_;
+
+ my $o = Net::Z3950::ZOOM::options_create();
+ my $p = Net::Z3950::ZOOM::connection_package($conn, $o);
+ # No need to keep ok()ing this, or checking the option-setting
+ Net::Z3950::ZOOM::package_option_set($p, databaseName => $dbname);
+ Net::Z3950::ZOOM::package_send($p, "drop");
+ my($errcode, $errmsg, $addinfo) = (undef, "dummy", "dummy");
+ $errcode = Net::Z3950::ZOOM::connection_error($conn, $errmsg, $addinfo);
+ ok($errcode == $expected_error,
+ ("database drop '$dbname'" . ($errcode ? " refused $errcode" : "") .
+ ($expected_error ? " expected $expected_error but succeeded" : "")));
+
+ Net::Z3950::ZOOM::package_destroy($p);
+ ok(1, "destroyed dropdb package");
+}
+
+
+# We always use "specialUpdate", which adds a record or replaces it if
+# it's already there. By contrast, "insert" fails if the record
+# already exists, and "replace" fails if it does not.
+#
+sub updaterec {
+ my($conn, $id, $file, $expected_error) = @_;
+
+ my $o = Net::Z3950::ZOOM::options_create();
+ my $p = Net::Z3950::ZOOM::connection_package($conn, $o);
+ Net::Z3950::ZOOM::package_option_set($p, action => "specialUpdate");
+ Net::Z3950::ZOOM::package_option_set($p, recordIdOpaque => $id);
+ Net::Z3950::ZOOM::package_option_set($p, record => $file);
+
+ Net::Z3950::ZOOM::package_send($p, "update");
+ my($errcode, $errmsg, $addinfo) = (undef, "dummy", "dummy");
+ $errcode = Net::Z3950::ZOOM::connection_error($conn, $errmsg, $addinfo);
+ ok($errcode == $expected_error, "record update $id" .
+ ($errcode ? " failed $errcode '$errmsg' ($addinfo)" : ""));
+
+ Net::Z3950::ZOOM::package_destroy($p);
+ ok(1, "destroyed update package");
+}
+
+
+sub count_hits {
+ my($conn, $dbname, $query, $expected_error, $expected_count) = @_;
+
+ my $rs = Net::Z3950::ZOOM::connection_search_pqf($conn, $query);
+ my($errcode, $errmsg, $addinfo) = (undef, "dummy", "dummy");
+ $errcode = Net::Z3950::ZOOM::connection_error($conn, $errmsg, $addinfo);
+ ok($errcode == $expected_error, "database '$dbname' " .
+ ($errcode == 0 ? "can be searched" : "not searchable ($errcode)"));
+ return if $errcode != 0;
+ my $n = Net::Z3950::ZOOM::resultset_size($rs);
+ ok($n == $expected_count,
+ "database '$dbname' has $n records (expected $expected_count)");
+}
+
+
+sub content_of {
+ my($filename) = @_;
+
+ use IO::File;
+ my $f = new IO::File("<$filename")
+ or die "can't open file '$filename': $!";
+ my $text = join("", <$f>);
+ $f->close();
+
+ return $text;
+}