X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=test%2Fapi%2Ft4.c;h=50657ba6aaf7ec9b78d3defa75f873c79c689009;hb=1872e3fc60b482771bbd1cb4b0290b8d6a9ef5d0;hp=820ec362af6af69d053910822458883f2bdc94df;hpb=6c9fcd3b5d3108702fa1ffc92dab4ab6060f9a19;p=idzebra-moved-to-github.git diff --git a/test/api/t4.c b/test/api/t4.c index 820ec36..50657ba 100644 --- a/test/api/t4.c +++ b/test/api/t4.c @@ -1,5 +1,5 @@ -/* $Id: t4.c,v 1.14 2005-01-15 19:38:35 adam Exp $ - Copyright (C) 1995-2005 +/* $Id: t4.c,v 1.23 2007-04-16 08:44:32 adam Exp $ + Copyright (C) 1995-2007 Index Data ApS This file is part of the Zebra server. @@ -15,9 +15,9 @@ FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License -along with Zebra; see the file LICENSE.zebra. If not, write to the -Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA -02111-1307, USA. +along with this program; if not, write to the Free Software +Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ /* t4 - insert a small pile of records, search and fetch them */ @@ -30,58 +30,110 @@ const char *myrec[] = { "\n", 0}; -int main(int argc, char **argv) +#define NUMBER_TO_FETCH_MAX 1000 + +static void tst(int argc, char **argv) { int i; - ZebraService zs = start_up(0, argc, argv); - ZebraHandle zh = zebra_open(zs); + int number_to_be_inserted = 5; + int number_to_fetch = 5; + + ZebraService zs = tl_start_up(0, argc, argv); + ZebraHandle zh = zebra_open(zs, 0); - init_data(zh, myrec); + YAZ_CHECK(tl_init_data(zh, myrec)); - zebra_begin_trans (zh, 1); - for (i = 0; i<1200; i++) + YAZ_CHECK(zebra_begin_trans (zh, 1) == ZEBRA_OK); + + for (i = 0; i< number_to_be_inserted-1; i++) + { /* -1 since already inserted one in init_data */ zebra_add_record(zh, myrec[0], strlen(myrec[0])); - zebra_end_trans(zh); + } + YAZ_CHECK(zebra_end_trans(zh) == ZEBRA_OK); + zebra_close(zh); zebra_stop(zs); - zs = start_service(""); - zh = zebra_open(zs); - zebra_select_database(zh, "Default"); + zs = tl_zebra_start(""); + zh = zebra_open(zs, 0); + YAZ_CHECK(zebra_select_database(zh, "Default") == ZEBRA_OK); + zebra_set_resource(zh, "sortmax", "3"); /* make small sort boundary */ for (i = 0; i<2; i++) { - ZebraRetrievalRecord retrievalRecord[1001]; + ZEBRA_RES ret; + ZebraRetrievalRecord retrievalRecord[NUMBER_TO_FETCH_MAX]; char setname[20]; int j; ODR odr_input = odr_createmem(ODR_DECODE); ODR odr_output = odr_createmem(ODR_DECODE); YAZ_PQF_Parser parser = yaz_pqf_create(); - Z_RPNQuery *query = yaz_pqf_parse(parser, odr_input, - "@attr 1=4 my"); - int hits; + Z_RPNQuery *query = yaz_pqf_parse(parser, odr_input, "@attr 1=4 my"); + zint hits; sprintf(setname, "s%d", i+1); - zebra_search_RPN(zh, odr_input, query, setname, &hits); + ret = zebra_search_RPN(zh, odr_input, query, setname, &hits); + if (ret != ZEBRA_OK) + { + int code = zebra_errCode(zh); + yaz_log(YLOG_WARN, "Unexpected error code=%d", code); + exit(1); + } + if (hits != number_to_be_inserted) + { + yaz_log(YLOG_WARN, "Unexpected hit count " ZINT_FORMAT + "(should be %d)", hits, number_to_be_inserted); + exit(1); + } yaz_pqf_destroy(parser); odr_destroy(odr_input); - zebra_begin_trans(zh, 1); + YAZ_CHECK(zebra_begin_trans(zh, 1) == ZEBRA_OK); - for (j = 0; j<1001; j++) + for (j = 0; j < number_to_fetch; j++) retrievalRecord[j].position = j+1; - zebra_records_retrieve(zh, odr_output, setname, 0, - VAL_TEXT_XML, 1001, retrievalRecord); + ret = zebra_records_retrieve(zh, odr_output, setname, 0, + yaz_oid_xml(), number_to_fetch, + retrievalRecord); + if (ret != ZEBRA_OK) + { + int code = zebra_errCode(zh); + yaz_log(YLOG_FATAL, "zebra_records_retrieve returned error %d", + code); + exit(1); + } - + for (j = 0; j < number_to_fetch; j++) + { + if (!retrievalRecord[j].buf) + { + yaz_log(YLOG_FATAL, "No record buf at position %d", j); + exit(1); + } + if (!retrievalRecord[j].len) + { + yaz_log(YLOG_FATAL, "No record len at position %d", j); + exit(1); + } + } odr_destroy(odr_output); - zebra_end_trans(zh); - + YAZ_CHECK(zebra_end_trans(zh) == ZEBRA_OK); } zebra_commit(zh); - return close_down(zh, zs, 0); + YAZ_CHECK(tl_close_down(zh, zs)); } + +TL_MAIN + +/* + * Local variables: + * c-basic-offset: 4 + * indent-tabs-mode: nil + * End: + * vim: shiftwidth=4 tabstop=8 expandtab + */ +