-/* $Id: t4.c,v 1.7 2004-06-14 23:43:32 adam Exp $
- Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004
- Index Data Aps
+/* $Id: t4.c,v 1.16 2005-04-14 12:01:50 adam Exp $
+ Copyright (C) 1995-2005
+ Index Data ApS
This file is part of the Zebra server.
02111-1307, USA.
*/
-#include <yaz/log.h>
-#include <yaz/pquery.h>
-#include <zebraapi.h>
+/* t4 - insert a small pile of records, search and fetch them */
-/* read zebra.cfg from env var srcdir if it exists; otherwise current dir */
-static ZebraService start_service()
-{
- char cfg[256];
- char *srcdir = getenv("srcdir");
- sprintf(cfg, "%.200s%szebra.cfg", srcdir ? srcdir : "", srcdir ? "/" : "");
- return zebra_start(cfg, 0, 0);
-}
+#include "testlib.h"
+
+const char *myrec[] = {
+ "<gils>\n"
+ " <title>My title</title>\n"
+ "</gils>\n",
+ 0};
+#define NUMBER_TO_FETCH_MAX 1000
+
int main(int argc, char **argv)
{
int i;
- ZebraService zs;
- ZebraHandle zh;
- const char *myrec =
- "<gils>\n"
- " <title>My title</title>\n"
- "</gils>\n";
+ int number_to_be_inserted = 5;
+ int number_to_fetch = 5;
- yaz_log_init_file("t4.log");
+ ZebraService zs = start_up(0, argc, argv);
+ ZebraHandle zh = zebra_open(zs);
- nmem_init ();
-
- zs = start_service();
- zh = zebra_open (zs);
- zebra_init(zh);
- zebra_select_database(zh, "Default");
+ init_data(zh, myrec);
zebra_begin_trans (zh, 1);
- for (i = 0; i<1200; i++)
- zebra_add_record (zh, myrec, strlen(myrec));
- zebra_end_trans (zh);
+ 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);
zebra_close(zh);
zebra_stop(zs);
- zs = start_service();
- zh = zebra_open (zs);
+ zs = start_service("");
+ zh = zebra_open(zs);
zebra_select_database(zh, "Default");
+ zebra_set_resource(zh, "sortmax", "3"); /* make small sort boundary */
for (i = 0; i<2; i++)
{
- ZebraRetrievalRecord retrievalRecord[1001];
+ 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);
+ 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);
+ zebra_search_RPN(zh, odr_input, query, setname, &hits);
+ 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);
+ odr_destroy(odr_input);
- zebra_begin_trans (zh, 1);
+ zebra_begin_trans(zh, 1);
- 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);
-
-
- odr_destroy (odr_output);
-
- zebra_end_trans (zh);
+ zebra_records_retrieve(zh, odr_output, setname, 0,
+ VAL_TEXT_XML, number_to_fetch, retrievalRecord);
+
+ if (zebra_errCode(zh))
+ {
+ yaz_log(YLOG_FATAL, "zebra_records_retrieve returned error %d",
+ zebra_errCode(zh));
+ 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);
}
- zebra_commit (zh);
- zebra_close (zh);
- zebra_stop (zs);
-
- nmem_exit ();
- xmalloc_trav ("x");
- exit (0);
+ zebra_commit(zh);
+ return close_down(zh, zs, 0);
}