+my $diagset = "dummy";
+$errcode = Net::Z3950::ZOOM::connection_error_x($conn, $errmsg, $addinfo,
+ $diagset);
+ok($errcode == 107 && $diagset eq "Bib-1",
+ "query rejected: error " . $errcode);
+Net::Z3950::ZOOM::query_destroy($q);
+
+# Client-side compiled CQL: this will fail due to lack of config-file
+$q = Net::Z3950::ZOOM::query_create();
+ok(defined $q, "create empty query");
+$res = Net::Z3950::ZOOM::query_cql2rpn($q,
+ 'title=utah and description=epicenter',
+ $conn);
+$errcode = Net::Z3950::ZOOM::connection_error_x($conn, $errmsg, $addinfo,
+ $diagset);
+ok($res < 0 &&
+ $errcode == Net::Z3950::ZOOM::ERROR_CQL_TRANSFORM &&
+ $diagset eq "ZOOM",
+ "can't make CQL2RPN query: error " . $errcode);
+Net::Z3950::ZOOM::query_destroy($q);
+
+# Do a successful client-compiled CQL search
+$q = Net::Z3950::ZOOM::query_create();
+ok(defined $q, "create empty query");
+Net::Z3950::ZOOM::connection_option_set($conn, cqlfile =>
+ "samples/cql/pqf.properties");
+$res = Net::Z3950::ZOOM::query_cql2rpn($q,
+ 'title=utah and description=epicenter',
+ $conn);
+ok($res == 0, "created CQL2RPN query");
+check_record($conn, $q);
+Net::Z3950::ZOOM::query_destroy($q);
+
+# Client-side compiled CCL: this will fail due to incorrect syntax
+$q = Net::Z3950::ZOOM::query_create();
+ok(defined $q, "create empty query");
+my($ccl_errcode, $ccl_errstr, $ccl_errpos) = (0, "", 0);
+
+$res = Net::Z3950::ZOOM::query_ccl2rpn($q,
+ 'ti=utah and',
+ "ti u=4 s=pw\nab u=62 s=pw",
+ $ccl_errcode, $ccl_errstr, $ccl_errpos);
+ok($res < 0 &&
+ $ccl_errcode == Net::Z3950::ZOOM::CCL_ERR_TERM_EXPECTED,
+ "can't make CCL2RPN query: error $ccl_errcode ($ccl_errstr)");
+Net::Z3950::ZOOM::query_destroy($q);
+
+# Do a successful client-compiled CCL search
+$q = Net::Z3950::ZOOM::query_create();
+ok(defined $q, "create empty query");
+$res = Net::Z3950::ZOOM::query_ccl2rpn($q,
+ 'ti=utah and ab=epicenter',
+ "ti u=4 s=pw\nab u=62 s=pw",
+ $ccl_errcode,
+ $ccl_errstr,
+ $ccl_errpos);
+ok($res == 0, "created CCL2RPN query");
+check_record($conn, $q);
+Net::Z3950::ZOOM::query_destroy($q);
+
+Net::Z3950::ZOOM::connection_destroy($conn);
+ok(1, "destroyed all objects");
+
+
+sub check_record {
+ my($conn, $q) = @_;
+
+ my $rs = Net::Z3950::ZOOM::connection_search($conn, $q);
+ my($errcode, $errmsg, $addinfo) = (undef, "dummy", "dummy");
+ $errcode = Net::Z3950::ZOOM::connection_error($conn, $errmsg, $addinfo);
+ ok($errcode == 0, "search");
+
+ my $n = Net::Z3950::ZOOM::resultset_size($rs);
+ ok($n == 1, "found 1 record as expected");
+
+ my $rec = Net::Z3950::ZOOM::resultset_record($rs, 0);
+ ok(1, "got record idenfified by query");
+
+ my $data = Net::Z3950::ZOOM::record_get($rec, "render");
+ ok(1, "rendered record");
+ ok($data =~ /^035 \$a ESDD0006$/m, "record is the expected one");
+
+ Net::Z3950::ZOOM::resultset_destroy($rs);
+}