Put local variables footer in all c, h files.
[idzebra-moved-to-github.git] / test / api / t4.c
index b38a9a5..85a57ab 100644 (file)
@@ -1,6 +1,6 @@
-/* $Id: t4.c,v 1.11 2004-10-29 13:02:39 heikki Exp $
-   Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004
-   Index Data Aps
+/* $Id: t4.c,v 1.20 2006-05-10 08:13:35 adam Exp $
+   Copyright (C) 1995-2005
+   Index Data ApS
 
 This file is part of the Zebra server.
 
@@ -30,58 +30,110 @@ const char *myrec[] = {
         "</gils>\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);
+
+    YAZ_CHECK(tl_init_data(zh, myrec));
 
-    init_data(zh,myrec);
+    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]));
+    }
+    YAZ_CHECK(zebra_end_trans(zh) == ZEBRA_OK);
 
-    zebra_begin_trans (zh, 1);
-    for (i = 0; i<1200; i++)
-       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);
-    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);    
+        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);
+        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,
+                                    VAL_TEXT_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);
+
+        YAZ_CHECK(zebra_end_trans(zh) == ZEBRA_OK);
+    }
+    zebra_commit(zh);
+    YAZ_CHECK(tl_close_down(zh, zs));
+}
 
-        odr_destroy (odr_output);
+TL_MAIN
 
-        zebra_end_trans (zh);
+/*
+ * Local variables:
+ * c-basic-offset: 4
+ * indent-tabs-mode: nil
+ * End:
+ * vim: shiftwidth=4 tabstop=8 expandtab
+ */
 
-    }
-    zebra_commit (zh);
-    return close_down(zh,zs,0);
-}