X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=ztest%2Fztest.c;h=77a600d020648949c55a82f69c55294803ae724d;hb=69cc5b167c5afbc8d14c0db30f9a5fb34dda0a24;hp=ce3363e10b281989c37d750c5373bb5dfdfc56ec;hpb=78786494a1fd16e59db481444e042737cabd5cd1;p=yaz-moved-to-github.git diff --git a/ztest/ztest.c b/ztest/ztest.c index ce3363e..77a600d 100644 --- a/ztest/ztest.c +++ b/ztest/ztest.c @@ -2,7 +2,7 @@ * Copyright (C) 1995-2005, Index Data ApS * See the file LICENSE for details. * - * $Id: ztest.c,v 1.77 2006-02-19 18:37:20 adam Exp $ + * $Id: ztest.c,v 1.83 2006-12-06 21:35:59 adam Exp $ */ /* @@ -54,7 +54,17 @@ int ztest_search(void *handle, bend_search_rr *rr) else if(!yaz_matchstr (rr->basenames[0], "Slow")) { #if HAVE_UNISTD_H - sleep(3); + /* wait up to 3 seconds and check if connection is still alive */ + int i; + for (i = 0; i<3; i++) + { + if (!bend_assoc_is_alive(rr->association)) + { + yaz_log(YLOG_LOG, "search aborted"); + break; + } + sleep(1); + } #endif ; } @@ -149,9 +159,9 @@ int ztest_esrequest (void *handle, bend_esrequest_rr *rr) if (!ill_ItemRequest (rr->decode, &item_req, 0, 0)) { yaz_log (log_level, - "Couldn't decode ItemRequest %s near %d", + "Couldn't decode ItemRequest %s near %ld", odr_errmsg(odr_geterror(rr->decode)), - odr_offset(rr->decode)); + (long) odr_offset(rr->decode)); } else yaz_log(log_level, "Decode ItemRequest OK"); @@ -172,9 +182,9 @@ int ztest_esrequest (void *handle, bend_esrequest_rr *rr) if (!ill_APDU (rr->decode, &ill_apdu, 0, 0)) { yaz_log (log_level, - "Couldn't decode ILL APDU %s near %d", + "Couldn't decode ILL APDU %s near %ld", odr_errmsg(odr_geterror(rr->decode)), - odr_offset(rr->decode)); + (long) odr_offset(rr->decode)); yaz_log(log_level, "PDU dump:"); odr_dumpBER(yaz_log_file(), (char *) r->u.single_ASN1_type->buf, @@ -410,16 +420,6 @@ int ztest_esrequest (void *handle, bend_esrequest_rr *rr) } } } - else if (rr->esr->taskSpecificParameters->which == Z_External_update0) - { - yaz_log(log_level, "Received DB Update (version 0)"); - } - else - { - yaz_log (YLOG_WARN, "Unknown Extended Service(%d)", - rr->esr->taskSpecificParameters->which); - - } return 0; } @@ -673,6 +673,12 @@ int ztest_explain(void *handle, bend_explain_rr *rr) return 0; } +int ztest_update(void *handle, bend_update_rr *rr) +{ + rr->operation_status = "success"; + return 0; +} + bend_initresult *bend_init(bend_initrequest *q) { bend_initresult *r = (bend_initresult *) @@ -700,6 +706,7 @@ bend_initresult *bend_init(bend_initrequest *q) q->bend_explain = ztest_explain; #endif q->bend_srw_scan = ztest_scan; + q->bend_srw_update = ztest_update; return r; }